OpenStack消息队列AMQP技术具体实现 [分析基于icehouse]

本文详细介绍了OpenStack中AMQP的使用,强调了其解耦、异步和负载均衡的优势。OpenStack支持RabbitMQ、Qpid等消息中间件,以Qpid为例,阐述了invoker和worker的角色,包括TopicPublisher、TopicConsumer、DirectPublisher、DirectConsumer等组件的工作原理,并通过图表解析rpc.call和rpc.cast的流程。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >


       本文系技术总结,供将来需要时翻开看看, 如有错误, 欢迎交流微笑

 第一部分:关键技术

       先发下感慨, 社区的code真是变化太快, code结构发生了很大的重构增强, 关于消息队列, openstack.common.rpc慢慢的都会转移到oslo.messaging上,以我2014年3月的code为例, 仅有heat, neutron, ceilometer没有转移。无论架构和部分实现如何变化,技术原理还是原来的原理。

       OpenStack中的消息队列技术使用的AMQP(Advanced Message Queue Protocol)异步消息处理机制。AMQP使用的是发布/订阅的模式, 它的好处是

       1)  实现消息发布方(服务器端)和消息处理方(客户端)的解耦和。

        2) 消息发布方和消息处理方可以是异步的

        3) 可以做到负载均衡。这个就涉及到消息队列中间件的实现问题, 当多个server端在运行, 请求就会被它们平衡到各个server端

        OpenStack支持RabiitMQ或者Qpid,也可以使用Zero MQ等等消息中间件,一般通过指定rpc_backend

rpc_backend = nova.openstack.common.rpc.impl_qpid #impl_qpid为qpid, impl_kommu为Rabbitmq,impl_zmq为Zero MQ, 当发现没有nova.opens

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值