news 2026/1/12 22:40:57

运行中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/1/9 11:04:27

Dify 1.7.0发布后,为什么90%的AI工程师都在关注它的音频处理能力?

第一章:Dify 1.7.0多模态RAG音频处理的革新意义 Dify 1.7.0 版本引入了对多模态检索增强生成(RAG)系统的全面升级,尤其在音频数据的处理能力上实现了突破性进展。该版本首次支持将语音输入直接嵌入到知识检索流程中,使…

作者头像 李华
网站建设 2026/1/11 5:04:36

金融级数据保护,手把手教你用PHP实现RSA加密全流程

第一章:金融级数据安全的挑战与RSA加密价值在金融系统中,数据的机密性、完整性和身份可验证性是安全架构的核心要求。随着网络攻击手段日益复杂,传统安全机制已难以应对中间人攻击、数据篡改和身份伪造等威胁。RSA加密算法作为非对称加密的基…

作者头像 李华
网站建设 2026/1/11 19:32:28

企业核心竞争力的评估方法

企业核心竞争力的评估方法 关键词:企业核心竞争力、评估方法、指标体系、数学模型、实际应用 摘要:本文围绕企业核心竞争力的评估方法展开深入探讨。首先介绍了研究的背景、目的、预期读者和文档结构等内容。接着阐述了企业核心竞争力的核心概念及其内在联系,给出了相关的原…

作者头像 李华
网站建设 2026/1/11 4:39:49

记录va_list重复使用导致的crash

博主介绍:程序喵大人 35 - 资深C/C/Rust/Android/iOS客户端开发10年大厂工作经验嵌入式/人工智能/自动驾驶/音视频/游戏开发入门级选手《C20高级编程》《C23高级编程》等多本书籍著译者更多原创精品文章,首发gzh,见文末👇&#x…

作者头像 李华
网站建设 2026/1/8 15:37:57

二十三种设计模式(十)--外观模式

外观模式 Facade 外观模式是开发过程中经常不经意间就用到的模式. 当我们编写一个功能相对复杂的模块时, 要对外提供一个简单的调用接口, 就用到了外观模式. 外观模式的核心价值就是对外提供简单易用的接口, 屏蔽内部复杂的逻辑, 协调多个子系统之间的交互顺序和依赖关系. 多个…

作者头像 李华
网站建设 2026/1/12 11:18:30

FSNotes深度体验:从笔记混乱到高效管理的完美蜕变

FSNotes深度体验:从笔记混乱到高效管理的完美蜕变 【免费下载链接】fsnotes Notes manager for macOS/iOS 项目地址: https://gitcode.com/gh_mirrors/fs/fsnotes 你是否曾经在十几个笔记应用间反复切换,却始终找不到那款"刚刚好"的工具…

作者头像 李华