15、服务交互、测试、规范与安全保障

服务交互、测试、规范与安全保障

1. 消息队列与异步通信

在服务交互中,消息队列起着关键作用。以 RabbitMQ 为例,使用 Pika 库可以实现消息的发送和接收。以下是一个基本的消息消费代码示例:

channel.basic_consume("playstore", on_message)
try:
    channel.start_consuming()
except KeyboardInterrupt:
    channel.stop_consuming()
connection.close()

Pika 会向 RabbitMQ 发送消息确认(ACK),确保消息在工作进程成功处理后能从队列中安全移除,这是消息传递的至少一次策略。

对于消息的发布和接收,有不同的模式。
- 单队列消费模式 :之前的模式中,工作进程处理特定主题的消息,消息被消费后会从队列中移除。
- 发布/订阅(Pub/Sub)模式 :当需要将消息发布给多个工作进程时,就需要使用该模式。它是构建通用事件系统的基础,与单队列消费模式类似,有一个交换器和多个队列,但交换器类型为 fanout。绑定到 fanout 交换器的每个队列都会收到相同的消息,可用于向所有微服务广播消息。

异步消息通信还有以下要点:
- 微服务在可以异步执行某些工作时,应使用非阻塞调用,避免不必要的请求阻塞。
- 服务间通信不限于任务队列。
- 通过消息队列发送事件是避免组件紧密耦合的好方法。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值