Localstack - доступ к SNS через java aws sdk: NoSuchFieldError: ENDPOINT_OVERRIDDEN

Я играю с экземпляром localstack, работающим на докере. Я пытаюсь получить доступ к службе sns, но получаю сообщение об ошибке при выполнении таких методов, как listTopics () или createTopic (). Я еще не нашел никакой помощи в Google, так что может кто-нибудь знает, что здесь не так?

Ошибка:

Caused by: java.lang.NoSuchFieldError: ENDPOINT_OVERRIDDEN
    at com.amazonaws.services.sns.AmazonSNSClient.executeListTopics(AmazonSNSClient.java:1830) ~[aws-java-sdk-sns-1.11.875.jar:na]
    at com.amazonaws.services.sns.AmazonSNSClient.listTopics(AmazonSNSClient.java:1812) ~[aws-java-sdk-sns-1.11.875.jar:na]
    at com.amazonaws.services.sns.AmazonSNSClient.listTopics(AmazonSNSClient.java:1853) ~[aws-java-sdk-sns-1.11.875.jar:na]
    at com.example.dockerspringboot.DockerSpringBootApplication.getSnsClient(DockerSpringBootApplication.java:62) ~[classes/:na]
    at com.example.dockerspringboot.DockerSpringBootApplication$$EnhancerBySpringCGLIB$$a65fee3d.CGLIB$getSnsClient$2(<generated>) ~[classes/:na]
    at com.example.dockerspringboot.DockerSpringBootApplication$$EnhancerBySpringCGLIB$$a65fee3d$$FastClassBySpringCGLIB$$99ad7dfd.invoke(<generated>) ~[classes/:na]
    at org.springframework.cglib.proxy.MethodProxy.invokeSuper(MethodProxy.java:244) ~[spring-core-5.2.9.RELEASE.jar:5.2.9.RELEASE]
    at org.springframework.context.annotation.ConfigurationClassEnhancer$BeanMethodInterceptor.intercept(ConfigurationClassEnhancer.java:331) ~[spring-context-5.2.9.RELEASE.jar:5.2.9.RELEASE]
    at com.example.dockerspringboot.DockerSpringBootApplication$$EnhancerBySpringCGLIB$$a65fee3d.getSnsClient(<generated>) ~[classes/:na]
    at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke0(Native Method) ~[na:na]
    at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) ~[na:na]
    at java.base/jdk.internal.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) ~[na:na]
    at java.base/java.lang.reflect.Method.invoke(Method.java:566) ~[na:na]
    at org.springframework.beans.factory.support.SimpleInstantiationStrategy.instantiate(SimpleInstantiationStrategy.java:154) ~[spring-beans-5.2.9.RELEASE.jar:5.2.9.RELEASE]
    ... 98 common frames omitted

Я пытаюсь получить доступ к службе localstack sns через java aws sdk:

<dependency>
    <groupId>com.amazonaws</groupId>
    <artifactId>aws-java-sdk-sns</artifactId>
    <version>1.11.875</version>
</dependency>

Код в моем приложении, в котором возникает ошибка, выглядит следующим образом:

private String serviceEndpoint = "http://localhost:4566";
private String signingRegion = "eu-west-1";

@Bean
    public AmazonSNS getSnsClient() {
        AmazonSNS sns = AmazonSNSClient.builder().withEndpointConfiguration(new AwsClientBuilder.EndpointConfiguration(serviceEndpoint, signingRegion)).withCredentials(new DefaultAWSCredentialsProviderChain()).build();

        System.out.println(sns.listTopics().toString());

        return sns;
    }

Я запускаю localstack в Docker с этим файлом для создания докеров:

version: '2.1'

services:
  localstack:
    container_name: "localstack"
    image: localstack/localstack-full
    network_mode: bridge
    ports:
      - "4566-4599:4566-4599"
      - "${PORT_WEB_UI-8080}:${PORT_WEB_UI-8080}"
    environment:
      - SERVICES=s3,sns
      - DEBUG=${DEBUG- }
      - DATA_DIR=/tmp/localstack/data
      - PORT_WEB_UI=${PORT_WEB_UI- }
      - LAMBDA_EXECUTOR=${LAMBDA_EXECUTOR- }
      - KINESIS_ERROR_PROBABILITY=${KINESIS_ERROR_PROBABILITY- }
      - DOCKER_HOST=unix:///var/run/docker.sock

    volumes:
      - "local_vol:/tmp/localstack"
      - "/var/run/docker.sock:/var/run/docker.sock"
volumes:
  local_vol:
      driver: local

Создание темы SNS с помощью cmdline работает нормально, значит, служба работает!

/opt/code/localstack # aws --endpoint-url=http://localhost:4566 sns create-topic --name my_topic
{
    "TopicArn": "arn:aws:sns:us-east-1:000000000000:my_topic"
}
/opt/code/localstack # aws --endpoint-url=http://localhost:4566 sns list-topics
{
    "Topics": [
        {
            "TopicArn": "arn:aws:sns:us-east-1:000000000000:my_topic"
        }
    ]
}

Кстати: я тоже использую S3 localstock, он работает - могут ли эти 2 конфликтовать?

Надеюсь, кто-нибудь может мне помочь, исправить это. :)


person CR92    schedule 05.10.2020    source источник


Ответы (4)


Я также столкнулся с этой ошибкой при использовании AmazonRoute53Client.

После проверки в классе HandlerContextKey нет поля ENDPOINT_OVERRIDDEN.

Этот класс можно найти в библиотеке aws-java-sdk-core. ENDPOINT_OVERRIDDEN был добавлен с 1.11.873.

Решение: обновите aws-java-sdk-core до последней версии или не ниже 1.11.873.

Исходный код Github

Библиотека: aws-java-sdk-core для версии 1.11. 873

person Noel    schedule 28.10.2020
comment
То же самое можно сказать и о подчиненных зависимостях aws. Обновил SES до этой версии, и ошибка ENDPOINT_OVERRIDDEN была удалена! ‹ArtifactId› aws-java-sdk-ses ‹/artifactId› ‹version› 1.11.930 ‹/version› - person Llama; 04.01.2021

Недавно я столкнулся с вышеуказанной проблемой, и не из-за LocalStack или какого-либо образа докера для локальной разработки AWS. Эта проблема связана с несовпадением версий com.amazonaws групповых зависимостей с основным модулем AWS. Эта проблема возникает из-за того, что зависимости AWS SDK пути к классам не совпадают с версией основного модуля AWS. Чтобы избежать этого конфликта версий, следует использовать aws-java-sdk-bom, а модуль BOM позаботится о проблемах управления версиями.

Фрагмент кода

Допустим, последняя версия aws-java-sdk-bom - это 1.11.934 ссылка

  • Maven
 <dependencies>
    <dependency>
      <groupId>com.amazonaws</groupId>
      <artifactId>aws-java-sdk-sns</artifactId>
    </dependency>
  <dependencies>

<dependencyManagement>
    <dependencies>
        <dependency>
            <groupId>com.amazonaws</groupId>
            <artifactId>aws-java-sdk-bom</artifactId>
            <version>1.11.934</version>
            <type>pom</type>
            <scope>import</scope>
        </dependency>
    </dependencies>
</dependencyManagement>
  • Gradle
    dependencies {
        implementation 'com.amazonaws:aws-java-sdk-sns'
    }
    
    dependencyManagement {
        imports {
            mavenBom 'com.amazonaws:aws-java-sdk-bom:1.11.934'
        }
    }
person Prasanth Rajendran    schedule 11.01.2021

Я тоже сталкиваюсь с той же проблемой.

Ошибка возникает из-за использования двух разных библиотек AWS, каждая из которых зависит от разных версий ядра AWS SDK.

Нам нужно убедиться, что номера версий совпадают. Они выпускают обновленные версии каждые пару дней: https://github.com/aws/aws-sdk-java/releases

Рекомендуемый способ использования зависимостей AWS с Maven - использование спецификации, которая будет синхронизировать версии зависимостей AWS. Дополнительная информация: https://aws.amazon.com/blogs/developer/managing-dependencies-with-aws-sdk-for-java-bill-of-materials-module-bom/

person Agi    schedule 24.11.2020

Если кто-нибудь столкнется с этим, я не смог бы найти здесь настоящую проблему, но получил ее, работающую с amazon aws sdk для java 2.0.

        <dependency>
            <groupId>software.amazon.awssdk</groupId>
            <artifactId>sns</artifactId>
            <version>2.15.3</version>
        </dependency>
person CR92    schedule 08.10.2020