SP-API Notification SQS 使用介绍

介绍

Notification是亚马逊卖家服务提供的API,Notification为事件驱动,依托于AWS SQS服务(Simple Queue Service) 基于MQ实现通知,可减少接口轮询次数,并且拥有比轮询更高的实时性

本文主要介绍在SP-API 中,如何使用SQS 接入Notification,正确消费消息参考文档

STEP 1 创建SQS

SQS控制台地址

1.1 创建队列

创建队列

1.2 设置基本属性

根据需求配置队列属性


配置详情-基本信息

1.3 设置默认访问策略

访问策略选择默认,创建结束后再修改


配置详情-访问策略

STEP 2 配置SQS (允许amazon 发送消息)

2.1 编辑队列

在队列创建完成后, 记录arn,并点击编辑

编辑.png

2.2 修改策略

记录当前队列的root Principal,点击策略生成器(此时,我们已经拿到了自身的ARN, 和自身的 Principal)

修改策略

2.3 自身拥有队列的所有权限

修改自身权限

2.4 Amazon拥有 GetQueueAttributes 和 SendMessage 权限

Amazon的为Principal (固定的): arn:aws:iam::437568002678:root

设置亚马逊的权限

2.5 生成配置

生成配置

2.6 复制配置JSON

复制配置JSON

2.7 替换配置JSON

替换配置JSON

2.8 点击保存

至此,我们拥有了一个队列,并且,该队列允许亚马逊发送消息,开发者账号拥有该队列所有权限

STEP 3 监听队列

推荐依赖Spring boot,使用JMS 监听队列

3.1 pom依赖

       <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-jms</artifactId>
        </dependency>

        <dependency>
            <groupId>com.amazonaws</groupId>
            <artifactId>amazon-sqs-java-messaging-lib</artifactId>
            <version>1.0.0</version>
            <type>jar</type>
        </dependency>

        <dependency>
            <groupId>com.amazonaws</groupId>
            <artifactId>aws-java-sdk-sqs</artifactId>
            <version>1.11.943</version>
        </dependency>

3.2 监听代码

@Component
@Slf4j
public class SqsConsumer {
    @JmsListener(destination = "SQS名称"
            , containerFactory = "listenerContainerFactory")
    public void consumer(SQSTextMessage sqsTestMessage) throws Exception {
            String text = sqsTestMessage.getText();
            log.info("接收到SQS通知:{}", text);
  }
}

3.3 listenerContainerFactory

    @Bean
    public SQSConnectionFactory connectionFactory() {
        SQSConnectionFactory sqsConnectionFactory = SQSConnectionFactory.builder()
              //amazonPropertiesConfig 为 AWSCredentialsProvider的实现类实例, 提供 AWSCredentials 即可
                .withAWSCredentialsProvider(amazonPropertiesConfig)
              // sqs所在地区 在endpoint中可以找到,如: us-west-1
                .withRegionName(amazonPropertiesConfig.getSqsRegion())
             //SQS地址 配置页中的地址 https://sqs.us-west-1.amazonaws.com/手动马赛克/TEST
                .withEndpoint(amazonPropertiesConfig.getSqsEndpoint())
                .build();
        return sqsConnectionFactory;

    }


    @Bean
    public DefaultJmsListenerContainerFactory listenerContainerFactory(SQSConnectionFactory connectionFactory) {
        DefaultJmsListenerContainerFactory factory =
                new DefaultJmsListenerContainerFactory();
        factory.setConnectionFactory(connectionFactory);
        factory.setDestinationResolver(new DynamicDestinationResolver());
        factory.setConcurrency("10-20"); //开启多少线程
        factory.setSessionAcknowledgeMode(Session.CLIENT_ACKNOWLEDGE); //开启自动确认
        return factory;
    }

STEP 4 订阅消息

4.1 创建 createDestination

注意:

  • 在请求参数中: resourceSpecification下的 sqs 和 eventBridge 只能二选一,并且必须选一个,在SQS中,我们填写SQS就行
  • 访问createDestination时,由于Destination是开发者的内容,与卖家没有关系,因此,在ApiClient对象的创建上,需要使用scope模式,scope = "sellingpartnerapi::notifications"
  LWAClientScopes lwaClientScopes = new LWAClientScopes(new HashSet<>());
        lwaClientScopes.getScopes().add("sellingpartnerapi::notifications");
        LWAAuthorizationCredentials lwaAuthorizationCredentials = LWAAuthorizationCredentials.builder()
                .clientId(clientId())
                .clientSecret(clientSecret())
                .scopes(lwaClientScopes)
                .endpoint(authUrl())
                .build();

createDestination 示例代码:

  public CreateDestinationResponse createDestination(String marketplaceId, CreateDestinationDTO createDestinationDTO) throws ApiException {
        NotificationsApi notificationsApi = getNotificationsApi(marketplaceId);
        DestinationResourceSpecification destinationResourceSpecification = new DestinationResourceSpecification();
        SqsResource sqsResource = new SqsResource();
        sqsResource.setArn(createDestinationDTO.getArn());
        destinationResourceSpecification.setSqs(sqsResource);

        CreateDestinationRequest body = new CreateDestinationRequest();
        body.setResourceSpecification(destinationResourceSpecification);
        body.setName(createDestinationDTO.getDestinationName());
        return notificationsApi.createDestination(body);
    }

@Data
public class CreateDestinationDTO {

    private String arn;  //sqs详情页中可以找到改值
    private String destinationName; //
    private String sqsName; //sqs详情页中可以找到改值
}

请求参数示例:

body
{
  "resourceSpecification": {
    "sqs": {
      "arn": "arn:aws:sqs:us-west-1:手动马赛克:TEST"
    }
  },
  "name": "testDestination"
}

返回值示例:

{
  "payload": {
    "name": "testDestination",
    "destinationId": "2d6eee67-23e9-40fe-destinationId",
    "resource": {
      "sqs": {
        "arn": "arn:aws:sqs:us-west-1:手动马赛克:TEST"
      }
    }
  }
}

需要记录下返回结果中的: destinationId

4.2 根据Destination创建订阅

注意

  • 一个卖家的一种消息类型,只能订阅一个 Destination
  • 此时,操作与卖家有关,需要使用卖家的授权进行访问
       LWAAuthorizationCredentials lwaAuthorizationCredentials = LWAAuthorizationCredentials.builder()
                .clientId(clientId)
                .clientSecret(clientSecret)
                .refreshToken(spAuthToken)
                .endpoint(authUrl)
                .build();

createSubscription 示例代码:

    public CreateSubscriptionResponse createSubscription(String destinationId, NotificationTypeEnum notificationType,String spAuthToken) throws ApiException {
        NotificationsApi notificationsApi = getNotificationsApi(spAuthToken);
        CreateSubscriptionRequest request = new CreateSubscriptionRequest();
        request.setDestinationId(destinationId);
        request.setPayloadVersion("1.0");
        return notificationsApi.createSubscription(request, notificationType.name());
    }

请求参数示例:

 url:
 /notifications/v1/subscriptions/REPORT_PROCESSING_FINISHED
 body:
 {
  "payloadVersion": "1.0",
  "destinationId": "2d6eee67-23e9-40fe-destinationId"
}

返回值示例:

{
  "payload": {
    "subscriptionId":"7ca3572b-2130-41eb-subscriptionId",
    "payloadVersion":"1.0",
    "destinationId": "2d6eee67-23e9-40fe-destinationId",
  }
}

至此, 已经完成了所有准备工作,耐心等待Amazon 触发相关类型的消息就可以啦!!!

5 备注

5.1 NotificationType

参考:NotificationType

5.2 通知数据接口

参考: notification-structure

REPORT_PROCESSING_FINISHED notification 示例:

{
  "notificationVersion": "2020-09-04",
  "notificationType": "REPORT_PROCESSING_FINISHED",
  "payloadVersion": "1.0",
  "eventTime": "2022-02-18T03:05:00.197Z",
  "payload": {
    "reportProcessingFinishedNotification": {
      "sellerId": "A2BAZU3******",
      "reportId": "34997*********",
      "reportType": "GET_FLAT_FILE_VAT_INVOICE_DATA_REPORT",
      "processingStatus": "DONE",
      "reportDocumentId": "amzn1.tortuga.********************************************"
    }
  },
  "notificationMetadata": {
    "applicationId": "amzn1.sellerapps.app.********************",
    "subscriptionId": "36df6577-33c7-********************",
    "publishTime": "2022-02-18T03:05:00.230Z",
    "notificationId": "0cbae32d-222f-********************"
  }
}

FEED_PROCESSING_FINISHED notification 示例:

{
  "notificationVersion": "2020-09-04",
  "notificationType": "FEED_PROCESSING_FINISHED",
  "payloadVersion": "1.0",
  "eventTime": "2022-02-18T08:46:38.498Z",
  "payload": {
    "feedProcessingFinishedNotification": {
      "sellerId": "A2EW6******",
      "feedId": "625004******",
      "feedType": "POST_ORDER_FULFILLMENT_DATA",
      "processingStatus": "DONE",
      "resultFeedDocumentId": "amzn1.tortuga.********************************************"
    }
  },
  "notificationMetadata": {
    "applicationId": "amzn1.sellerapps.app.**************************",
    "subscriptionId": "4d5b53b4-66ad-4ee0-***************",
    "publishTime": "2022-02-18T08:46:39.950Z",
    "notificationId": "188fea65-74da-4fce-***************"
  }
}
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,099评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,828评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,540评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,848评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,971评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,132评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,193评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,934评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,376评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,687评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,846评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,537评论 4 335
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,175评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,887评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,134评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,674评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,741评论 2 351

推荐阅读更多精彩内容