Исключение GCP Tomcat java.net.ConnectException: отказано в подключении (отказано в подключении)

#java #python #flask #tomcat #google-cloud-platform

#java #python #flask #tomcat #google-облачная платформа

Вопрос:

Ситуация: Эта проблема возникает при вызове REST API из ReactJS / nginx. Затем Java / Tomcat выполняет другой вызов REST API для сервера Python / Flask. Ответ от Flask отправляется Tomcat в ReactJS.

 Call flow:
Receive REST API call from ReactJS to Java/Tomcat (){
  response = send REST API from Java/Tomcat to python/Flask();
  return response;
}
  

Следующая ошибка возникает, когда Rest API (http://localhost:5000/adb/killserver/1234 ) отправляется из клиентского кода Java на основе виртуальной машины GCP на сервер на базе python flask.

 java.net.ConnectException: Connection refused (Connection refused)
    at java.net.PlainSocketImpl.socketConnect(Native Method)
    at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350)
    at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206)
    at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188)
    at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392)
    at java.net.Socket.connect(Socket.java:607)
    at java.net.Socket.connect(Socket.java:556)
    at sun.net.NetworkClient.doConnect(NetworkClient.java:180)
    at sun.net.www.http.HttpClient.openServer(HttpClient.java:463)
    at sun.net.www.http.HttpClient.openServer(HttpClient.java:558)
    at sun.net.www.http.HttpClient.<init>(HttpClient.java:242)
    at sun.net.www.http.HttpClient.New(HttpClient.java:339)
    at sun.net.www.http.HttpClient.New(HttpClient.java:357)
    at sun.net.www.protocol.http.HttpURLConnection.getNewHttpClient(HttpURLConnection.java:1226)
    at sun.net.www.protocol.http.HttpURLConnection.plainConnect0(HttpURLConnection.java:1162)
    at sun.net.www.protocol.http.HttpURLConnection.plainConnect(HttpURLConnection.java:1056)
    at sun.net.www.protocol.http.HttpURLConnection.connect(HttpURLConnection.java:990)
    at sun.net.www.protocol.http.HttpURLConnection.getInputStream0(HttpURLConnection.java:1570)
    at sun.net.www.protocol.http.HttpURLConnection.getInputStream(HttpURLConnection.java:1498)
    at java.net.HttpURLConnection.getResponseCode(HttpURLConnection.java:480)
    at com.example.APKGeneration.restapi.MyGETRequest(restapi.java:35)
    at com.example.APKGeneration.APKGeneration.sendGetMessage(APKGeneration.java:423)
    at com.example.APKGeneration.APKGeneration.killADBRest(APKGeneration.java:433)
    at com.example.APKGeneration.APKGeneration.executeTestcases(APKGeneration.java:113)
    at com.example.Common.design.onClickBtnTestExecutionState(design.java:523)
    at com.digitran.vte.MyResource.ExecuteTestsAndSaveInMongoDB(MyResource.java:1062)
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
    at java.lang.reflect.Method.invoke(Method.java:498)
    at org.glassfish.jersey.server.model.internal.ResourceMethodInvocationHandlerFactory$1.invoke(ResourceMethodInvocationHandlerFactory.java:81)
    at org.glassfish.jersey.server.model.internal.AbstractJavaResourceMethodDispatcher$1.run(AbstractJavaResourceMethodDispatcher.java:151)
    at org.glassfish.jersey.server.model.internal.AbstractJavaResourceMethodDispatcher.invoke(AbstractJavaResourceMethodDispatcher.java:171)
    at org.glassfish.jersey.server.model.internal.JavaResourceMethodDispatcherProvider$ResponseOutInvoker.doDispatch(JavaResourceMethodDispatcherProvider.java:152)
    at org.glassfish.jersey.server.model.internal.AbstractJavaResourceMethodDispatcher.dispatch(AbstractJavaResourceMethodDispatcher.java:104)
    at org.glassfish.jersey.server.model.ResourceMethodInvoker.invoke(ResourceMethodInvoker.java:387)
    at org.glassfish.jersey.server.model.ResourceMethodInvoker.apply(ResourceMethodInvoker.java:331)
    at org.glassfish.jersey.server.model.ResourceMethodInvoker.apply(ResourceMethodInvoker.java:103)
    at org.glassfish.jersey.server.ServerRuntime$1.run(ServerRuntime.java:271)
    at org.glassfish.jersey.internal.Errors$1.call(Errors.java:271)
    at org.glassfish.jersey.internal.Errors$1.call(Errors.java:267)
    at org.glassfish.jersey.internal.Errors.process(Errors.java:315)
    at org.glassfish.jersey.internal.Errors.process(Errors.java:297)
    at org.glassfish.jersey.internal.Errors.process(Errors.java:267)
    at org.glassfish.jersey.process.internal.RequestScope.runInScope(RequestScope.java:297)
    at org.glassfish.jersey.server.ServerRuntime.process(ServerRuntime.java:254)
    at org.glassfish.jersey.server.ApplicationHandler.handle(ApplicationHandler.java:1030)
    at org.glassfish.jersey.servlet.WebComponent.service(WebComponent.java:373)
    at org.glassfish.jersey.servlet.ServletContainer.service(ServletContainer.java:381)
    at org.glassfish.jersey.servlet.ServletContainer.service(ServletContainer.java:344)
    at org.glassfish.jersey.servlet.ServletContainer.service(ServletContainer.java:221)
    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:53)
    at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193)
    at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166)
    at com.digitran.filters.CorsFilter.doFilter(CorsFilter.java:27)
    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:202)
    at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:97)
    at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:541)
    at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:143)
    at psiprobe.Tomcat90AgentValve.invoke(Tomcat90AgentValve.java:35)
    at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:92)
    at org.apache.catalina.valves.AbstractAccessLogValve.invoke(AbstractAccessLogValve.java:690)
    at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:78)
    at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:343)
    at org.apache.coyote.http11.Http11Processor.service(Http11Processor.java:374)
    at org.apache.coyote.AbstractProcessorLight.process(AbstractProcessorLight.java:65)
    at org.apache.coyote.AbstractProtocol$ConnectionHandler.process(AbstractProtocol.java:868)
    at org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.doRun(NioEndpoint.java:1590)
    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)
  

Код клиента Java приведен ниже:

 public static StringBuffer MyGETRequest(String getUrlString) throws IOException {
        URL urlForGetRequest = new URL(getUrlString);
        StringBuffer response = new StringBuffer();
        String readLine = null;
        HttpURLConnection conection = (HttpURLConnection) urlForGetRequest.openConnection();
        conection.setRequestMethod("GET");
        int responseCode = conection.getResponseCode();
        if (responseCode == HttpURLConnection.HTTP_OK) {
            BufferedReader in = new BufferedReader(
                new InputStreamReader(conection.getInputStream()));         
            while ((readLine = in .readLine()) != null) {
                response.append(readLine);
            } in .close();
            // print result
            System.out.println("JSON String Result "   response.toString());
            //GetAndPost.POSTRequest(response.toString());
        } else {
            System.out.println("GET NOT WORKED");
        }
        return response;
    }
  

Код python flask приведен ниже:

 @app.route('/adb/killserver/<uuid>', methods=['GET', 'POST'])
def adbkillserver(uuid):
    print("You are getting adb kill-server request")
    command = "adb kill-server"
    result = run_command(command)
    print("result = ",result)
    return "adb kill server called"
  

Оба кода Java и Python работают нормально при развертывании в среде WSL, Tomcat и War.

Но не работает при развертывании в среде GCP, Tomcat и War.

В GCP брандмауэр открыт для портов 8080 (Java) и 5000 (python).

Вопросы:

  1. Связана ли эта ошибка с настройками брандмауэра GCP?
  2. Связана ли эта ошибка с CORS?
  3. Почему он работает в среде WSL? но не в GCP?
  4. Пожалуйста, предоставьте решение для этой проблемы.

Комментарии:

1. Я не знаком с GCP, но вы уверены, что оба процесса Java и Python выполняются на одном хосте? Запрашивается, потому что вы вызываете конечную точку Python на локальном хосте.

2. ReactJS / nginx запущен на 1-й виртуальной машине GCP. Java / Tomcat запущен на 2-й виртуальной машине GCP. Python / Flask запущен на локальном хосте.

3. Домен ‘localhost’ не разрешается на глобально уникальный хост, кроме, скажем, ‘google.com «. Вместо этого, если вы хотите подключить сетевой клиент к какому-либо сетевому ресурсу, который развернут на том же хосте, что и клиент, вы настраиваете клиент на использование localhost . Итак, я предполагаю, что в вашем первом сценарии все три службы запущены на одном компьютере (на вашем компьютере разработчика?) Затем, в вашем нерабочем сценарии, у вас есть три службы, распределенные на разных машинах. Таким образом, если вы настроите Tomcat для подключения к localhost: 5000, он будет искать эту самую службу на виртуальной машине GCP 2nd.

4. Спасибо. это имеет смысл. Я попытался использовать ip-адрес моего компьютера. Но не повезло. Строка getUrlString = » 192.168.0.103:5000/adb/killserver/1234 «;

5. Ваш КОМПЬЮТЕР подключен не к Интернету напрямую, а к сетевому маршрутизатору, который, в свою очередь, является шлюзом в Интернет. Используйте сервис, подобный whatismyip.com чтобы узнать текущий IP-адрес вашего маршрутизатора (ваш провайдер обычно не назначает фиксированный IP-адрес, поэтому будьте готовы к тому, что он будет меняться ежедневно). Некоторые маршрутизаторы предлагают переадресацию портов, поэтому вы в принципе можете предоставить свою службу Flask / Python в Интернет. Однако обратите внимание, что это может иметь серьезные последствия для безопасности. Почему бы вам не рассмотреть возможность развертывания службы Flask / Python на третьей виртуальной машине GCP?