RabbitMQ 安装使用教程
环境 CentOS7 + Python3.5 yum -y install epel-release erlang socat
cd /usr/local/src
wget http://www.rabbitmq.com/releases/rabbitmq-server/v3.6.15/rabbitmq-server-3.6.15-1.el7.noarch.rpm
yum install rabbitmq-server-3.6.-.el7.noarch.rpm 插件列表查询: rabbitmq-plugins list
开启管理功能: rabbitmq-plugins enable rabbitmq_management 增加访问用户,默认用户guest只能本地访问。
rabbitmqctl add_user admin 设置用户角色: rabbitmqctl set_user_tags admin administrator
权限设置:rabbitmqctl set_permissions [-p vhostpath] {user} {conf} {write} {read}
conf: 一个正则表达式match哪些配置资源能够被该用户访问。
write: 一个正则表达式match哪些配置资源能够被该用户读。
read: 一个正则表达式match哪些配置资源能够被该用户访问。 权限设置示例: rabbitmqctl set_permissions -p / admin ".*" ".*" ".*" 列出所有用户: rabbitmqctl list_users
删除用户: rabbitmqctl delete_user {username}
修改用户密码: rabbitmqctl change_password {username} {newpassword} 启动: rabbitmq-server -detached
关闭: rabbitmqctl stop
服务器状态: rabbitmqctl status
集群状态: rabbitmqctl cluster_status
添加vhost: rabbitmqctl add_vhost {name}
删除vhost: rabbitmqctl delete_vhost {name}
生产者文件 producer.py
import pika, sys
credentials = pika.PlainCredentials("admin", "")
conn_params = pika.ConnectionParameters("192.168.205.128", virtual_host="/", credentials=credentials)
conn_broker = pika.BlockingConnection(conn_params)
channel = conn_broker.channel()
channel.confirm_delivery() # 将信道设置为confirm模式
msg = sys.argv[1] # 将第一个参数作为消息内容
msg_props = pika.BasicProperties()
msg_props.content_type = "text/plain"
ack = channel.basic_publish(body=msg, exchange="hello-exchange", properties=msg_props, routing_key="hola") # 发布信息
if ack is True:
print ("put message to rabbitmq successed!")
else:
print ("put message to rabbitmq failed")
channel.close()
消费者文件 consumer.py
import pika
credentials = pika.PlainCredentials("admin", "")
conn_params = pika.ConnectionParameters("192.168.205.128", virtual_host="/", credentials=credentials)
conn_broker = pika.BlockingConnection(conn_params)
channel = conn_broker.channel() # 获取信道
channel.exchange_declare("hello-exchange", "direct", passive=False, durable=True, auto_delete=False) # 声明交换器
channel.queue_declare(queue="hello-queue") #声明队列
channel.queue_bind(queue="hello-queue", exchange="hello-exchange", routing_key="hola") # 使用路由键绑定队列和交换器
def msg_consumer(channel, method, header, body): # 处理消息
channel.basic_ack(delivery_tag=method.delivery_tag) # 消息确认
print ("%d : '%s' " %(method.delivery_tag, body) )
if body == b'quit': # 这里的 body 是 bytes 类型
channel.basic_cancel(consumer_tag="hello-consumer") # 停止消费并退出
channel.stop_consuming()
return
# 订阅消费者
channel.basic_consume( msg_consumer, queue="hello-queue", consumer_tag="hello-consumer")
channel.start_consuming() # 开始消费
RabbitMQ 安装使用教程的更多相关文章
- Window10下RabbitMQ安装图文教程
版权声明:本文为博主原创文章,未经博主允许欢迎转载,请注明原文链接.一起交流,共同进步. https://blog.csdn.net/newbie_907486852/article/details/ ...
- 转:Window10下RabbitMQ安装图文教程
一.erlang下载安装 1.下载 下载erlang,原因在于RabbitMQ服务端代码是使用并发式语言erlang编写的,下载地址:http://www.erlang.org/downloads,双 ...
- Mac环境下RabbitMq安装与测试教程
RabbitMq安装与测试教程 Installing on Mac I. 安装 123456789 brew install rabbitmq ## 进入安装目录cd /usr/local/Cella ...
- linux中RabbitMQ安装教程
linux中RabbitMQ安装教程 在做一个微服务项目时候用到消息队列,于是深入了解了消息队列知识,并在linux上安装了Rabbitmq,本博客介绍Rabbitmq的安装教程,想要深入了解消息队列 ...
- rabbitmq安装.教程
https://www.cnblogs.com/ericli-ericli/p/5902270.html (rabbitmq安装)https://www.cnblogs.com/iiwen/p/538 ...
- Ubuntu 16.04 RabbitMq 安装与运行(安装篇)
Ubuntu 16.04 RabbitMq 安装与运行(安装篇) 2018年08月15日 15:05:24 我跟吴彦祖四六开 阅读数:1966 前言 目前公司用阿里云 + redis 的方式实现的 ...
- rabbitMQ学习1:消息队列介绍与rabbitmq安装使用
1. 什么是消息队列 生活里的消息队列,如同邮局的邮箱, 如果没邮箱的话, 邮件必须找到邮件那个人,递给他,才玩完成,那这个任务会处理的很麻烦,很慢,效率很低 但是如果有了邮箱, 邮件直接丢给邮箱,用 ...
- 消息队列rabbitmq rabbitMQ安装
消息队列rabbitmq 12.1 rabbitMQ 1. 你了解的消息队列 生活里的消息队列,如同邮局的邮箱, 如果没邮箱的话, 邮件必须找到邮件那个人,递给他,才玩完成,那这个任务会处理的很麻 ...
- SpringBoot系列之RabbitMQ使用实用教程
SpringBoot系列之RabbitMQ使用实用教程 @ 目录 1. 消息队列概述 1.1 MQ的概述 1.2 MQ目的地形式 2. 消息队列实现方式 2.1 常见MQ框架 2.2 MQ实现方式 3 ...
随机推荐
- If the parts of an organization (e.g., teams, departments, or subdivisions) do not closely reflect the essential parts of the product, or if the relationship between organizations do not reflect the r
https://en.wikipedia.org/wiki/Conway%27s_law
- 深入理解Flask中的上下文
https://blog.csdn.net/barrysj/article/details/51519254 1.AppContext类即是应用上下文,可以看到里面只保存了几个变量,其中比较重要的有: ...
- Django1.6 运行manage.py 报错解决办法(ImportError)
django项目中运行manage.py python manage.py runserver 出现如下错误提示: Traceback (most recent call last): File &q ...
- 如何实现手游app瘦身?
手游服务商来说,手游包体大一直是个很困扰的问题.一款手游产品而言,包体大小和更新方式对于有效用户的转化率往往起到非常关键的作用,话说手游安装包越小,用户转化率越高,那该如何实现app瘦身呢? 工具/原 ...
- 22.Atomicity and Transactions-官方文档摘录
原子性和事务 1 在单个文档修改多个嵌入文档,写操作都在文档级别上都是原子的 2 在单个写操作修改多个文档时,每个文档的修改都具有原子性,但是,作为一个整体的操作,并不是原子的.其他操作可能有交互.使 ...
- maven 之 web.xml 头设置错误问题
1.一般开发工具创建web.xml的时候会默认添加web.xml头,而有些插件(例如maven相关插件)默认添加的为 版本和你的开发工具Project facets(项目特性)中设置不同.那么就会导致 ...
- 设计模式C++实现——适配器模式
版权声明:本文为博主原创文章,未经博主同意不得转载. https://blog.csdn.net/walkerkalr/article/details/29863177 模式定义: 适 ...
- Spark2.0机器学习系列之5:随机森林
概述 随机森林是决策树的组合算法,基础是决策树,关于决策树和Spark2.0中的代码设计可以参考本人另外一篇博客: http://www.cnblogs.com/itboys/p/8312894.ht ...
- Spring第二弹—–搭建与测试Spring的开发环境
PS:Spring既可以使用在javaSE中,也可以使用在javaWeb中. 使用Spring需要的jar 下载spring(我下载的是2.5.6版本),然后进行解压缩,在解压目录中找到下面jar文件 ...
- 生信-序列比较dp[未完成]
来自:生物信息学-陈铭第二版的一个例题. 题目: 目前的代码,运行不正确,关键就是不知道怎么回溯啊,回溯怎么标记呢? #include <iostream> #include<vec ...