Weblogic的update和stop/start的区别。
今天联调测试人员发现一个bug,当对weblogic的web应用执行stop,然后start的时候 系统就出现故障了。
但如果对weblogic的web应用 进行update的时候,就没问题。
问题的缘由:
对weblogic的webapp执行 stop/start时候,只会调用javax.servlet.ServletContextListener接口的
contextDestroyed()、contextInitialized()方法。
所以对于单例的类,或者类中的静态成员变量,就可能存在危险。
而update的时候不仅会调用ServletContextListener接口的方法,而且会将类对象摧毁,然后ClassLoader重新加载相关的类。单例的类也同样要摧毁掉重新创建。
另外update或者stop,甚至delete掉webapp的时候 其实程序中start起来的线程都继续在跑的(因为此时线程的生命期跟webapp不关联,而是跟weblogic的主进程关联)。 所以对于webapp,都必须在contextDestroyed() 将该中止的线程手动停止掉。