接口服务不能正常启动导致的问题
Posted bingjjfly
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了接口服务不能正常启动导致的问题相关的知识,希望对你有一定的参考价值。
问题描述
服务启动时报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包依赖。
以上是关于接口服务不能正常启动导致的问题的主要内容,如果未能解决你的问题,请参考以下文章
记录一次断电导致centos7.4系统不能正常进入的解决方案
dubbo服务启动正常,但是访问不到服务,在监测中心也找不服务的原因之一