news 2026/5/11 8:39:48

运行中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/11 8:38:25

pako测试实战:从压缩算法到质量保证的完整指南

在数据压缩的世界里,pako库就像是一个精密的工具套装,为JavaScript开发者提供了强大的zlib压缩能力。然而,如何确保这套工具在各种场景下都能精准工作,就需要一套完善的测试体系来保驾护航。 【免费下载链接】pako high speed zli…

作者头像 李华
网站建设 2026/5/11 5:46:39

电机试验平台的基本概念

电机试验平台是一种用于测试电机性能、效率和可靠性的专用设备。通过模拟实际运行条件,对电机进行各种参数的测量和分析。这类平台广泛应用于工业制造、科研开发和产品质量控制领域。电机试验平台的主要功能电机试验平台通常具备多种测试功能,包括但不限…

作者头像 李华
网站建设 2026/5/11 8:39:48

DAY10@浙大疏锦行

笔记:东西太多了 还是得再多看看文档作业:

作者头像 李华
网站建设 2026/5/11 8:39:44

数据结构初开课:栈的实现

本次编译环境为VS2022 文章目录前言栈的实现1.什么是栈2.栈的实现一.头文件和源文件的创建以及头文件中的内容二.功能代码的实现1.定义和销毁2.增加和删除3.判断空 找栈顶 获取栈中的个数总结前言 在我们了解完链表:单链表和双链表后 我们将开始 栈和队列的学习 今…

作者头像 李华
网站建设 2026/5/9 11:46:01

进阶数据结构Splay应用-维护数列

目录*引言*题目-维护数列问题分析算法步骤实现细节代码实现引言 该问题几乎包含了所有的splaysplaysplay操作, 如果不了解splaysplaysplay可以单击这里 题目-维护数列 问题分析 因为涉及到区间翻转操作, 线段树无法实现(线段树解决的是区间属性问题) 其实最复杂的操作是求区…

作者头像 李华
网站建设 2026/5/9 11:01:07

如何快速部署Hocuspocus:实时协作的终极指南

如何快速部署Hocuspocus:实时协作的终极指南 【免费下载链接】hocuspocus The Y.js WebSocket backend 项目地址: https://gitcode.com/gh_mirrors/ho/hocuspocus Hocuspocus是一个基于Y.js的实时协作后端服务,专为构建多用户实时同步应用而设计。…

作者头像 李华