How to push the data from dynamodb through stream

前端 未结 2 1143
天涯浪人
天涯浪人 2021-01-24 04:59

Below is the json file

[
    {
        "year": 2013,
        "title": "Rush",
        "actors": [
                "Da         


        
2条回答
  •  一生所求
    2021-01-24 05:34

    DynamoDB has a built in feature (DynamoDB streams) that will handle the stream part of this question.

    When you configure this you have the choice of the following configurations:

    • KEYS_ONLY — Only the key attributes of the modified item.
    • NEW_IMAGE — The entire item, as it appears after it was modified.
    • OLD_IMAGE — The entire item, as it appeared before it was modified.
    • NEW_AND_OLD_IMAGES — Both the new and the old images of the item.

    This will produce an event that looks like the following

    {
       "Records":[
          {
             "eventID":"1",
             "eventName":"INSERT",
             "eventVersion":"1.0",
             "eventSource":"aws:dynamodb",
             "awsRegion":"us-east-1",
             "dynamodb":{
                "Keys":{
                   "Id":{
                      "N":"101"
                   }
                },
                "NewImage":{
                   "Message":{
                      "S":"New item!"
                   },
                   "Id":{
                      "N":"101"
                   }
                },
                "SequenceNumber":"111",
                "SizeBytes":26,
                "StreamViewType":"NEW_AND_OLD_IMAGES"
             },
             "eventSourceARN":"stream-ARN"
          },
          {
             "eventID":"2",
             "eventName":"MODIFY",
             "eventVersion":"1.0",
             "eventSource":"aws:dynamodb",
             "awsRegion":"us-east-1",
             "dynamodb":{
                "Keys":{
                   "Id":{
                      "N":"101"
                   }
                },
                "NewImage":{
                   "Message":{
                      "S":"This item has changed"
                   },
                   "Id":{
                      "N":"101"
                   }
                },
                "OldImage":{
                   "Message":{
                      "S":"New item!"
                   },
                   "Id":{
                      "N":"101"
                   }
                },
                "SequenceNumber":"222",
                "SizeBytes":59,
                "StreamViewType":"NEW_AND_OLD_IMAGES"
             },
             "eventSourceARN":"stream-ARN"
          },
          {
             "eventID":"3",
             "eventName":"REMOVE",
             "eventVersion":"1.0",
             "eventSource":"aws:dynamodb",
             "awsRegion":"us-east-1",
             "dynamodb":{
                "Keys":{
                   "Id":{
                      "N":"101"
                   }
                },
                "OldImage":{
                   "Message":{
                      "S":"This item has changed"
                   },
                   "Id":{
                      "N":"101"
                   }
                },
                "SequenceNumber":"333",
                "SizeBytes":38,
                "StreamViewType":"NEW_AND_OLD_IMAGES"
             },
             "eventSourceARN":"stream-ARN"
          }
       ]
    }
    

    As you're already familiar with Lambda it makes sense to use a Lambda function to consume the records and then iterate through them to process them in the Elasticsearch format before adding them to your index.

    When doing this make sure that you iterate through each record as there may be multiple depending on your configuration.

    For more information on the steps required for the Lambda side of the function check out the Tutorial: Using AWS Lambda with Amazon DynamoDB streams page.

提交回复
热议问题