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...

相关推荐
pany5 分钟前
体验一款编程友好的显示器
前端·后端·程序员
Zuckjet10 分钟前
从零到百万:Notion如何用CRDT征服离线协作的终极挑战?
前端
ikonan15 分钟前
译:Chrome DevTools 实用技巧和窍门清单
前端·javascript
Juchecar15 分钟前
Vue3 v-if、v-show、v-for 详解及示例
前端·vue.js
ccc101819 分钟前
通过学长的分享,我学到了
前端
编辑胜编程19 分钟前
记录MCP开发表单
前端
可爱生存报告19 分钟前
vue3 vite quill-image-resize-module打包报错 Cannot set properties of undefined
前端·vite
__lll_19 分钟前
前端性能优化:Vue + Vite 全链路性能提升与打包体积压缩指南
前端·性能优化
weJee20 分钟前
pnpm原理
前端·前端工程化
小高00721 分钟前
⚡️ Vue 3.5 正式发布:10× 响应式性能、SSR 水合黑科技、告别 .value!
前端·javascript·vue.js