当前位置: 首页 > wzjs >正文

html 社区网站 模板ip138域名查询

html 社区网站 模板,ip138域名查询,wordpress主题添加设置选项,上海企业专属网站建设平台一、幂等性实现 1.1 什么是幂等性? 幂等性是指同一条消息无论被消费多少次,业务结果都只生效一次,防止重复扣款、重复发货等问题。 RabbitMQ 的投递模式是“至少一次交付”(at-least-once delivery),如果消费者处理失败或者没有及…

一、幂等性实现

1.1 什么是幂等性?

幂等性是指同一条消息无论被消费多少次,业务结果都只生效一次,防止重复扣款、重复发货等问题。

RabbitMQ 的投递模式是“至少一次交付”(at-least-once delivery),如果消费者处理失败或者没有及时确认,消息会被多次投递。如果业务本身不具备幂等性,就可能导致重复扣款、重复发货等严重后果。

1.2 实现思路

RabbitMQ 只负责消息的可靠投递,而不会记录每条消息是否已经被成功消费。因此,需要由消费者端维护消费状态,常见做法是借助 Redis 实现去重逻辑。

消息在生产阶段应携带全局唯一的 message_id(例如订单号:order:10010)。在消费逻辑中,先通过 Redis 的原子命令 SETNX 尝试写入该 message_id:①如果 SETNX返回1,表示第一次消费,可以处理;②如果返回0,表示已消费,直接忽略

 二、消息重放实现

在RabbitMQ中,ack和nack机制是保证可靠投递、实现重放的关键。

2.1 ack和nack

如果你的消费逻辑里既没有调用ack,也没有调用nack,消息状态会一直unacked。只要没确认,就永远不会删除消息。

(1) ack

确认消息已被消费成功。当消费者调用:

ch.basic_ack(delivery_tag=method.delivery_tag)

RabbitMQ就会把消息从队列里永久删除。只要你ack了,这条消息就不可能再来了。

(2) nack

告诉RabbitMQ“我没处理好”。有两种方式:

# 发送nack并重入队列
# RabbitMQ会立刻把消息放回队列,再投递给其他消费者。
ch.basic_nack(delivery_tag=method.delivery_tag, requeue=True)# 发送nack不重入队列
# 消息就会被丢弃(或者,如果绑定了死信队列,就转入死信队列)。
ch.basic_nack(delivery_tag=method.delivery_tag, requeue=False)

2.2 实现思路

生产者代码
import pika
import uuidconnection = pika.BlockingConnection(pika.ConnectionParameters('localhost'))
channel = connection.channel()
channel.queue_declare(queue='test_queue', durable=True)message_id = str(uuid.uuid4())
body = "test message"properties = pika.BasicProperties(delivery_mode=2,message_id=message_id
)channel.basic_publish(exchange='',routing_key='test_queue',body=body,properties=properties
)print(f"[x] Sent '{body}' with message_id {message_id}")connection.close()
 消费者代码
import pika
import redis
import time# Redis
r = redis.StrictRedis(host='localhost', port=6379, db=0)# RabbitMQ
connection = pika.BlockingConnection(pika.ConnectionParameters('localhost'))
channel = connection.channel()
channel.queue_declare(queue='test_queue', durable=True)def callback(ch, method, properties, body):message_id = properties.message_idif not message_id:import hashlibmessage_id = hashlib.md5(body).hexdigest()redis_key = f"msg:{message_id}"if r.setnx(redis_key, 1):r.expire(redis_key, 24*60*60)print(f"[x] Processing message: {body.decode()}")try:# 模拟异常if "fail" in body.decode():raise Exception("Simulated failure")# 成功处理ch.basic_ack(delivery_tag=method.delivery_tag)print("[+] Message processed successfully")except Exception as e:print(f"[!] Error: {e}")# 立即重放ch.basic_nack(delivery_tag=method.delivery_tag, requeue=True)else:# 已消费ch.basic_ack(delivery_tag=method.delivery_tag)print(f"[!] Duplicate message detected: {message_id}")channel.basic_qos(prefetch_count=1)
channel.basic_consume(queue='test_queue',on_message_callback=callback,auto_ack=False   # 手动ack
)print("[*] Waiting for messages. CTRL+C to exit")
channel.start_consuming()

http://www.dtcms.com/wzjs/814955.html

相关文章:

  • 文昌市建设局网站品牌商城网站建设公司
  • 湖南网站建设oqiandume域名免费注册
  • 电影网站制作教程好不好免费公司网站模版
  • 怎么学习做网站外贸网站翻译建设
  • 做网站建设的合同网站导航功能
  • 重庆制作网站手机应用市场
  • php网站开发 实战教程上海移动网站建设
  • 网站后台密码存在哪wordpress 忘记管理员密码
  • 网站开发有哪些风险整站优化哪家专业
  • 地方网站总结东莞市工程建设安监站网站
  • 网站 板块 模块姑苏网站建设
  • 怎么用php做网站方案商店名怎么显示在地图上
  • 蓝气球卡地亚手表官方网站电子商务网站关键技术
  • 携程前端网站开发团队您的网站空间即将过期
  • 公司企业网站建设教程一个空间放2个网站
  • 广东专业移动网站建设哪家好营销型网站建设注意
  • 做网站空间百度云和阿里云区别wordpress采集接口
  • html做电子书网站网站做中英版
  • 网站建设拿什么框架网站logo大全
  • 企业网站设计服务公司wordpress 天津机房
  • 关键词优化软件排行合肥seo推广培训
  • 苏州网站建设培训学校上海市交通建设工程安全质量监督站网站
  • 网站开发与运营案例教程电子商务网站建设与管理试题
  • ssp媒体服怎样做网站扬州市江都区城乡建设局网站
  • 网站设计与制作报价wordpress同标题覆盖
  • 做幼儿英语的教案网站黄山建设网站公司电话号码
  • 商品展示网站模板手机上page转换wordpress
  • 网站建设先买主机还是甘肃企业网站建设
  • 肇庆 网站建设 域联微信小程序应用开发赛
  • 建设银行网站上不去百度浏览官网