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

相关推荐
代码搬运媛8 小时前
Jest 测试框架详解与实现指南
前端
counterxing9 小时前
我把 Codex 里的 Skills 做成了一个 MCP,还支持分享
前端·agent·ai编程
wangqiaowq9 小时前
windows下nginx的安装
linux·服务器·前端
之歆9 小时前
DAY_12JavaScript DOM 完全指南(二):实战与性能篇
开发语言·前端·javascript·ecmascript
发现一只大呆瓜9 小时前
Vite凭什么这么快?3分钟带你彻底搞懂 Vite 热更新的幕后黑手
前端·面试·vite
Maimai1080810 小时前
React如何用 @microsoft/fetch-event-source 落地 SSE:比原生 EventSource 更灵活的实时推送方案
前端·javascript·react.js·microsoft·前端框架·reactjs·webassembly
kyriewen11 小时前
产品经理把PRD写成“天书”,我用AI半小时重写了一遍,他当场愣住
前端·ai编程·cursor
humcomm12 小时前
元框架的工作原理详解
前端·前端框架
canonical_entropy12 小时前
Attractor Before Harness: AI 大规模开发的方法论
前端·aigc·ai编程
zhangxingchao12 小时前
多 Agent 架构到底怎么选?从 Claude Agent Teams、Cognition/Devin 到工程落地原则
前端·人工智能·后端