SQS Java клиентское исключение - com.amazon aws .SdkClientException: невозможно выполнить запрос HTTP: отказано в разрешении: подключение - PullRequest
0 голосов
/ 02 апреля 2020

У меня есть пользователь * SQS java (AWS Java SDK 1.11.313), опрашивающий очередь каждые 20 секунд, которая работает почти неделю. За это время он не удался два раза, оба раза выдавая следующее исключение:

com.amazonaws.SdkClientException: Unable to execute HTTP request: Permission denied: connect
        at com.amazonaws.http.AmazonHttpClient$RequestExecutor.handleRetryableException(AmazonHttpClient.java:1114)
        at com.amazonaws.http.AmazonHttpClient$RequestExecutor.executeHelper(AmazonHttpClient.java:1064)
        at com.amazonaws.http.AmazonHttpClient$RequestExecutor.doExecute(AmazonHttpClient.java:743)
        at com.amazonaws.http.AmazonHttpClient$RequestExecutor.executeWithTimer(AmazonHttpClient.java:717)
        at com.amazonaws.http.AmazonHttpClient$RequestExecutor.execute(AmazonHttpClient.java:699)
        at com.amazonaws.http.AmazonHttpClient$RequestExecutor.access$500(AmazonHttpClient.java:667)
        at com.amazonaws.http.AmazonHttpClient$RequestExecutionBuilderImpl.execute(AmazonHttpClient.java:649)
        at com.amazonaws.http.AmazonHttpClient.execute(AmazonHttpClient.java:513)
        at com.amazonaws.services.sqs.AmazonSQSClient.doInvoke(AmazonSQSClient.java:2033)
        at com.amazonaws.services.sqs.AmazonSQSClient.invoke(AmazonSQSClient.java:2009)
        at com.amazonaws.services.sqs.AmazonSQSClient.executeReceiveMessage(AmazonSQSClient.java:1485)
        at com.amazonaws.services.sqs.AmazonSQSClient.receiveMessage(AmazonSQSClient.java:1460)
        at net.myCompany.messageHandlers.QMessageHandler.receiveMsg(QMessageHandler.java:112)
        at net.myCompany.MessageHandler.receiveDirectMsg(MessageHandler.java:23)
        at net.myCompany.commandProcessors.QCommandProcessor.run(QCommandProcessor.java:23)
        at java.lang.Thread.run(Thread.java:748)
Caused by: java.net.SocketException: Permission denied: connect
        at java.net.DualStackPlainSocketImpl.connect0(Native Method)
        at java.net.DualStackPlainSocketImpl.socketConnect(DualStackPlainSocketImpl.java:83)
        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.PlainSocketImpl.connect(PlainSocketImpl.java:172)
        at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392)
        at java.net.Socket.connect(Socket.java:589)
        at org.apache.http.conn.ssl.SSLConnectionSocketFactory.connectSocket(SSLConnectionSocketFactory.java:339)
        at com.amazonaws.http.conn.ssl.SdkTLSSocketFactory.connectSocket(SdkTLSSocketFactory.java:132)
        at org.apache.http.impl.conn.DefaultHttpClientConnectionOperator.connect(DefaultHttpClientConnectionOperator.java:142)
        at org.apache.http.impl.conn.PoolingHttpClientConnectionManager.connect(PoolingHttpClientConnectionManager.java:373)
        at sun.reflect.GeneratedMethodAccessor21.invoke(Unknown Source)
        at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
        at java.lang.reflect.Method.invoke(Method.java:498)
        at com.amazonaws.http.conn.ClientConnectionManagerFactory$Handler.invoke(ClientConnectionManagerFactory.java:76)
        at com.amazonaws.http.conn.$Proxy9.connect(Unknown Source)
        at org.apache.http.impl.execchain.MainClientExec.establishRoute(MainClientExec.java:381)
        at org.apache.http.impl.execchain.MainClientExec.execute(MainClientExec.java:237)
        at org.apache.http.impl.execchain.ProtocolExec.execute(ProtocolExec.java:185)
        at org.apache.http.impl.client.InternalHttpClient.doExecute(InternalHttpClient.java:185)
        at org.apache.http.impl.client.CloseableHttpClient.execute(CloseableHttpClient.java:83)
        at org.apache.http.impl.client.CloseableHttpClient.execute(CloseableHttpClient.java:56)
        at com.amazonaws.http.apache.client.impl.SdkHttpClient.execute(SdkHttpClient.java:72)
        at com.amazonaws.http.AmazonHttpClient$RequestExecutor.executeOneRequest(AmazonHttpClient.java:1236)
        at com.amazonaws.http.AmazonHttpClient$RequestExecutor.executeHelper(AmazonHttpClient.java:1056)
        ... 14 more 

В обоих случаях клиент восстанавливался через ~ 15 минут. Приведенный ниже метод отвечает за создание и отправку запроса на получение. Исключение возникло при вызове метода sqs.receiveMessage() над параметром для l oop. Каждый раз, когда отправляется запрос, создается новый экземпляр com.amazonaws.services.sqs.AmazonSQS, который присваивается переменной sqs.

List<JSONObject> receiveMsg() {

        List<JSONObject> cmdMsgList = new ArrayList<>();

        try {
            if(sqs != null) {
                System.out.println("Attempting message receive at: " + Instant.now());
                // Receive messages
                ReceiveMessageRequest receiveMessageRequest = new ReceiveMessageRequest(commandQUrl);
                receiveMessageRequest.setWaitTimeSeconds(20);
                receiveMessageRequest.setMaxNumberOfMessages(10);
                List<Message> messages = sqs.receiveMessage(receiveMessageRequest).getMessages();
                for (Message message : messages) {
                    JSONObject msgBody = checkTargetDevice(message);
                    if (msgBody != null) {
                        cmdMsgList.add(msgBody);
                    }
                }
            } else {
                ServiceManager.getInstance().setServerConnection(false);
                ServiceManager.getInstance().setConnectionStatus("Can't receive message - Message channel does not exist");
            }

        } catch (QueueDoesNotExistException mia) {
            ServiceManager.getInstance().setServerConnection(false);
        }catch (AmazonServiceException ase) {
            if(ServiceManager.getInstance().isDebug()) {
                ase.printStackTrace();
                ase.getErrorMessage();
            }
        } catch (AmazonClientException ace) {
            if(ServiceManager.getInstance().isDebug()) {
                ace.printStackTrace();
            }
        }

        return cmdMsgList;
}

Я подумал, что, возможно, слишком много соединений было создано и не закрылось должным образом, однако после использования netstat это не кажется чрезмерным только с несколькими TCP-соединениями для этой программы. С тех пор я добавил вызов sqs.shutdown() перед оператором return, однако я не ожидаю больших изменений, поскольку в документации AWS указано, что этот вызов метода на интерфейсе AmazonSQS является необязательным метод, и вызывающие абоненты не должны называть его .

Любые идеи или советы по этой проблеме очень приветствуются. Заранее спасибо.

...