服务器端

 
 

安装 ubuntu 16.04 server

 
 

安装 rabbitmq-server

 
 

设置 apt 源

curl -s https://packagecloud.io/install/repositories/rabbitmq/rabbitmq-server/script.python.sh | bash

 
 

使用 apt-get install rabbitmq-server 安装 rabbitmq 服务器

 
 

按键Y或者 y 确认安装

 
 

 
 

rabbitmq-server 简单管理

 
 

rabbitmq-server通过 rabbitmqctl 进行管理,以
管理员身份执行 rabbitmqctl 可以列出全部可以使用的
指令

 
 

创建用户

sudo rabbitmqctl add_user user_name password

 
 

更改密码

sudo rabbitmqctl change_password user_name new_password

 
 

增加虚拟主机

sudo rabbitmqctl add_vhost vhost_name

 
 

授予权限

sudo rabbitmqctl set_permissions -p vhost_name user_name ".*" ".*" ".*"

 
 

 
 

说明:

user_name为
用户名

password 为密码

new_password 为新密码

vhost_name 为
虚拟主机名

".*" ".*" ".*" 为权限,分别代表 configure , read , write

 
 

 
 

 
 

 
 

如果出现错误,可以
查看 rabbitmq-server 日志, sudo tail -f /var/log/rabbitmq/rabbit@ubuntu

 
 

 
 

 
 

注意:默认用户 guest 不允许远程访问

 
 

 
 

安装管理插件

 
 

使用命令 sudo rabbitmq-plugins enable rabbitmq_management

 
 

 
 

使用 rabbitmq-server 的端口 15672 访问管理系统

 
 

 
 

登录
管理平台的用户,必须授予 adminstrator 权限,
使用命令 sudo rabbitmqctl set_user_tags user_name administrator, 例如

 
 

使用
授权的用户登录

 
 

 
 

 
 

客户端使用

 
 

安装 pika

 
 

使用命令 pip install pika 安装 pika 库

 
 

 
 

测试
例程

 
 

import pika

import random

 
 

credentials = pika.PlainCredentials('jeffery', '1234')

#这里可以连接远程IP,请记得打开远程端口

parameters = pika.ConnectionParameters('192.168.30.128',5672,'/',credentials)

connection = pika.BlockingConnection(parameters)

channel = connection.channel()

 
 

#channel.queue_declare(queue='hello')

number = random.randint(1,1000)

body = 'hello world:%s' %number

channel.basic_publish(exchange='',

routing_key='hello',

body=body)

print " [x] Sent %s" %body

connection.close()

 
 

 
 

测试
成功,例如

 
 

 
 

 
 

RPC 模式

 
 

客户端发送一个请求消息然后服务器回复一个响应消息。为了收到一个响应,我们需要发送一个'回调'的请求的队列地址。我们可以使用默认队列(在Java客户端除外)。

AMQP协议给消息定义了14个属性。大部分的属性很少使用,除了下面几个:

deliveryMode: 将消息标记为持久(值为2)或瞬态(任何其他值)。你可能记得在第二个教程中使用了这个属性。

contentType:用来设置mime类型。例如经常使用的JSON格式数据,就需要将此属性设置为:application/json。

replyTo: 通常用来命名一个回调队列.

correlationId: 用来关联RPC请求的响应.

 
 

 
 

 
 

工作流程

1)、客户端启动时,创建了一个匿名的回调队列。

2)、在一个RPC请求中,客户端发送一个消息,它有两个属性:1.REPLYTO,用来设置回调队列名;2.correlationId,对于每个请求都被设置成唯一的值。

3)、请求被发送到rpc_queue队列.

4)、RPC工作者(又名:服务器)等待接收该队列的请求。当收到一个请求,它就会处理并把结果发送给客户端,使用的队列是replyTo字段指定的。

5)、客户端等待接收回调队列中的数据。当接到一个消息,它会检查它的correlationId属性。如果它和设置的相匹配,就会把响应返回给应用程序。

 
 

 
 

例程:

 
 

rpc_server.py

 
 

#!/usr/bin/env python

import pika

 
 

credentials = pika.PlainCredentials('jeffery', '1234')

connection = pika.BlockingConnection(pika.ConnectionParameters('192.168.30.128',5672,'/',credentials))

 
 

channel = connection.channel()

 
 

channel.queue_declare(queue='rpc_queue')

 
 

def fib(n):

if n == 0:

return 0

elif n == 1:

return 1

else:

return fib(n-1) + fib(n-2)

 
 

def on_request(ch, method, props, body):

n = int(body)

 
 

print(" [.] fib(%s)" % n)

response = fib(n)

 
 

ch.basic_publish(exchange='',

routing_key=props.reply_to,

properties=pika.BasicProperties(correlation_id = \

props.correlation_id),

body=str(response))

ch.basic_ack(delivery_tag = method.delivery_tag)

 
 

channel.basic_qos(prefetch_count=1)

channel.basic_consume(on_request, queue='rpc_queue')

 
 

print(" [x] Awaiting RPC requests")

channel.start_consuming()

 
 

 
 

rpc_client.py

 
 

#!/usr/bin/env python

import pika

import uuid

 
 

class FibonacciRpcClient(object):

def __init__(self):

credentials = pika.PlainCredentials('jeffery', '1234')

self.connection = pika.BlockingConnection(pika.ConnectionParameters('192.168.30.128',5672,'/',credentials))

 
 

self.channel = self.connection.channel()

 
 

result = self.channel.queue_declare(exclusive=True)

self.callback_queue = result.method.queue

 
 

self.channel.basic_consume(self.on_response, no_ack=True,

queue=self.callback_queue)

 
 

def on_response(self, ch, method, props, body):

if self.corr_id == props.correlation_id:

self.response = body

 
 

def call(self, n):

self.response = None

self.corr_id = str(uuid.uuid4())

self.channel.basic_publish(exchange='',

routing_key='rpc_queue',

properties=pika.BasicProperties(

reply_to = self.callback_queue,

correlation_id = self.corr_id,

),

body=str(n))

while self.response is None:

self.connection.process_data_events()

return int(self.response)

 
 

fibonacci_rpc = FibonacciRpcClient()

 
 

print(" [x] Requesting fib(30)")

response = fibonacci_rpc.call(30)

print(" [.] Got %r" % response)

 
 

 
 

运行例程的效果

 
 

服务端

 
 

客户端

使用rabbitmq rpc 模式的更多相关文章

  1. RPC模式的Hub操作

    signalR 专题—— 第四篇 模拟RPC模式的Hub操作   在之前的文章中,我们使用的都是持久连接,但是使用持久连接的话,这种模拟socket的形式使用起来还是很不方便的,比如只有一个唯一的 O ...

  2. 【python】-- RabbitMQ RPC模型

    RabbitMQ RPC模型 RPC(remote procedure call)模型说通俗一点就是客户端发一个请求给远程服务端,让它去执行,然后服务端端再把执行的结果再返回给客户端. 1.服务端 i ...

  3. rabbitMQ tipic 模式

    RabbitMQ消息队列(八)-通过Topic主题模式分发消息(.Net Core版) 前两章我们讲了RabbitMQ的direct模式和fanout模式,本章介绍topic主题模式的应用.如果对di ...

  4. 1.RabbitMq - Work 模式

    RabbitMq - Work 模式 一.什么是Work模式 如果有几个消息都需要处理,且每个消息的处理时间很长,仅有一个消费者,那么当它在处理一个消息的时候,其他消息就只有等待. 等待有时候是好的, ...

  5. Solon rpc 之 SocketD 协议 - 单链接双向RPC模式

    Solon rpc 之 SocketD 协议系列 Solon rpc 之 SocketD 协议 - 概述 Solon rpc 之 SocketD 协议 - 消息上报模式 Solon rpc 之 Soc ...

  6. 8.rabbitmq RPC模拟微服务架构中的服务调用

    标题 : 8.rabbitmq RPC模拟微服务架构中的服务调用 目录 : RabbitMQ 序号 : 8 { var connectionFactory = new ConnectionFactor ...

  7. RabbitMQ双向发送(接收端有返回RPC模式)

    remote procedure call 服务端 import pika import time connection = pika.BlockingConnection(pika.Connecti ...

  8. RabbitMQ工作模式

    ------------恢复内容开始------------ RabbitMQ基本概念: Producer:生产者(消息的提供者) Consumer:消费者(消息的使用者) Message:消息(程序 ...

  9. asp.net signalR 专题—— 第四篇 模拟RPC模式的Hub操作

    在之前的文章中,我们使用的都是持久连接,但是使用持久连接的话,这种模拟socket的形式使用起来还是很不方便的,比如只有一个唯一的 OnReceived方法来处理业务逻辑,如下图: protected ...

随机推荐

  1. POJ2154 Color 【Polya定理 + 欧拉函数】

    题目 Beads of N colors are connected together into a circular necklace of N beads (N<=1000000000). ...

  2. Python之数据结构:集合

    一.set集合 1.集合是一个无序不重复元素集,有去重的作用 set集合类需要的参数必须是迭代器类型的,如:序列.字典等,然后转换成无序不重复的元素集.由于集合是不重复的,所以可以对字符串.列表.元组 ...

  3. JS 中如何输出空格

    在写JS代码的时候,大家可以会发现这样现象: document.write(" 1 2 3 "); 结果: 无论在输出的内容中什么位置有多少个空格,显示的结果好像只有一个空格. 这 ...

  4. artTemplate模板引擎的不同使用方式

    arttemplate提供了两种不同的使用方式 一种是将模板写在页面内 <script id="test" type="text/html"> &l ...

  5. Safari 11.0 已发布,新特性都在这儿了!

    Safari 11.0 兼容性 Safari 11.0 可运行于 iOS 11.0 和 macOS 10.1版本的系统环境,同时在macOS 10.12.6 和 10.11.6版本中也可以使用. Hi ...

  6. Docker学习之Docker Registry

    前言 前面已经学习了怎样通过Dockerfile来构建我们自己的镜像了,但是一个系统可能包含着很多个微服务即有很多个镜像,当镜像越来越多的时候,就必须得有一个地方来管理这些镜像,Docker官方提供了 ...

  7. ubuntu php编译安装配置

    安装参考:http://ilanni.blog.51cto.com/526870/1569322/ 加载扩展的一些参数参考:http://java-er.com/blog/nginx-php-fpm/

  8. css3 实现多行文本折行

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  9. Zookeeper如何从官网下载和安装

    打开百度搜索,输入Zookeeper关键词,一般第一条搜索记录就是apache官网下载的地址 进入apache官网,由于是国外的网站,里面内容都是英文的,可以大概看下Zookeeper的描述和介绍,在 ...

  10. java中 文件压缩处理

    public static void main(String[] args) throws IOException { File file=new File("./mhxx_configs. ...