记录一个类加载变量引发的问题

类加载变量导致的问题

类加载变量导致的问题

因为项目需要,银行要求使用weblogic部署并且启动所有项目,不允许项目单独开服务启动一般都有这样的要求,我所在的项目组有两个单独main方法启动的服务,经过改造变成了可以部署在weblogic启动的web服务,其中一个网关接口服务,依赖于银行方提供的总线ESB服务,发送接口实现和其他系统交互,这中间存在需要行方提供的esb.jar这个jar包,以及行方提供的esbclient.properties配置文件。

  • 如下是行方提供的jar文件java类读取esbclient.properties事例代码
public class ClientEngine{
	private static String envProperties = "esbclient.properties";
	private static String envProperties = "mssterkey.properties";
	private static String clientPath = "esb.client.path";
	...
	static{
		String path = System.getProperty(clientPath);
		if(log.isDebugEnabled()){
			log.debug(clientPath + "=" + path);
		}
		if((path != null)&&(!path.equals(""))){
			File f = new File(path + File.separator + envProperties);
			...
		}
	}
}
  • esbclient.properties是个文件,里面定义的参数也是类似client.protocol=HTTP
    这种,上面这段代码就带来一个问题,读取配置文件的是先读取path,也就是根据我们指定的clientPath去找到esbclient.properties,然后再去读取properties文件里面的配置项,但是因为这个读取的配置是写在static块里面的,这个就需要我们一启动weblogic就需要把clientPath这个指定的esb.client.path传进去,不然永远无法取到这个值。

找到问题根源,接下来就是如何解决它,其实很简单,只需要将这两个配置文件放置到服务器配置文件路径,在weblogic启动的bin目录下,有个配置文件叫setDomainEnv.sh的脚本,要解决这个启动的时候就传递这个path进去只需要把这个参数当作JVM的参数传入就行,但这个不是classLoader动态加载的所以只能给死路径,所以只需要写**-Desb.client.path=/wls/config**。然后这个路径存放这两个配置文件,启动weblogic,可以在nohup文件开头看到这个参数被当作JVM的参数传入了,问题得到解决。

转载请注明出处!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值