teg 基于EUREKA优雅发布

葫芦的运维日志

下一篇 搜索 上一篇

浏览量 1305

2022/08/29 16:37


基于EUREKA优雅发布

基于EUREKA不优雅的原因

如图所示:

  1. app1的pod启动后会向eureka注册自己的服务名、ip、端口信息。
  2. app2想要调用app1的接口需要向eureka查询,通过向eureka发送app1的服务名获取app1 pod的ip和端口。
  3. app2 直接通过获取的ip、端口和app1的pod进行通讯。

不优雅的问题在于

  1. 当app1 pod滚动更新时,新pod拉起后会直接杀掉旧版的pod。
  2. 旧pod被杀掉后,30秒后eureka才会将此旧pod信息在eureka中清除。
  3. 但此期间如app2有有请求还会将其发送至旧的pod,此时旧的pod已经不存在了。 此时就发生了服务报错。

将服务变得优雅

1.java服务暴漏端点:

management:
  endpoints:
    web:
      exposure:
        include: service-registry

注意此端点暴漏需要做白名单限制即只可通过localhost调用

2.deployments添加生命周期钩子

    lifecycle:
      preStop:
        exec:
          command:
          - /bin/bash
          - /tmp/pre_stop.sh

3.添加预停止脚本到项目根目录中

#!/bin/bash
curl -X POST "http://localhost:8080/actuator/service-registry?status=DOWN"  -H "Content-Type: application/vnd.spring-boot.actuator.v2+json;charset=UTF-8"
sleep 40

4.在packege步骤中引入此脚本

FROM ****
ENV LANG C.UTF-8

RUN ln -sf /usr/share/zoneinfo/Asia/Shanghai /etc/localtime

COPY pre_stop.sh /tmp/pre_stop.sh
COPY build/libs/*jar /opt/spring-cloud/lib/app1.jar
EXPOSE 8080
ENTRYPOINT ["java","-server","-Xms2560m","-Xmx2560m", "-jar", "/opt/spring-cloud/lib/app1.jar]

最终优雅

完成以上步骤后,发布服务,第一次发布会讲脚本及生命周期钩子带上去。 当第二次发布即会成为优雅发布。

原理

在pod Terminating状态时通过pre_stop.sh脚本,告知eureka此pod注销,同时sleep 40秒等待,而后清除此pod。

葫芦的运维日志

打赏

上一篇 搜索 下一篇
© 冰糖葫芦甜(bthlt.com) 2021 王梓打赏联系方式 陕ICP备17005322号-1