2 回答
TA贡献1836条经验 获得超4个赞
在Tomcat 9.0.x中,通过更新server.xml文件的Connector元素中的协议属性值来消除以下异常。
例外:
27-Mar-2020 08:06:45.726 SEVERE [main] org.apache.catalina.util.LifecycleBase.handleSubClassException Failed to initialize component [Connector[org.apache.coyote.http11.Http11Protocol-auto-null]]
org.apache.catalina.LifecycleException: Protocol handler instantiation failed
27-Mar-2020 08:06:44.929 SEVERE [main] org.apache.catalina.connector.Connector.<init> Protocol handler instantiation failed
java.lang.ClassNotFoundException: org.apache.coyote.http11.Http11Protocol
异常语法:
<Connector port="9443"
protocol="org.apache.coyote.http11.Http11Protocol"
maxThreads="200"
SSLEnabled="true"
scheme="https"
secure="true"
clientAuth="want"
sslProtocol="TLS"
connectionTimeout="20000"
keystoreFile="D:\\MYAPP\\DINESH_LOMTE\\dlomte_keystore.jks"
keystorePass="cardinal"
keystoreType="JKS"
truststoreFile="D:\\MYAPP\\DINESH_LOMTE\\dlomte_truststore.jks"
truststorePass="cardinal"
truststoreType="JKS"
/>
在上面的连接器元素语法中更新协议属性值
从
protocol="org.apache.coyote.http11.Http11Protocol"
到
protocol="org.apache.coyote.http11.Http11NioProtocol"
注意:为了使用显式协议而不是依赖自动切换机制,可以使用以下值之一,根据您的要求选择
org.apache.coyote.http11.Http11NioProtocol - non blocking Java NIO connector
org.apache.coyote.http11.Http11Nio2Protocol - non blocking Java NIO2 connector
org.apache.coyote.http11.Http11AprProtocol - the APR/native connector.
TA贡献1775条经验 获得超11个赞
我遇到过同样的问题。它开始初始化一个非 io-blocking 连接器
05-Nov-2018 16:33:57.080 INFO [main] org.apache.coyote.AbstractProtocol.init Initializing ProtocolHandler ["http-nio-8080"]
但是您的配置建议使用 io 阻塞连接器
Http11Protocol
所以也许你会尝试使用其他连接器。在我的情况下,更改Http11Protocol
为Http11NioProtocol
有助于修复此错误。
添加回答
举报