news 2026/5/20 14:23:37

运行中JAR包替换原理与实践

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
运行中JAR包替换原理与实践
jar包正在运行中,为什么可以被替换?

这是一个很好的问题,涉及操作系统、JVM和文件系统的底层机制。简单来说:运行中的JAR文件可以被替换,是因为操作系统允许已打开的文件被删除或重写,但JVM仍然持有原文件的句柄和内容。

详细原理:

1.操作系统级别

  • 在Linux/Unix系统中,文件被删除时,如果还有进程在使用它,文件内容不会立即从磁盘移除

  • 内核会维护一个"引用计数",只有当所有引用都关闭时,磁盘空间才会被释放

  • 已打开的文件描述符仍然可以读写原文件内容

  • Windows也有类似机制,但实现方式不同

2.JVM角度

java

// JVM通过ClassLoader加载类时,会打开JAR文件 JarFile jarFile = new JarFile("app.jar"); // 即使外部删除app.jar,jarFile对象仍能读取内容

3.具体过程

text

时间线: 1. t0: JVM启动,打开app.jar,获取文件描述符fd=100 2. t1: 类加载器从fd=100读取类字节码 3. t2: 你删除或替换app.jar(新文件可能获得新的inode) 4. t3: JVM仍然通过fd=100读取旧的JAR内容 5. t4: 重启应用时,JVM会关闭fd=100,重新打开新的app.jar

实践中的注意事项:

可以做的操作:

  • 替换JAR文件(旧进程继续运行,新进程用新JAR)

  • 删除JAR文件(已运行的不受影响)

  • 重命名JAR文件

可能遇到的问题:

bash

# 场景1:直接替换可能失败 cp new.jar app.jar # 可能报"Text file busy"错误 # 场景2:优雅替换方法 mv app.jar app.jar.bak && cp new.jar app.jar # 或者使用 nohup 等方式先停止再替换

🔧安全替换建议:

bash

# 1. 先停止应用(推荐) ./stop.sh cp new.jar app.jar ./start.sh # 2. 使用原子替换(某些系统支持) install -m 755 new.jar app.jar # 3. 使用版本化JAR名 # app-1.0.jar -> app-1.1.jar # 通过符号链接指向当前版本 ln -sf app-1.1.jar app-current.jar

特殊注意事项:

  1. 动态加载的类:如果使用自定义ClassLoader动态加载新类,可能会遇到问题

  2. 配置文件:JAR内部的配置文件更改不会生效,需要重启

  3. 资源文件:同样需要重启才能读取新的资源

  4. 热部署框架:如Spring Boot DevTools、JRebel等有特殊处理机制

总结:

技术上是可行的,因为操作系统允许这样做,但生产环境不推荐直接替换,应该:

  1. 正常停止应用

  2. 备份原JAR

  3. 部署新JAR

  4. 重新启动

这样可以避免各种潜在问题,如内存泄漏、类加载冲突、资源未释放等。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/19 7:27:23

MeshLab vs传统软件:3D处理效率提升300%的秘诀

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容: 开发一个MeshLab批处理效率工具包:1) 自动化常见处理流程的脚本集合(去噪、简化、修复等);2) 性能对比测试模块;3) 任务队…

作者头像 李华
网站建设 2026/5/17 8:59:59

Nuxt项目内网服务器域名代理访问故障排查

一、文档概述 本文针对Nuxt项目在本地运行正常、打包无异常,但部署至内网服务器后出现接口访问异常、资源加载失败的问题,梳理故障背景、排查流程及解决方案,为技术人员解决同类内网环境下的代理配置故障提供参考。 二、故障背景与现象项目环…

作者头像 李华
网站建设 2026/5/17 4:40:06

通信系统仿真:光通信系统仿真_(14).高级光通信系统仿真技术

高级光通信系统仿真技术 光纤非线性效应仿真 光纤非线性效应概述 光纤非线性效应是指在高光功率或长距离传输条件下,光纤材料的折射率随光强度的变化而变化,导致光信号在传输过程中发生各种非线性畸变。这些效应包括自相位调制(SPM&#xff0…

作者头像 李华
网站建设 2026/5/18 11:41:17

Java空窗一年,自救日记

这是小红书上一位Java工程师空窗一年后的真实经历。 根据最近的行业调研和招聘数据,AI的发展确实对Java工程师提出了新挑战,但也带来了明确的转型机遇。其现状可概括为:市场分化明显,初级岗位收缩,但“JavaAI”的复合…

作者头像 李华
网站建设 2026/5/15 5:36:05

用AI生成随机乱码的5种高级技巧

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容: 创建一个可以生成随机乱码的Web应用,要求:1.支持自定义字符集(如仅字母、数字、符号或混合)2.可设置生成长度范围 3.能控制特殊符号出…

作者头像 李华
网站建设 2026/5/16 13:30:02

高性能表格组件AG Grid 35 全新发布:支持单元格公式、分组拖拽、绝对排序、列选择等

作为全球知名的企业级数据网格控件,AG Grid 以强大的性能、灵活的 API 设计与成熟的企业组件生态而闻名,广泛应用于金融、制造、能源、电商等高数据密度行业。此次发布的 AG Grid 35 是一次重量级更新,带来了诸多提升用户交互体验与数据处理效…

作者头像 李华