现网-更新jsp后,为什么有些服务器能拿到新页面,而有些服务器获取的是旧页面,为什么有些服务器什么事也不干隔断时间就自动能看新页面啦?
你需要懂的Tomcat-生成jsp的.class文件的原理,以及在生产环境配置需注意的点。
- Jsp被编译的原理
在Tomcat中会有定时任务 拿jsp文件的时间戳和已编译的.class文件的时间戳 进行比较,两者的时间戳只要不同 就会再次编译。
- jsp更新后未立马生效的原因分析
1) 更新Jsp 和 启动tomcat的权限不一致
如:jsp 和 work 同为 root权限,tomcat 启动为 test 权限
则当 jsp更新后,检查到文件有更新,但却没有权限删除老文件-生成新的文件,当页面访问时就会一直 访问到老的jsp页面。
tomcat会有告警:
WARNING [ContainerBackgroundProcessor[StandardEngine[Catalina]]] org.apache.jasper.compiler.Compiler.removeGeneratedFiles Failed to delete generated Java file
**2) tomcat的web.xml 中 设置了 Jsp更新 检查时间**
在web.xml中设置了 checkInterval为600,则表示 1小时 检查一次JSP更新
<init-param>
<param-name>development</param-name>
<param-value>false</param-value>
</init-param>
<init-param>
<param-name>checkInterval</param-name>
<param-value>600</param-value>
</init-param>
3. Tomcat 的默认的jsp编译配置
Tomcat默认配置 为 development 模式,每隔4s 检查下 Jsp更新。
在研发时为了节省研发时间,提交工作效率,都是jsp更新后,页面立马能看到新的效果,给调试带来了极大的便利。
而如果再现网环境也配置成这样-就会显得很不合理
理由一:现网不会频繁更新jsp
理由二:现网频繁检查jsp更新会带来资源消耗。
4. 生产环境该如何是好?
我没有个固定值,我老板说:需要定在1分钟以内,我回:那我们就一分钟吧。
1分钟的时间在等待忍受时间内吧,如太长-现网验证也挺麻烦的,会耽误事。
生产环境可在web.xml中修改 Jsp更新 1分钟检查 的配置
<servlet>
<servlet-name>jsp</servlet-name>
<servlet-class>org.apache.jasper.servlet.JspServlet</servlet-class>
<init-param>
<param-name>fork</param-name>
<param-value>false</param-value>
</init-param>
<init-param>
<param-name>xpoweredBy</param-name>
<param-value>false</param-value>
</init-param>
<load-on-startup>3</load-on-startup>
<init-param>
<param-name>development</param-name>
<param-value>false</param-value>
</init-param>
<init-param>
<param-name>checkInterval</param-name>
<param-value>60</param-value>
</init-param>
</servlet>
附录:
配置出jsp编译日志-当新jsp未生效时 可通过日志来查看
${TOMCAT_HOME}/conf/logging.properties中
增加
java.util.logging.ConsoleHandler.level = FINE
java.util.logging.ConsoleHandler.formatter = org.apache.juli.OneLineFormatter
添加在这里,添加内容如下:
org.apache.jasper.compiler.Compiler.level = FINE
org.apache.jasper.compiler.Compiler.formatter = org.apache.juli.OneLineFormatter