was缓存导致web.xml更改无效

  • Post author:
  • Post category:其他



在项目中经常遇见这样的问题:修改应用的配置文件


web


.xml


后,无论重启应用还是重启



WebSphere

服务器


,都不能重新加载



web.xml

,导致修改的内容无效




这个问题困扰了我好久,即使删除了

${was


安装目录


}

\IBM\

WebSphere

\AppServer\profiles\AppSrv01\下的temp和wstemp两个

缓存

文件夹下的临时文件,重启后还是无效。几经折腾,后来终于找到了问题所在——还


是由于


was




缓存

机制导致的。


找到${was


安装目录


}\


AppServer\profiles\AppSrv01\config\cells


\xxxNode01Cell


\applications\${应用名}


.ear


\deployments\目录下,有一个与应用相同名称的

缓存

文件夹,删除或修改该文件夹的


web


.xml


,重启


was


即可。



web.xml

文件在



websphere

中会有两个地方存储


一个

websphere

的问题,首先声明一下我对

websphere

的目录结构并不是很了解,如果了解它的目录结构也就不会犯下这样的错误:

我们做应用项目需要发布到

websphere

上,项目经理让我为应用整体作一个限制,要求是:当系统跑批时间不允许用户登录系统;于是我想了良久发现用过滤器来做最合适不过了。开始准备了,写好过滤器进行配置后发现我的过滤器怎么样不生效,这样我就又调整了一下过滤器的位置,发现过滤器生效和了,可以由于应用本身使用了struts2,这样我的过滤器添加在struts2的过滤器之前就会出现问题:如果我的过滤器生效就不会再经过struts2的过滤器,在返回到页面的时候就会报为经过struts2过滤器的错误。之后一段时间我没有什么办法了,再经过一段时间的思考之后,我决定修改struts2的过滤器,起始也不知道从什么地方下手,于是开始看struts2的源代码,发现可以对其分发器Dispatch进行修改:就是在分发器分发之前判断如果时间是在跑批时间就让它跳转到固定页面(登录页面),经过修改终于成功了。我的调试服务器是tomcat5.5没有什么问题,昨天我们发布到

websphere

上后发现也是能够正常运行的。晚上我欣喜地回到了住处,突然有个同事打电话给我说他修改了

web.xml

中的相关时间的配置信息重启服务器后配置信息并没有生效。

今天早晨我开始寻找问题,发现不管怎么修改它确实不会生效,经过和同事讨论:想法是

websphere

应该有



缓存

目录,找找看还有没有其他地方对

web.xml

有存储。于是使用find命令找

web.xml

文件,突然屏幕上出现两个前缀和我们的应用名称相同的

web.xml

文件,一个是我们预先知道目录(../AppServer/profiles/AppSrv01/installedApps/loopbackNode01Cell/),另一个是(config/cells/loopbackNode01Cell/application/)目录,为了描述方便我把前面的目录名称叫目录一,将后面的目录名称叫目录二。经过反复测试发现只有修改了目录二下面的

web.xml

文件并重启服务器后应用才会生效,目录一中的配置文件并不起作用,至此问题就解决了。



版权声明:本文为llyzq原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。