问题描述
服务启动时报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包依赖。