V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
lc1450
V2EX  ›  程序员

如何保证单实列服务高可用

  •  
  •   lc1450 · 2020-12-01 13:46:18 +08:00 · 1561 次点击
    这是一个创建于 1243 天前的主题,其中的信息可能已经有所发展或是发生改变。
    线上有几个旧项目,当时开发没考虑过数据库并发问题

    现在为了保证业务可靠,准备了备机(记为 B1),当服务器(记为 A1)出现故障,需要启动 B1 的服务,
    同时要保证 A1 无法连接数据库(A1 故障可能只是短时间网络波动)

    现在的问题是如何避免 B1 正常服务时,A1 故障自动恢复后对数据库连接操作
    各位大佬有什么好的解决方案? 小弟先谢谢了
    9 条回复    2020-12-01 15:34:38 +08:00
    xxxy
        1
    xxxy  
       2020-12-01 13:59:07 +08:00
    数据库主主同步
    opengps
        2
    opengps  
       2020-12-01 14:08:38 +08:00 via Android
    数据库作为内网服务,网络波动因素很小,反倒是需要重点关注下是不是峰值超过了数据库承载力
    如果真的只是担心主节点挂掉,那么数据库主从热备确实需要
    nikandaoleshenme
        3
    nikandaoleshenme  
       2020-12-01 14:17:33 +08:00
    换个稳定的主机,比如这台 uptime 14:12:31 up 398 days, 3:59,近 400 天,没停机,上面的服务也没有宕机

    服务器没有你想的那么重要,当然也没有你想的那么弱不禁风,说故障就故障了
    Bazingal
        4
    Bazingal  
       2020-12-01 14:29:11 +08:00 via Android   ❤️ 1
    nginx 反代设置 B 为 backup
    DoctorCat
        5
    DoctorCat  
       2020-12-01 14:40:24 +08:00
    一楼正解,双主同步最简单。具体可参考 keepalived 方案
    xuanbg
        6
    xuanbg  
       2020-12-01 15:12:15 +08:00
    假设数据库只有一个,那你要确定服务有没有定时任务什么的会访问数据库,如果没有的话,4 楼的方案最简单实用,基本上就是无缝切换。如果有的话,就只能在服务挂掉后在开机了,你想要无缝切换主备是不可能的。

    任何事情都是有代价的,我认为最好的办法就是改成双实例,搞个分布式锁,需要锁的地方锁上就行了。一般来说需要加锁的地方不是很多。
    yeqizhang
        7
    yeqizhang  
       2020-12-01 15:16:58 +08:00
    只考虑数据主主同步我觉得不太符合楼主的应用场景,不知道楼上有说的 nginx backup 那个是否符合楼主的
    mhycy
        8
    mhycy  
       2020-12-01 15:32:12 +08:00
    数据库代理
    lc1450
        9
    lc1450  
    OP
       2020-12-01 15:34:38 +08:00
    @xxxy 数据库是另一个组管理的,只给了一个连接地址
    @nikandaoleshenme 服务器还是比较稳的,就是内网偶尔抽风
    @Bazingal nginx backup 好像是个好办法,可以试试
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   我们的愿景   ·   实用小工具   ·   1102 人在线   最高记录 6543   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 33ms · UTC 18:08 · PVG 02:08 · LAX 11:08 · JFK 14:08
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.