我正在运行PHP桥服务器()。有时我会有一个间歇性的错误。当我通过/opt/apache-tomcat-8.5.43/bin和startup.sh从./shutdown.sh目录重新启动tomcat服务器时,它就可以工作了。
25-Jul-2019 13:53:52.766 SEVERE [http-nio-8080-exec-8] org.apache.catalina.core.StandardWrapperValve.invoke Servlet.service() for servlet [PhpCGIServlet] in context with path [/JavaBridge] threw exception
php.java.fastcgi.ConnectionException
at php.java.fastcgi.FCGIInputStream.read(FCGIInputStream.java:31)
at php.java.fastcgi.FCGIHeaderParser.parseBody(FCGIHeaderParser.java:82)
at php.java.servlet.fastcgi.FastCGIServlet.doExecute(FastCGIServlet.java:442)
at php.java.servlet.fastcgi.FastCGIServlet.execute(FastCGIServlet.java:468)
at php.java.servlet.fastcgi.FastCGIServlet.handle(FastCGIServlet.java:479)
at php.java.servlet.fastcgi.FastCGIServlet.doGet(FastCGIServlet.java:507)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:635)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:742)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:231)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166)
at org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:52)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166)
at php.java.servlet.PhpCGIFilter.doFilter(PhpCGIFilter.java:126)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166)
at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:199)
at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:96)
at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:493)
at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:137)
at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:81)
at org.apache.catalina.valves.AbstractAccessLogValve.invoke(AbstractAccessLogValve.java:660)
at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:87)
at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:343)
at org.apache.coyote.http11.Http11Processor.service(Http11Processor.java:798)
at org.apache.coyote.AbstractProcessorLight.process(AbstractProcessorLight.java:66)
at org.apache.coyote.AbstractProtocol$ConnectionHandler.process(AbstractProtocol.java:808)
at org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.doRun(NioEndpoint.java:1498)
at org.apache.tomcat.util.net.SocketProcessorBase.run(SocketProcessorBase.java:49)
at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1149)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:624)
at org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61)
at java.lang.Thread.run(Thread.java:748)
Caused by: java.io.IOException: Protocol error
at php.java.fastcgi.FCGIInputStream.doRead(FCGIInputStream.java:56)
at php.java.fastcgi.FCGIInputStream.read(FCGIInputStream.java:29)文档:
FROM ubuntu:16.04
MAINTAINER Alexey Nurgaliev <atnurgaliev@gmail.com>
ENV DEBIAN_FRONTEND=noninteractive
ENV JAVA_BRIDGE_URL="https://sourceforge.net/projects/php-java-bridge/files/Binary%20package/php-java-bridge_7.1.3/php-java-bridge_7.1.3_documentation.zip/download"
ENV JAYBIRD_URL="https://github.com/FirebirdSQL/jaybird/releases/download/v2.2.13/Jaybird-2.2.13-JDK_1.8.zip"
ENV JAYBIRD_FILE_NAME="jaybird-full-2.2.13.jar"
ENV POSTGRESQL_URL="https://jdbc.postgresql.org/download/postgresql-9.4.1212.jar"
ENV POSTGRESQL_FILE_NAME="postgresql-9.4.1212.jar"
ENV TOMCAT_VERSION="8.5.43"
ENV TOMCAT_URL="http://apache-mirror.rbc.ru/pub/apache/tomcat/tomcat-8/v8.5.43/bin/apache-tomcat-8.5.43.tar.gz"
ENV TOMCAT_DIR="/opt/apache-tomcat-${TOMCAT_VERSION}"
ENV TOMCAT_LIB_DIR="${TOMCAT_DIR}/webapps/JavaBridge/WEB-INF/lib"
RUN apt-get update -y && \
apt-get upgrade -y && \
apt-get install -y unzip wget php-cgi openjdk-8-jre-headless locales && \
apt-get install -y nano && \
apt-get install -y curl wget && \
locale-gen --lang ru_RU.UTF-8
RUN cd /opt &&\
wget -O "tomcat.tar.gz" "${TOMCAT_URL}" &&\
tar -xf "tomcat.tar.gz" &&\
rm "tomcat.tar.gz" &&\
wget -O "JavaBridge.zip" "${JAVA_BRIDGE_URL}" &&\
unzip "JavaBridge.zip" -d "JavaBridge" &&\
unzip -o "JavaBridge/JavaBridge.war" -d "${TOMCAT_DIR}/webapps/JavaBridge" &&\
rm -R JavaBridge &&\
rm JavaBridge.zip &&\
wget -O "jaybird.zip" "${JAYBIRD_URL}" &&\
unzip "jaybird.zip" -d "jaybird" &&\
cp "jaybird/${JAYBIRD_FILE_NAME}" "${TOMCAT_LIB_DIR}" &&\
rm -R "jaybird" &&\
wget "${POSTGRESQL_URL}" &&\
cp "${POSTGRESQL_FILE_NAME}" "${TOMCAT_LIB_DIR}" &&\
rm "${POSTGRESQL_FILE_NAME}"
EXPOSE 8080
CMD LANG=ru_RU.UTF-8 "${TOMCAT_DIR}/bin/catalina.sh" run

发布于 2019-08-01 10:17:00
错误消息说,由于协议错误,它在连接上有异常。发生这种情况的原因有多种:
如果是第一个,您可以编辑启动文件,因此tomcat将等待其他服务启动,具体取决于您为此使用的服务。如果您使用的是systemd,请看下面的答案:https://unix.stackexchange.com/questions/43202/how-can-i-start-a-systemd-service-only-after-mysql-has-started
您可以查看php错误日志、访问日志,并查看那里是否存在可能有帮助的错误。您还应该查看您发布的堆栈跟踪上面和下面的消息。这可能对正在发生的问题有所帮助。
发布于 2019-07-25 16:35:56
一些与协议相关的依赖模块没有加载,因此导致java.io.IOException,它无法与目标资源建立连接。
https://stackoverflow.com/questions/57203732
复制相似问题