在应用运行时升级软件,无需重新启动的方式有两种:热部署与热加载。
对Java程序来说,热部署是在服务器运行的时候重新部署项目,热加载是在运行时重新加载class从而升级应用。
热加载主要依赖Java的类加载机制,实现方式可概括为在容器启动时起一条后台进程,定时检测类文件的时间戳变化,若发现时间戳改变,则将类重新载入。
对比反射机制,反射是在程序运行时捕获类信息,通过动态调用来改变程序的行为。热加载是在运行时通过重新加载改变类信息,直接改变程序行为。
热部署原理类似,但它直接重新加载整个应用,这种方式会释放内存,比热加载更彻底,但同时也更费时间。
区别:
热加载:服务器会监听class文件的改变,包括WEB-INF文件夹下的classes、lib和web.xml等,若发生改变,则局部进行加载,不清空session,不释放内存,开发中用的多,但是要考虑内存溢出等情况。
热部署:整个项目重新部署,包括重新打包war文件。清空session,释放内存,项目打包的时候用的多。
热加载代码:在server.xml中配置reloadable=”true”:
<Context docBase="xxx" path="/xxx" reloadable="true"/> |
热部署代码:在server.xml中配置autoDeploy=”true”:
<Context docBase="xxx" path="/xxx" autoDeploy="true"/> |
或者:
<Host name="localhost" appBase="webapps" unpackWARs="true" autoDeploy="true" xmlValidation="false" xmlNamespaceAware="false"> <Context docBase="xxx" path="/xxx"/> </Host> |