Синхронизация:Механизм двусторонней синхронизации

Материал из wiki.standart-n.ru
Версия от 13:17, 2 октября 2018; Olgav (обсуждение | вклад)

(разн.) ← Предыдущая | Текущая версия (разн.) | Следующая → (разн.)
Перейти к: навигация, поиск

Используемые сокращения

ГБ - Глобальная база
КБ - Клиентская база

СТРУКТУРА G$DISTRIBUTE

Данная таблица заполняется 
1) триггерами, каждая запись соответствует определенной операцией с синхронизируемой таблицей – для отправки 
2) Входящими данными синхронизации – для приема данных.  
ID – Ключ таблицы
TABLENAME – Имя таблицы
UUID – Уникальный строковый идентификатор таблицы TABLENAME
PACKET – Показатель изменения записи на КБ. (Инкрементируется в текущей КБ)
SOPER – Вид операции с таблицей TABLENAME. 0 – INSERT, 1 – UPDATE, 2 - DELETE
FROM_PROFILE_ID – 1) NULL: данная запись появилась в текущей КБ 2) 0:данная запись появилась на ГБ 3) Код профиля: код профиля с которого пришла запись
TO_PROFILE_ID – пока не используется
SERVERPACKET – Показатель изменения записи на ГБ. (Инкрементируется на ГБ)
INSERTDT – Дата вставки записи.
RELATIONTYPE - Для частично реплицируемых таблиц. 0 - полная репликация 1 – частичная. Устанавливается триггером или процедурой или скриптом getrelationtype.php, для конкретной сети.

КБ --> ГБ

1. Находим максимальный загруженный packet в ГБ данного профиля. Select max(packet) from g$distribute where from_profile_id=:profile_id.
2. Подготавливаем пакет для сервера от максимально загруженного на сервер до последнего, что есть в G$DISTRIBUTE. 
   select d.uuid, trim(d.tablename) as tablename, d.packet, d.soper from G$DISTRIBUTE d where (d.FROM_PROFILE_ID is null) and d.packet>:max_packet order by d.packet 
3. В текстовый файл для каждой выбранной записи в предыдущем запросе записываются данные: вид операции, имя таблицы, уникальный идентификатор, значения и имена всех полей таблицы. 
   Если установлено ограничение максимального размера пакета для двухсторонней синхронизации, то данные могут уйти не все за один раз.
4. Данный пакет отправляется на сервер, где ставится в очередь загрузки или загружается в ГБ.

ГБ --> КБ

1. Находим максимальный загруженный serverpacket в КБ' в G$DISTRIBUTE. Select max(serverpacket) from g$distribute where from_profile_id is not null.
2. Дается команда скриптам на сервере, собрать пакет для текущего профиля. От максимально загруженного serverpacket до последнего serverpacket, что есть в G$DISTRIBUTE в ГБ. 
   select d.uuid, trim(d.tablename) as tablename,    iif(d.packet is null, 0, d.packet), d.soper, SERVERPACKET, FROM_PROFILE_ID from G$DISTRIBUTE d where (serverpacket>:max_server_packet) order by d.serverpacket
3. В текстовый файл для каждой выбранной записи в предыдущем запросе записываются данные: вид операции, имя таблицы, уникальный идентификатор, значения и имена всех полей таблицы.
4. Данный пакет принимается и загружается в КБ.