AWS Java SDK Asyn c Клиент в среде ECS EC2 - PullRequest
0 голосов
/ 04 мая 2020

Я пытаюсь перенести службу java из beanstalk в ECS. К сожалению, используемый asyn c клиент, похоже, не работает таким образом. Я также пытался обновить до последней версии (software.amazon.awssdk: bom: 2.13.8) безрезультатно.

Для тестирования я создал entpoint с обычным клиентом и включил ведение журнала отладки для com.amazonaws.request и software.amazon.awssdk.

С обычным клиентом он работает как положено, и я вижу следующий процесс в файле журнала

2020-05-04 06:38:33.380 DEBUG 1 --- [oundedElastic-8] software.amazon.awssdk.request           : Sending Request: DefaultSdkHttpFullRequest(httpMethod=POST, protocol=https, host=dynamodb.eu-central-1.amazonaws.com, encodedPath=/, headers=[amz-sdk-invocation-id, Content-Length, Content-Type, User-Agent, X-Amz-Target], queryParameters=[])
2020-05-04 06:38:33.386 DEBUG 1 --- [oundedElastic-8] s.amazon.awssdk.auth.signer.Aws4Signer   : AWS4 String to sign: AWS4-HMAC-SHA256
20200504T063833Z
20200504/eu-central-1/dynamodb/aws4_request
8f5568b71452990c24ec92f13e06416df55b0725c456484837c7d34c77e312d1
2020-05-04 06:38:33.389 DEBUG 1 --- [oundedElastic-8] s.a.a.h.a.i.conn.SdkTlsSocketFactory     : Connecting socket to dynamodb.eu-central-1.amazonaws.com/52.94.17.148:443 with timeout 2000
2020-05-04 06:38:33.390 DEBUG 1 --- [oundedElastic-8] s.a.a.h.a.i.conn.SdkTlsSocketFactory     : Enabled protocols: [TLSv1.3, TLSv1.2, TLSv1.1, TLSv1]
2020-05-04 06:38:33.392 DEBUG 1 --- [oundedElastic-8] s.a.a.h.a.i.conn.SdkTlsSocketFactory     : Enabled cipher suites:[TLS_AES_128_GCM_SHA256, TLS_AES_256_GCM_SHA384, TLS_RSA_WITH_AES_256_GCM_SHA384, TLS_DHE_RSA_WITH_AES_256_GCM_SHA384, TLS_DHE_DSS_WITH_AES_256_GCM_SHA384, TLS_RSA_WITH_AES_128_GCM_SHA256, TLS_DHE_RSA_WITH_AES_128_GCM_SHA256, TLS_DHE_DSS_WITH_AES_128_GCM_SHA256, TLS_RSA_WITH_AES_256_CBC_SHA256, TLS_DHE_RSA_WITH_AES_256_CBC_SHA256, TLS_DHE_DSS_WITH_AES_256_CBC_SHA256, TLS_RSA_WITH_AES_256_CBC_SHA, TLS_DHE_RSA_WITH_AES_256_CBC_SHA, TLS_DHE_DSS_WITH_AES_256_CBC_SHA, TLS_RSA_WITH_AES_128_CBC_SHA256, TLS_DHE_RSA_WITH_AES_128_CBC_SHA256, TLS_DHE_DSS_WITH_AES_128_CBC_SHA256, TLS_RSA_WITH_AES_128_CBC_SHA, TLS_DHE_RSA_WITH_AES_128_CBC_SHA, TLS_DHE_DSS_WITH_AES_128_CBC_SHA, TLS_EMPTY_RENEGOTIATION_INFO_SCSV]
2020-05-04 06:38:33.392 DEBUG 1 --- [oundedElastic-8] s.a.a.h.a.i.conn.SdkTlsSocketFactory     : socket.getSupportedProtocols(): [TLSv1.3, TLSv1.2, TLSv1.1, TLSv1, SSLv3, SSLv2Hello], socket.getEnabledProtocols(): [TLSv1.3, TLSv1.2, TLSv1.1, TLSv1]
2020-05-04 06:38:33.393 DEBUG 1 --- [oundedElastic-8] s.a.a.h.a.i.conn.SdkTlsSocketFactory     : TLS protocol enabled for SSL handshake: [TLSv1.2, TLSv1.1, TLSv1, TLSv1.3]
2020-05-04 06:38:33.393 DEBUG 1 --- [oundedElastic-8] s.a.a.h.a.i.conn.SdkTlsSocketFactory     : Starting handshake
2020-05-04 06:38:33.448 DEBUG 1 --- [oundedElastic-8] s.a.a.h.a.i.conn.SdkTlsSocketFactory     : Secure session established
2020-05-04 06:38:33.448 DEBUG 1 --- [oundedElastic-8] s.a.a.h.a.i.conn.SdkTlsSocketFactory     :  negotiated protocol: TLSv1.2
2020-05-04 06:38:33.448 DEBUG 1 --- [oundedElastic-8] s.a.a.h.a.i.conn.SdkTlsSocketFactory     :  negotiated cipher suite: TLS_RSA_WITH_AES_128_GCM_SHA256
2020-05-04 06:38:33.449 DEBUG 1 --- [oundedElastic-8] s.a.a.h.a.i.conn.SdkTlsSocketFactory     :  peer principal: CN=dynamodb.eu-central-1.amazonaws.com
2020-05-04 06:38:33.449 DEBUG 1 --- [oundedElastic-8] s.a.a.h.a.i.conn.SdkTlsSocketFactory     :  peer alternative names: [dynamodb.eu-central-1.amazonaws.com, *.ddb.eu-central-1.amazonaws.com]
2020-05-04 06:38:33.449 DEBUG 1 --- [oundedElastic-8] s.a.a.h.a.i.conn.SdkTlsSocketFactory     :  issuer principal: CN=Amazon, OU=Server CA 1B, O=Amazon, C=US
2020-05-04 06:38:33.449 DEBUG 1 --- [oundedElastic-8] s.a.a.h.a.internal.net.SdkSslSocket      : created: dynamodb.eu-central-1.amazonaws.com/52.94.17.148:443
2020-05-04 06:38:33.486 DEBUG 1 --- [oundedElastic-8] software.amazon.awssdk.request           : Received successful response: 200

В клиенте Asyn c запрос немедленно завершается с ошибкой Channel was closed before it could be written to.

2020-05-04 06:46:30.278 DEBUG 1 --- [ledExecutor-4-0] software.amazon.awssdk.request           : Retrying Request: DefaultSdkHttpFullRequest(httpMethod=POST, protocol=https, host=dynamodb.eu-central-1.amazonaws.com, encodedPath=/, headers=[amz-sdk-invocation-id, Content-Length, Content-Type, User-Agent, X-Amz-Target], queryParameters=[])
2020-05-04 06:46:30.280 DEBUG 1 --- [ledExecutor-4-0] s.amazon.awssdk.auth.signer.Aws4Signer   : AWS4 String to sign: AWS4-HMAC-SHA256
20200504T064630Z
20200504/eu-central-1/dynamodb/aws4_request
c0690ccc235e73f0a118bcaf7f2ffd435490e4511b5c3f78b60ee244c0d9f24d
2020-05-04 06:46:30.323 DEBUG 1 --- [tyEventLoop-3-1] s.a.a.h.n.n.i.NettyRequestExecutor       : Channel was closed before it could be written to.
java.io.IOException: Channel was closed before it could be written to.
    at software.amazon.awssdk.http.nio.netty.internal.NettyRequestExecutor.tryConfigurePipeline(NettyRequestExecutor.java:190) ~[netty-nio-client-2.13.8.jar:na]
    at software.amazon.awssdk.http.nio.netty.internal.NettyRequestExecutor.makeRequestListener(NettyRequestExecutor.java:138) ~[netty-nio-client-2.13.8.jar:na]
    at io.netty.util.concurrent.DefaultPromise.notifyListener0(DefaultPromise.java:577) ~[netty-common-4.1.48.Final.jar:4.1.48.Final]
    at io.netty.util.concurrent.DefaultPromise.notifyListenersNow(DefaultPromise.java:551) ~[netty-common-4.1.48.Final.jar:4.1.48.Final]
    at io.netty.util.concurrent.DefaultPromise.access$200(DefaultPromise.java:35) ~[netty-common-4.1.48.Final.jar:4.1.48.Final]
    at io.netty.util.concurrent.DefaultPromise$1.run(DefaultPromise.java:501) ~[netty-common-4.1.48.Final.jar:4.1.48.Final]
    at io.netty.util.concurrent.AbstractEventExecutor.safeExecute(AbstractEventExecutor.java:164) ~[netty-common-4.1.48.Final.jar:4.1.48.Final]
    at io.netty.util.concurrent.SingleThreadEventExecutor.runAllTasks(SingleThreadEventExecutor.java:472) ~[netty-common-4.1.48.Final.jar:4.1.48.Final]
    at io.netty.channel.nio.NioEventLoop.run(NioEventLoop.java:500) ~[netty-transport-4.1.48.Final.jar:4.1.48.Final]
    at io.netty.util.concurrent.SingleThreadEventExecutor$4.run(SingleThreadEventExecutor.java:989) ~[netty-common-4.1.48.Final.jar:4.1.48.Final]
    at io.netty.util.internal.ThreadExecutorMap$2.run(ThreadExecutorMap.java:74) ~[netty-common-4.1.48.Final.jar:4.1.48.Final]
    at java.base/java.lang.Thread.run(Unknown Source) ~[na:na]
2020-05-04 06:46:30.327 DEBUG 1 --- [tyEventLoop-3-1] software.amazon.awssdk.request           : Retryable error detected. Will retry in 33ms. Request attempt number 3
...

Оба клиента создаются без специальной настройки. DynamoDbAsyncClient.create();

Может кто-нибудь сказать мне, как избежать этой ошибки?

...