• 蓝魔丶
    2019-11-27
    读了两遍,老师有4个问题
    1.同城双活方案中,应用服务在跨机房写和同机房读的策略下,应用程序是如何实现这种策略的(读写分离),有相关的实现方案吗?并且是如何应对在并发情况下主从延长导致的读同机房数据库无数据问题。
    2.同城双活方案中,缓存部署架构是在各种机房中创建缓存库,不进行缓存数据的同步吗?还是会与数据库类似建立主从机制保证同步缓存数据。注册中心部署架构是只需要部署到任意一个机房就可以是吗?不需要考虑在双机房都独立部署的情况嘛?
    3.异地多活方案中,是如何做到对用户进行分片,保证尽量调用本机房的服务的?
    4.异地多活方案中,最后提到的那个场景,我的理解是本次服务调用需要的数据很可能是存储在异地机房中,这样无法避免的进行远程的服务调用或数据访问,为了保证可用性,只有牺牲性能上延长,但是还是应该尽量避免这种跨异地的远程访问,保证两个异地两个机房中都有对方的所有东西,包括数据和服务等。
    展开

    作者回复: 1. 如果已经做了主从分离,那么只需要在异地机房配置主库是主机房的主库,从库配置本机房从库即可。主从延迟的问题,可以通过主动写缓存来解决
    2. 像memcached这样的缓存是没有办法同步的,注册中心可以部署在单机房
    3. 一般按照用户的属性来分片,比如ID,地域
    4. 是的

    
     5
  • Hinimix
    2019-12-18
    老师,比如用zk做注册中心,一个服务我在两个机房各部署了一套,我在web服务连接的时候怎么确定是本机房呢,是需要注册时候注册个机房名,然后web选择有这个机房名的吗

    作者回复: 是的,注册的名字里面带上机房标识,比如zw-feed-service(兆维-feed-服务)

     1
     4
  • 电光火石
    2019-12-08
    老师请问一下,异地多活的方案中,A机房的主库同步到B机房的从库,B机房的主库同步到A机房的从库。我理解:那A机房的服务看到的是自己机房的主库和对方机房的从库,通过数据库分片,不同的数据路由到不同数据库,是这样的吗?分片在A机房主库中的数据和分片在B机房主库找那个的数据不做同步?

    作者回复: 是的,通过分片尽量让用户访问本机房的数据

     1
     1
  • 被过去推开
    2019-12-05
    阿里云有跨区域mysql主从复制,比同机房的主从复制贵了不少
    
     1
  • 海罗沃德
    2019-11-27
    我們使用AWS,跨region部署,會導致緩存不同步,而AWS不支持跨region複製redis數據,而我們又沒有做用戶分片,導致PM,測試都在玩命用同一個用戶側跨region的case

    作者回复: 异地多活的方案中,数据的延迟就是坑

    
     1
  • 刘冲
    2019-11-27
    同城双机房,数据库同步和异城数据库同步方案有啥区别?图上没看太懂,

    作者回复: 数据库同步的方案是一样的,只是同城机房之间的数据延迟小,对于业务的影响小。异地的话数据同步延迟比较高,可能对业务有影响

     1
     1
  • 星空123
    2019-11-27
    这就是为啥公司买服务器都会买同个大区,同个可用区的原因了。减少两个服务器交互的网络延迟
    
     1
  • 小山猫
    2020-01-29
    老师好,异地用户分片用什么方案比较好,比如电商中涉及到用户、商品、商家,用户只看本机房对应的商品吗

    作者回复: 这个根据业务特点定,比如淘宝就是按照uid来分片,饿了么是按照地域来分片

    
    
  • 洋洋洋
    2019-12-14
    老师,我感觉你在异地多活方案写的不是很详细,比如异地双机房的主库是否同步,每个机房是保存有全量的数据,以及异地多活的架构题也不是很清晰
    
    
  • 👽
    2019-12-12
    我的理解:还是得分析了流量价值。如果,机房宕机会给公司带来较大损失的时候。就需要考虑多活。但是,如果宕机对系统没什么太大的影响(例如停一天也没什么影响的项目),就并不需要考虑多活。

    作者回复: 额 一般也不会有宕机一天对公司没有影响的项目吧

    主要是架构复杂度带来的成本和可用性之间的权衡

     1
    
  • 阿土
    2019-12-04
    老师,异地多活架构中,数据双向同步如何做?

    作者回复: 一般是通过队列来实现

    
    
  • longslee
    2019-12-03
    打卡。emmm,全是大佬经验,跪了
    
    
  • 阿卡牛
    2019-11-29
    梦想还是要有的,万一有机会给我实践异地多活呢?
    
    
  • MoonGod
    2019-11-29
    老师请问一下,异地多活的方案中,两地数据库数据是相互隔离的吗?主从同步的方案只是把本机房的从库放倒对端机房。但对端机房主库写入的数据不会同步到这个从库中吧?

    作者回复: 是要同步的,因为你很难做到用户完全分片,所有的请求都落入到本机房中

    
    
  • 扬一场远远的风
    2019-11-27
    “这里有一个场景:假如在电商系统中,用户 A 要查看所有订单的信息,而这些订单中,店铺的信息和卖家的信息很可能是存储在异地机房中,那么你应该优先保证服务调用,和数据读取在本机房中进行,即使读取的是跨机房从库的数据,会有一些延迟,也是可以接受的。”这句没明白。我理解前文讲的“对于某个固定的乃,服务的调用和数据的读写都应该保证在同一个机房中”。而例子中:本人的基本信息和订单信息主库在机房A中,所以数据读取和服务调用应该保证在机房A ,而店铺信息主库和卖家信息主库在机房B中(机房A异步方式从机房B同步过来),此时,对于店铺信息和卖家信息的读取应该也是在机房A中吧?!

    作者回复: 你说的没错,数据是可以同步的,但是异地机房之间延迟比较高,同步也会有延迟的。

    
    
  • 小喵喵
    2019-11-27
    在小公司,连机房都没有,都是部署在云服务器上。这怎么学习这些架构呢?

    作者回复: 云服务是有可用区概念的,你可以理解为同城多机房:)

    
    
  • 星空123
    2019-11-27
    异步多活架构,这套架构太花钱了
    
    
我们在线,来聊聊吧