java - PHP Java 桥异常 - 协议(protocol)错误

标签 java php apache docker tomcat

我正在运行 PHP-Java 桥接服务器 (apache-tomcat)。有时我会遇到间歇性错误。当我通过 ./shutdown.shstartup.sh< 从 /opt/apache-tomcat-8.5.43/bin 目录重新启动 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)

Dockerfile:

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

enter image description here

最佳答案

错误消息说由于协议(protocol)错误,连接出现异常。发生这种情况的原因有多种:

  • 在发出请求时需要联系的服务器不可用

  • 在 JAVA 尝试调用应用程序时 php-fcgi 仍在启动

  • 您使用错误的协议(protocol)从 php 请求数据

如果是第一个,您可以编辑启动文件,以便 tomcat 等待其他服务启动,具体取决于您为此使用的服务。如果您使用的是 systemd,请查看以下答案:https://unix.stackexchange.com/questions/43202/how-can-i-start-a-systemd-service-only-after-mysql-has-started

您可以查看 php 错误日志、访问日志并查看是否有可能有帮助的错误。 您还应该查看您发布的堆栈跟踪上方和下方的消息。它可能有助于解决问题。

关于java - PHP Java 桥异常 - 协议(protocol)错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57203732/

相关文章:

apache - Phabricator 通知服务器 SSL 错误

linux - CGI 环境,读取最大大小是固定的?

java - 无法在 OSGi Apache Felix Web 控制台中添加加号按钮来创建新的配置实例

Java 正则表达式 ReplaceAll 未按预期工作

java - 在 Apache 的 httpclient 上向 HttpPost 添加参数

java - 无法安装 Android APK

php - Doctrine 2.2 + Zend Framework 分页速度优化

php - PhalconPHP-如何向用户显示500错误

PHP 将所有 $_POST[] 变量访问到一个数组中?

apache - 如何将我在 EC2 中的网站重定向到我的域