使用阿里云的产品有段时间了,产品使用简单,稳定性高,售后服务好,尤其是他们的工单服务最为让人称赞。客户提交了工单后客服人员几乎马上就会给出相应的解决方案,如果他们不能解决就会转到相应的技术工程师哪里,实时更新问题的处理进展,节约了我很多时间,让我可以专心在自己的业务上。当然,我在使用他们的产品的过程中也碰到了一些坑,主要是针对ACE产品,让我长了不少知识。
1. Jar包冲突
在本地打包成功并在ACE容器中测试成功,上传到线上ACE容器时不能成功启动并抛出异常:Cjava.lang.IllegalStateException: Detected both log4j-over-slf4j.jar AND slf4j-log4j12.jar on the class path, preempting StackOverflowError.
这是因为项目同时包含了对log4j-over-slf4j.jar和slf4j-log4j12.jar两个jar包的依赖,而这两个jar包会循环引用导致内存溢出。解决的办法就是将两个jar包其中一个的依赖移除掉。
这里的坑在于本地和线上的ACE环境不一致,本地可以正常启动而线上不能正常启动。
修改meven的pom文件,将这两个jar包k掉,可能就是引入新的东西的时候不小心把这两个东西都搞进来了,然后自己就悲剧了
<dependency>
<groupId>qunar.tc.qschedule</groupId>
<artifactId>qschedule-client</artifactId>
<version>${qschedule.version}</version >
<exclusions>
<exclusion>
<groupId>commons-logging</groupId>
<artifactId>commons-logging</artifactId>
</exclusion>
<exclusion>
<artifactId>log4j-over-slf4j</artifactId>
<groupId>org.slf4j</groupId>
</exclusion>
<exclusion>
<artifactId>slf4j-log4j12</artifactId>
<groupId>org.slf4j</groupId>
</exclusion>
<exclusion>
<artifactId>log4j</artifactId>
<groupId>log4j</groupId>
</exclusion>
</exclusions>
</dependency>
自己坑自己啊