【Oracle】公安内网+互联网数据同步机制分析?

公安内网与互联网数据同步机制分析(这里指的是脱敏数据)

1、项目背景

原则上,公安内网数据是无法同步到互联网,也是不被允许的。但是为了一些业务的需要(例如,内网办理的业务要及时反馈给用户),这里就需要内外网同步机制。在不违规又能满足条件的情况下,数据必须脱敏,且需要在前置机上完成。

2、解决方案

@1、数据库与数据库之间的同步
@2、外网通过SOAP+地址映射,主动进内网拉取数据。

3、重点讨论

数据库之间的同步机制:
有三个数据结构相同的表,A/B/C,主键为自增ID
A、C在互联网,B表在公安内网,当A表数据有变化时,会触发同步机制,A表中的数据会立马同步的B表中,B表数据变化,会立马同步到C表。这个机制看似很合理,保证了三个表永远数据相同,但是一旦用户在内网进行数据操作后,B表中新增了数据,立马会同步到C,此时B/C是相同的,但是A表明显是滞后的,此时用户在外网中进行数据操作后,A同步到B的时候,就会发现主键冲突了。同步就会中断,无法满足内外网数据同步的要求。

4、解决方法

采用自增ID的形式主键无法满足上面的要求,这里就需要进行主键的改造,我们设置主键为UUID随机32数,这样就能保证主键永远不会冲突,然后把A/C表看成是读写分离表,读C写A

如下ORACLE数据表:

create table uuid(
id varchar2(32) default sys_guid(),
name varchar2(100) NOT NULL
) ;

如果已经创建了表,那么先保证你原有的主键ID没有任何实际的业务意义,要修改的话使用下面的方法。

alter table uuid modify id default sys_guid() ;
update uuid set id = sys_guid ();
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值