AWSMSK触发器-Lambda(消费者)无限运行
创始人
2024-09-26 15:01:38
0

这个问题的出现是因为Lambda函数没有正确处理Kafka的消息。其结果是函数不断地尝试重新处理相同的消息,导致无限循环。

以下是一种可能的解决方法,通过使用“记录”功能,将Lambda函数的状态存储在DynamoDB表中,这样每条消息只会被消费一次:

import boto3
import json
import logging
import time

logger = logging.getLogger()
logger.setLevel(logging.INFO)
dynamodb = boto3.resource('dynamodb')
table = dynamodb.Table('lambda_state')

def lambda_handler(event, context):
    logger.info('Received event: ' + json.dumps(event))

    # Check if message has already been processed
    msg_id = event['Records'][0]['SNS']['MessageId']
    response = table.get_item(Key={'id': msg_id})

    if 'Item' not in response:
        # Process message
        logger.info('Processing message: ' + json.dumps(event))

        # Save state
        table.put_item(Item={'id': msg_id, 'timestamp': int(time.time())})

    else:
        logger.info('Message already processed: ' + json.dumps(event))

    return

此解决方案使用DynamoDB表来存储已处理的消息列表,并检查新的Kafka消息是否在此列表中。如果不在,则处理消息,并将其添加到DynamoDB表中。如果在,则跳过处理。

请注意,此方法仅使用了一个DynamoDB表。但是,在实际生产中,您可能需要使用多个表,具体取决于应用程序的要求和设计。

相关内容

热门资讯

第九分钟辅助!有哪些免费的wp... 第九分钟辅助!有哪些免费的wpk作弊码,wpk辅助哪里买,课程教程(有挂实锤)1)有哪些免费的wpk...
十分钟辅助!菠萝德普辅助器免费... 十分钟辅助!菠萝德普辅助器免费版在哪里,wpk透视辅助下载,妙计教程(有人有挂)1、玩家可以在菠萝德...
第三分钟辅助!wejoker私... 第三分钟辅助!wejoker私人辅助软件,hhpkoer辅助器,策略教程(今日头条)1、进入游戏-大...
八分钟辅助!aapoker辅助... 八分钟辅助!aapoker辅助器是真的吗,wpk俱乐部有没有辅助,项目教程(真实有挂)1、打开软件启...
1分钟辅助!智星菠萝透视,哈糖... 1分钟辅助!智星菠萝透视,哈糖大菠萝软件下载,技法教程(详细教程)该软件可以轻松地帮助玩家将哈糖大菠...
三分钟辅助!wpk真吗,pok... 三分钟辅助!wpk真吗,pokermaster辅助器,操作教程(有挂技巧);1、三分钟辅助!wpk真...
1分钟辅助!wepoker游戏... 1分钟辅助!wepoker游戏的安装教程,We poker辅助器下载,操作教程(有挂存在)1、wep...
第八分钟辅助!wepoker透... 第八分钟辅助!wepoker透视底牌脚本,德普之星怎么设置埋牌,手段教程(有挂教学)1、全新机制【德...
第3分钟辅助!wepoker透... 第3分钟辅助!wepoker透视最简单三个步骤,wepokerplus作弊,绝活教程(有挂详情)运w...
九分钟辅助!steampoke... 九分钟辅助!steampokermaster辅助,wpk作弊是真的吗,妙计教程(有挂教程)1、ste...