AWSDAX和GSI在新增条目后的负缓存
创始人
2024-09-24 19:03:24
0

在AWS DAX和GSI中,如果在缓存数据时通过API直接创建或更新了新项,那么这些新添加的项会被添加到缓存中以供后续读取。但是,这些缓存的副本在从缓存中提取时可能不会反映最新的修改,因此可能会导致数据不一致。这种问题可能导致应用程序中出现引用或逻辑错误。

为了解决这个问题,您可以使用DynamoDB StreamsAWS Lambda。使用DynamoDB Streams,您可以获取对表的更改通知,然后使用Lambda执行适当的缓存更新和副本无效。以下是一些代码示例,展示了如何实现此方法:

触发器配置:

{
    "StreamViewType": "NEW_AND_OLD_IMAGES",
    "StreamSpecification": {
        "StreamEnabled": true,
        "StreamViewType": "NEW_AND_OLD_IMAGES"
    }
}

Lambda代码:

import boto3

dynamodb = boto3.resource('dynamodb')
dax = boto3.client('dax')

def lambda_handler(event, context):
    for record in event['Records']:
        if record['eventName'] != "REMOVE":
            table_name = record['dynamodb']['TableName']
            region = record['awsRegion']
            record_id = record['dynamodb']['Keys']['recordId']['S']

            # 检查缓存
            try:
                response = dax.get_item(
                    TableName=table_name,
                    Key={'recordId':{'S':record_id}},
                    ConsistentRead=True
                )

                # 更新缓存
                if 'Item' in response:
                    item = response['Item']
                    dax.put_item(
                        TableName=table_name,
                        Item=item
                    )

            except:
                pass

            # 删除负缓存
            dynamodb_client = boto3.client('dynamodb', region_name=region)
            dynamodb_client.transact_write_items(
                TransactItems=[
                    {
                        'Delete': {
                            'TableName': table_name + '-GSI',
                            'Key': {
                                'recordId': {'S': record_id},
                                'gsiRecordId': {'S': record_id}
                            }
                        }
                    },
                    {
                        'Delete': {
                            'TableName': table_name + '-GSI',
                            'Key': {
                                'recordId': {'S': record_id},
                                'gsiName': {'S': 'exampleGSI'}

相关内容

热门资讯

保存时出现了1个错误,导致这篇... 当保存文章时出现错误时,可以通过以下步骤解决问题:查看错误信息:查看错误提示信息可以帮助我们了解具体...
汇川伺服电机位置控制模式参数配... 1. 基本控制参数设置 1)设置位置控制模式   2)绝对值位置线性模...
不能访问光猫的的管理页面 光猫是现代家庭宽带网络的重要组成部分,它可以提供高速稳定的网络连接。但是,有时候我们会遇到不能访问光...
本地主机上的图像未显示 问题描述:在本地主机上显示图像时,图像未能正常显示。解决方法:以下是一些可能的解决方法,具体取决于问...
不一致的条件格式 要解决不一致的条件格式问题,可以按照以下步骤进行:确定条件格式的规则:首先,需要明确条件格式的规则是...
表格中数据未显示 当表格中的数据未显示时,可能是由于以下几个原因导致的:HTML代码问题:检查表格的HTML代码是否正...
表格列调整大小出现问题 问题描述:表格列调整大小出现问题,无法正常调整列宽。解决方法:检查表格的布局方式是否正确。确保表格使...
Android|无法访问或保存... 这个问题可能是由于权限设置不正确导致的。您需要在应用程序清单文件中添加以下代码来请求适当的权限:此外...
【NI Multisim 14...   目录 序言 一、工具栏 🍊1.“标准”工具栏 🍊 2.视图工具...
银河麒麟V10SP1高级服务器... 银河麒麟高级服务器操作系统简介: 银河麒麟高级服务器操作系统V10是针对企业级关键业务...