王金铎王 2018-12-17 07:55 采纳率: 100%
浏览 3249
已采纳

大型Java项目如何实现不停机维护的?求大神解答

一直很好奇,大型Java项目如何实现不停机维护的?比如支付宝的后台?
还有个疑问就是比如说某个方法执行的时间比较长比如说需要耗时10s,如果某个用户在访问某台服务器的时候,当这个方法执行到5s的时候,这个服务器要进行更新,那这个方法没有走完服务就停掉了,如何处理的这种问题?

  • 写回答

2条回答 默认 最新

  • 三阶魔方 2018-12-17 08:40
    关注

    既然提到支付宝后台了,那你看看dubbo的官方文档呗。dubbo这种分布式框架,已经基本上解决了热部署的切换问题了,不过还需要补充一些管理型的规则。

    比如耗时10s的操作,不会为了更新而停止的,dubbo中有专门的接口查看负载情况,某一节点需要更新时,这一节点从负载均衡中移除,那么新来的操作就不会请求他了。

    之后等它结束所有的操作,就停下来,更新,再启动,加入负载均衡节点。

    负载均衡是动态的,可以通过权重来配置,更新计划里会通过权重配置的方式,让每一个节点负载减少到0,之后才进行更新。

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥20 有人能用聚类分析帮我分析一下文本内容嘛
  • ¥15 请问Lammps做复合材料拉伸模拟,应力应变曲线问题
  • ¥30 python代码,帮调试
  • ¥15 #MATLAB仿真#车辆换道路径规划
  • ¥15 java 操作 elasticsearch 8.1 实现 索引的重建
  • ¥15 数据可视化Python
  • ¥15 要给毕业设计添加扫码登录的功能!!有偿
  • ¥15 kafka 分区副本增加会导致消息丢失或者不可用吗?
  • ¥15 微信公众号自制会员卡没有收款渠道啊
  • ¥100 Jenkins自动化部署—悬赏100元