openstack中的rpc通信

OpenStack中的RPC机制用于实现跨进程通信,主要基于AMQP协议。AMQP通过Publisher、Consumer、Exchange和Queue进行消息传递。在OpenStack中,RPC使用Direct、Topic和Fanout三种Exchange Type。Server对应AMQP的Consumer,Client对应Publisher,Topic类似Topic Exchange,用于组织相关方法。Namespace、Method和API version则是RPC的扩展概念,提供方法版本管理和组织。
摘要由CSDN通过智能技术生成

RPC即Remote Procedure Call(远程方法调用),是Openstack中一种用来实现跨进程(或者跨机器)的通信机制。Openstack中同项目内(如nova, neutron, cinder...)各服务(service)及通过RPC实现彼此间通信。

RCP只定义了一个通信接口,其底层的实现可以各不相同。目前Openstack中的主要采用AMQP来实现。AMQP(Advanced Message Queuing Protocol)是一种基于队列的可靠消息服务协议,具体可参考http://en.wikipedia.org/wiki/Advanced_Message_Queuing_Protocol。作为一种通信协议,AMQP同样存在多个实现,如Apache Qpid, RabbitMQ等。


AMQP 模型有四个重要的角色:

  • Publisher:消息发送者,将消息发送的 Exchange 并指明 Routing Key,以便 Message Queue 可以正确的收到消息。Routing key用于 Exchange 判断哪些消息需要发送对应的 Message Queue。

  • Consumer:消息接受者,从 Message Queue 获取消息。

  • Exchange:根据 Routing key 转发消息到对应的 Message Queue 中。

  • queue:

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值