接口服务不能正常启动导致的问题

问题描述

  服务启动时报Caused by:java.lang.ClassNotFoundException:org.slf4j.impl.StaticLoggerBinder异常。

  客户端访问报:Unable to instantiate Action, **Action, defined for '**' in namespace '/' **Action - action - file:/**tomcat/webapps/**/WEB-INF/classes/struts.xml:13:67

问题原因

  服务依赖了公共服务**CommonService,后者引用了slf4j的相关日志类,但是前者没有slf4j的相关Jar包,所以启动时找不到类。

Hessian协议

  因为是服务和web分离,服务启动异常但是web启动成功,所以请求时实例化Action时Service类不能初始化从而导致了Action实例化异常

  客户端通过Hessian协议获取服务的Service时也会异常。

解决方案

  由于各个模块使用的jar包各不相同,子模块依赖了Common但是却不具备Common的jar包就会有问题。

  方案一:common打Jar时连同lib目录及其jar包一同打,但是common的体积会增大,本可以只打Class文件,但是多打了好多jar包,子模块体积也会随之增大,多出好多重复的jar包。

  方案二:子模块的jar包依赖要大于等于common的jar包依赖。

猜你喜欢

转载自www.cnblogs.com/BINGJJFLY/p/9816331.html