要在AWS账户之间复制DynamoDB表,可以使用DynamoDB Streams和AWS Lambda函数来实现。
以下是一个解决方法的步骤和示例代码:
创建源DynamoDB表和目标DynamoDB表,确保两个账户都有相应的访问权限。
在源DynamoDB表上启用DynamoDB Streams。可以通过AWS Management Console或AWS CLI来完成此操作。
创建一个AWS Lambda函数,用于处理DynamoDB Streams中的数据并将其复制到目标DynamoDB表中。可以使用以下示例代码作为Lambda函数:
import boto3
def lambda_handler(event, context):
dynamodb = boto3.resource('dynamodb')
source_table = dynamodb.Table('source-table-name')
target_table = dynamodb.Table('target-table-name')
for record in event['Records']:
if record['eventName'] == 'INSERT' or record['eventName'] == 'MODIFY':
item = record['dynamodb']['NewImage']
target_table.put_item(Item=item)
elif record['eventName'] == 'REMOVE':
item = record['dynamodb']['Keys']
target_table.delete_item(Key=item)
return 'Successfully processed {} records.'.format(len(event['Records']))
请确保将代码中的source-table-name和target-table-name替换为实际的源表和目标表名称。
在AWS Lambda控制台中创建一个新的Lambda函数,并将上述代码复制并粘贴到函数代码编辑器中。
在Lambda函数的配置中,将触发器类型设置为DynamoDB,并选择源DynamoDB表以及启用的DynamoDB Streams。
保存并部署Lambda函数。
现在,当源DynamoDB表上的数据发生更改时,Lambda函数将被触发,并将更改复制到目标DynamoDB表中。
请注意,以上步骤和示例代码仅为参考,具体的实现方式可能因实际需求和环境而有所不同。