我们所看到的光,是很多年之前其他星球飞过来,我们所感受到的重力,也是经过一个时间段后所感知到的,目前宇宙中除了猜测中的量子干涉外,同一件事情在两地是不可能同时发生的,这是物理限制。
实际活动中,一般意义上的多活,其实是一个数据中心写,其他数据中心同步数据,这种同步可以在消息队列层或者RPC层,或者数据库层,夸张点的存储层,都可以做到异步,或者一定意义上的同步。
把单写多读的结构,根据一定分区规则比如省市放在指定分区机房,加上省市机房之间的同步,就是目前一般意义上,可以做到的所谓多活。
部分答题说分布式算法,但实际上应用过程中,分布式算法对延迟的要求,直接决定了目前现有的分布式的各种结构,基本上都只能在同一机房或者比较近的同城机房,要跨个省,碰到挖掘机挖线的概率,还是蛮高的。
参考文章中提到的,并没有脱离上述的东西,但其中很多东西,是目前只有阿里搞出来的,或者说只有阿里是公开讲的(这点意义上,阿里功德无量)。
关于提到的延迟问题,首先文中已经交代的是单点写,可以肯定会有一个延迟(现在已经是2017年了,通过种种手段,做到1s内延迟的通用方案很多了已经),对一致性要求比较低(绝大多数需求)完全可以读从机房,而有非常高一致性需求的,可以读主机房,另外,主机房里面也可以搞分布式的读写强一致分离,保证主机房的压力承载能力。