docker怎样实现java的服务不中断滚动升级

docker怎样实现java的服务不中断滚动升级

学习地址:www.skillup.host/1/java/roll...

1.滚动升级存在难点

1.1 滚动升级时至少有两个节点支撑服务,意味着要开两个同样的端口,普通手段同时映射到宿主机会冲突

2.2 如果不映射到宿主机,得使用负载中间件,不能同时映射,那么必须使用负载中间件

2.3 java启动时候,不是运行了就立马可以服务请求,得等待端口监听好了才行

2.4 滚动升级,新容器起来后,老容器得移除掉

2.5 新的jar文件不能直接替换,需要拷贝个副本,否则旧的容器读到新的文件会报错

2.找到网上开源的方案haproxy+docker-compose实现

docker-compose文件写法如下

bash 复制代码
services:
  lb:
    image: haproxy
    restart: always
    volumes:
      - /var/run/docker.sock:/var/run/docker.sock
    links:
      - web
    ports:
      - 8080:8080
    environment:
      - HEALTH_CHECK=check inter 1000 rise 2 fall 2 # 1s内两次连接失败定为失败容器,不接受外部服务
      - TIMEOUT=connect 1000
    networks:
      - mynet
  web:
    image: amazoncorretto:11-al2023-jdk 
    restart: always
    hostname: 'jeiat'
    environment:
      - TZ=Asia/Shanghai
      - VIRTUAL_HOST=*:8080
    ports:
      - '127.0.0.0::8080'
    volumes:
      - ./jar/api-0.0.1-SNAPSHOT.jar:/app-new.jar #映射jar文件到容器,更新时只用拷贝文件
      - ./jar/lib:/lib #库地址,减少jar包大小
      - ./entry-point.sh:/entry-point.sh
    entrypoint: /entry-point.sh
    command: ["java","-Dloader.path=./lib","-jar","/app.jar"]

3.入口脚本文件

bash 复制代码
#!/bin/sh
cp /app-new.jar /app.jar
exec "$@"

4.勿忘给定入口文件可执行权限

推荐阅读

配置 docker0 网桥:www.skillup.host/1/docker/do...

容器访问控制:www.skillup.host/1/docker/do...

相关推荐
天蓝色的鱼鱼24 分钟前
关于 CSS 你可能不知道的属性,但关键时刻很有用
前端·css
泯泷1 小时前
第 2 篇:设计第一套字节码:Opcode、Instruction 与 Constant Pool
前端·javascript·安全
妙码生花1 小时前
从 PHP 到 AI + Golang,程序员自救转型手记(十五):优化细节、网络请求封装
前端·后端·ai编程
泯泷1 小时前
第 1 篇:从 1 + 2 开始:亲手写出第一台 JSVM
前端·javascript·安全
团团崽_七分甜1 小时前
Spring Boot 核心知识点总结
前端
lichenyang4532 小时前
从一个按钮开始,理解 ASCF 框架到底在做什么
前端
古夕2 小时前
第三方 SSO 接入实践:redirect_uri 编码、回调一致性与跨项目联调
前端·vue.js
朦胧之2 小时前
页面白屏卡住排查方法
前端·javascript
用户593608741402 小时前
Playwright 黑魔法:用 ClipboardEvent 绕过 React 富文本编辑器
前端
石山岭3 小时前
自己动手写了一个 Android 虚拟定位 App:GPSSimulate 技术实
android·前端