Ver Mensaje Individual
  #1  
Antiguo 12-11-2011
Avatar de AzidRain
[AzidRain] AzidRain is offline
Miembro Premium
 
Registrado: sep 2005
Ubicación: Córdoba, Veracruz, México
Posts: 2.914
Reputación: 21
AzidRain Va camino a la fama
Base de datos por contingencia

Sea un sistema cliente basado en MySQL (básicamente facturación, logística y administración de transporte). Hay varias sucursales, todas conectadas directamente al servidor de la casa matriz. En diversas tablas se hace uso extensivo de claves autogeneradas para controlar algunos documentos (órdenes de cobro, números de embarque, etc.) Hay una tabla en especial, la de clientes, que es mantenida por todas las sucursales ya que todas dan de alta nuevos clientes todos los días De manera que en todas las sucursales tienen acceso a consultar información generada en cualquier otra prácticamente en tiempo real via internet.

Ahora bien, en el supuesto de que no haya conexión de internet, ninguna sucursal puede hacer nada en el sistema, ni siquiera loguearse pues no tiene acceso a la base de datos.

Estoy pensando en una forma de lograr que cada sucursal durante una contingencia de este tipo pueda seguir trabajando normal, lo cual no es problema pues con instalar un servidor local en cada una y activarlo en estos casos se resuelve. El problema viene cuando pasa la contingencia, nos encontraremos con bases de datos totalmente diferentes, en el caso de los clientes pudiera darse el caso de que un mismo cliente hubiera sido dado de alta 2 o mas veces en las sucursales debido a que no se tiene acceso al registro "maestro" por decirlo así.

El problema que quiero consultarles es como hacer un esquema que permita recuperar toda la información generada por las sucursales, y "normalizarla" para que siga con las numeraciones y demás que ya tenía el servidor maestro. He pensando en agregar una función para utilizarse en el programa conectado al servidor principal que reprocese cada tabla modificada, la copie a sus datos y le añada las claves que le toquen por decir algo si la sucursal x hizo ordenes de cobro del 1 al 100, copiar los datos y cambiarle del 5000 al 5100 que son los que le hubieran tocado de haber habido línea, obviamente haciendo todos los cambios en cascada a las tablas dependientes.
En cuanto a las facturas no hay problema porque son únicas para cada sucursal y en ese caso no son autoincrementados si no una combinación de un numero de folio y una serie que identifica la sucursal.


En MySQL ya probé la sincronización, pero no me sirve porque es de una sola vía aunque al final creo que será la única forma.

¿Alguna idea?
__________________
AKA "El animalito" ||Cordobés a mucha honra||
Responder Con Cita