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

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服务启动正常,但是访问不到服务,在监测中心也找不服务的原因之一

FlashBuilder 4.7 非正常关闭导致的不能启动的解决的方法

centos 系统ssh服务启动异常排查

jar报错红线项目能正常启动,jar不报错项目不能启动

服务错误导致系统无法正常启动(Centos 6)