Weblogic的update和stop/start的区别

WebLogic更新与重启区别

 

 

 

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() 将该中止的线程手动停止掉。

Buildfile: /data/upload/domain03/domain03-ncejb.xml copyjar: [echo] file:LkmWorktimeErpV2Ejb.jar stop: [wldeploy] weblogic.Deployer -noexit -name LkmNcEjbs -adminurl t3://132.147.180.94:7091 -user weblogic -password ******** -stop [wldeploy] weblogic.Deployer invoked with options: -noexit -name LkmNcEjbs -adminurl t3://132.147.180.94:7091 -user weblogic -stop [wldeploy] <Oct 13, 2025, 4:58:20 PM China Standard Time> <Info> <J2EE Deployment SPI> <BEA-260121> <Initiating stop operation for application, LkmNcEjbs [archive: null], to configured targets.> [wldeploy] Task 104 initiated: [Deployer:149026]stop application LkmNcEjbs on MS1. [wldeploy] Task 104 completed: [Deployer:149026]stop application LkmNcEjbs on MS1. [wldeploy] Target state: stop completed on Server MS1 [wldeploy] redeploy: [wldeploy] weblogic.Deployer -noexit -name LkmNcEjbs -source /data/upload/LKM_Java_Apps/domain03/ejb_apps/LkmNcEjbs.ear -targets MS1 -adminurl t3://132.147.180.94:7091 -user weblogic -password ******** -redeploy [wldeploy] weblogic.Deployer invoked with options: -noexit -name LkmNcEjbs -source /data/upload/LKM_Java_Apps/domain03/ejb_apps/LkmNcEjbs.ear -targets MS1 -adminurl t3://132.147.180.94:7091 -user weblogic -redeploy [wldeploy] <Oct 13, 2025, 4:58:27 PM China Standard Time> <Info> <J2EE Deployment SPI> <BEA-260121> <Initiating redeploy operation for application, LkmNcEjbs [archive: /data/upload/LKM_Java_Apps/domain03/ejb_apps/LkmNcEjbs.ear], to MS1 .> [wldeploy] weblogic.management.ManagementException: [Deployer:149164]The domain edit lock is owned by another session in exclusive mode. Therefore, this deployment operation cannot proceed. [wldeploy] at weblogic.utils.StackTraceDisabled.unknownMethod() [wldeploy] Exception in thread "main" weblogic.management.ManagementException: [Deployer:149164]The domain edit lock is owned by another session in exclusive mode. Therefore, this deployment operation cannot proceed. [wldeploy] at weblogic.utils.StackTraceDisabled.unknownMethod() BUILD FAILED /data/upload/domain03/domain03-ncejb.xml:28: webLogic.Deployer execution failed
最新发布
10-14
评论 1
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值