SymmetricDS 仅以一种方式同步
SymmetricDS only synchronizes one way
同步仅适用于从客户端到-> 服务器,与配置的内容无关
--------------------------------------------------------------------------
-- Node Groups
------------------------------------------------------------------------------
insert into sym_node_group (node_group_id) values ('client');
------------------------------------------------------------------------------
-- Node Group Links
------------------------------------------------------------------------------
-- server sends changes to client when client pulls from server
insert into sym_node_group_link (source_node_group_id, target_node_group_id, data_event_action, is_reversible)
values ('server', 'client', 'W', 1);
-- client sends changes to server when client pushes to server
insert into sym_node_group_link (source_node_group_id, target_node_group_id, data_event_action, is_reversible)
values ('client', 'server', 'P', 1);
------------------------------------------------------------------------------
-- Channels
------------------------------------------------------------------------------
insert into sym_channel
(channel_id, processing_order, max_batch_size, enabled, description)
values('XXX', 1, 100000, 1, 'Everything');
------------------------------------------------------------------------------
-- Routers
------------------------------------------------------------------------------
insert into sym_router
(router_id,source_node_group_id,target_node_group_id,router_type,create_time,last_update_time)
values('server_2_client', 'server', 'client', 'default',current_timestamp, current_timestamp);
insert into sym_router
(router_id,source_node_group_id,target_node_group_id,router_type,create_time,last_update_time)
values('client_2_server', 'client', 'server', 'default',current_timestamp, current_timestamp);
------------------------------------------------------------------------------
-- Triggers
------------------------------------------------------------------------------
insert into SYM_TRIGGER (trigger_id, source_table_name,
channel_id, last_update_time, create_time)
values ('client_2_server', '*', 'XXX', current_timestamp, current_timestamp);
insert into SYM_TRIGGER (trigger_id, source_table_name,
channel_id, last_update_time, create_time)
values ('server_2_client', '*', 'XXX', current_timestamp, current_timestamp);
------------------------------------------------------------------------------
-- SYM_TRIGGER_ROUTER
------------------------------------------------------------------------------
insert into SYM_TRIGGER_ROUTER (trigger_id, router_id, initial_load_order, create_time, last_update_time)
values ('client_2_server', 'client_2_server', 100, current_timestamp, current_timestamp);
insert into SYM_TRIGGER_ROUTER (trigger_id, router_id, initial_load_order, create_time, last_update_time)
values ('server_2_client', 'server_2_client', 200, current_timestamp, current_timestamp);
您缺少 sym_node_group 中的插入(除非您的 post 中存在复制粘贴错误):
insert into sym_node_group (node_group_id) values ('server');
此外,将 is_reversible 的 sym_node_group_link 行设置为 0。这是您不需要的实验性功能。要获得双向复制,你只需要在每个方向上都有一个组 link,你已经有了。
由于我的配置是在SymetricEngine启动后添加的(它是用Flyway插入到数据库中的)
我需要手动触发同步。
ServerSymmetricEngine serverEngine = new ServerSymmetricEngine(new File(url.getPath()));
serverEngine.setDeploymentType("server");
serverEngine.setup();
serverEngine.start();
// Here was the script inserts by flyway
serverEngine.syncTriggers();
同步仅适用于从客户端到-> 服务器,与配置的内容无关
--------------------------------------------------------------------------
-- Node Groups
------------------------------------------------------------------------------
insert into sym_node_group (node_group_id) values ('client');
------------------------------------------------------------------------------
-- Node Group Links
------------------------------------------------------------------------------
-- server sends changes to client when client pulls from server
insert into sym_node_group_link (source_node_group_id, target_node_group_id, data_event_action, is_reversible)
values ('server', 'client', 'W', 1);
-- client sends changes to server when client pushes to server
insert into sym_node_group_link (source_node_group_id, target_node_group_id, data_event_action, is_reversible)
values ('client', 'server', 'P', 1);
------------------------------------------------------------------------------
-- Channels
------------------------------------------------------------------------------
insert into sym_channel
(channel_id, processing_order, max_batch_size, enabled, description)
values('XXX', 1, 100000, 1, 'Everything');
------------------------------------------------------------------------------
-- Routers
------------------------------------------------------------------------------
insert into sym_router
(router_id,source_node_group_id,target_node_group_id,router_type,create_time,last_update_time)
values('server_2_client', 'server', 'client', 'default',current_timestamp, current_timestamp);
insert into sym_router
(router_id,source_node_group_id,target_node_group_id,router_type,create_time,last_update_time)
values('client_2_server', 'client', 'server', 'default',current_timestamp, current_timestamp);
------------------------------------------------------------------------------
-- Triggers
------------------------------------------------------------------------------
insert into SYM_TRIGGER (trigger_id, source_table_name,
channel_id, last_update_time, create_time)
values ('client_2_server', '*', 'XXX', current_timestamp, current_timestamp);
insert into SYM_TRIGGER (trigger_id, source_table_name,
channel_id, last_update_time, create_time)
values ('server_2_client', '*', 'XXX', current_timestamp, current_timestamp);
------------------------------------------------------------------------------
-- SYM_TRIGGER_ROUTER
------------------------------------------------------------------------------
insert into SYM_TRIGGER_ROUTER (trigger_id, router_id, initial_load_order, create_time, last_update_time)
values ('client_2_server', 'client_2_server', 100, current_timestamp, current_timestamp);
insert into SYM_TRIGGER_ROUTER (trigger_id, router_id, initial_load_order, create_time, last_update_time)
values ('server_2_client', 'server_2_client', 200, current_timestamp, current_timestamp);
您缺少 sym_node_group 中的插入(除非您的 post 中存在复制粘贴错误):
insert into sym_node_group (node_group_id) values ('server');
此外,将 is_reversible 的 sym_node_group_link 行设置为 0。这是您不需要的实验性功能。要获得双向复制,你只需要在每个方向上都有一个组 link,你已经有了。
由于我的配置是在SymetricEngine启动后添加的(它是用Flyway插入到数据库中的)
我需要手动触发同步。
ServerSymmetricEngine serverEngine = new ServerSymmetricEngine(new File(url.getPath()));
serverEngine.setDeploymentType("server");
serverEngine.setup();
serverEngine.start();
// Here was the script inserts by flyway
serverEngine.syncTriggers();