前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Redis 应用实践-消息队列-解耦系统组件

Redis 应用实践-消息队列-解耦系统组件

原创
作者头像
玖叁叁
发布2023-04-15 17:42:03
2340
发布2023-04-15 17:42:03
举报
文章被收录于专栏:玖叁叁玖叁叁

Redis作为消息队列的应用场景之二是解耦系统组件。例如,当一个系统由多个组件组成时,每个组件都可以将消息推送到Redis队列中,而其他组件可以订阅这些队列以获取消息。这样,系统组件之间的通信变得简单而高效。

代码语言:javascript
复制
import redis
import time
import threading

r = redis.Redis(host='localhost', port=6379, db=0)

# 组件1
def component1():
    while True:
        # 执行任务1
        print('component1 task1')
        time.sleep(1)
        # 推送消息到队列
        r.publish('queue1', 'message from component1')

# 组件2
def component2():
    p = r.pubsub()
    p.subscribe('queue1')
    while True:
        message = p.get_message()
        if message and message['type'] == 'message':
            # 执行任务2
            print('component2 task2:', message['data'])

# 创建组件线程
t1 = threading.Thread(target=component1)
t2 = threading.Thread(target=component2)
t1.daemon = True
t2.daemon = True
t1.start()
t2.start()

# 等待程序结束
while True:
    time.sleep(1)

在此示例中,组件1向名为queue1的主题中发布消息,而组件2订阅queue1主题以获取消息。当组件1推送消息时,组件2将获取并处理消息。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
云数据库 Redis
腾讯云数据库 Redis(TencentDB for Redis)是腾讯云打造的兼容 Redis 协议的缓存和存储服务。丰富的数据结构能帮助您完成不同类型的业务场景开发。支持主从热备,提供自动容灾切换、数据备份、故障迁移、实例监控、在线扩容、数据回档等全套的数据库服务。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档