RabbitMQ消息队列的安装,以及在python中的简单使用

RabbitMQ作为一个企业级的被广泛使用的消息队列,其强大自然不需多说,任务堆积能力,并发能力,分布式,高可用,支持多协议等等,这次就讲讲怎么在虚拟机上部署RabbitMQ
我是在centos7上进行部署的
RabbitMQ是erlang编写的,我们必须先安装erlang才行,我们使用源码安装

wget http://erlang.org/download/otp_src_21.1.tar.gz
tar -zxvf otp_src_21.1.tar.gz

解压好之后进行编译安装


cd otp_src_21.1
# 这里要新建一个erlang文件夹,因为erlang
编译安装默认是装在/usr/local下的bin和lib中,
这里我们将他统一装到/usr/local/erlang中,方便查找和使用。
mkdir -p /usr/local/erlang
 
# 在编译之前,必须安装以下依赖包
yum install -y make gcc gcc-c++ m4 openssl openssl-devel ncurses-devel unixODBC unixODBC-devel java java-devel
 
./configure --prefix=/usr/local/erlang

在这里插入图片描述
出现这种情况是正常的
然后直接编译安装

make && make install

在这里插入图片描述
然后在/usr/local/erlang路径下可以看到bin和lib文件夹,这就证明OK了,然后配置一下环境

vim /etc/profile  #打开环境配置文件
PATH=$PATH:/usr/local/erlang/bin  #将erlang路径加入到里面
source /etc/profile  #刷新该文件

输入下erl,出现了交互界面就代表成功了
下载安装rabbitmq

wget https://github.com/rabbitmq/rabbitmq-server/releases/download/v3.7.8/rabbitmq-server-generic-unix-3.7.8.tar.xz
tar -xvf rabbitmq-server-generic-unix-3.7.8.tar.xz -C /usr/local/
#这里是下载解压3.7.8版本的rabbitmq

配置环境

vim /etc/profile
PATH=$PATH:/usr/local/rabbitmq_server-3.7.8/sbin
source /etc/profile
rabbitmq-plugins enable rabbitmq_management  #添加web管理的插件

接下来需要删除一个目录

find / -name mnesia 
#找到并删除这个目录,你可以先mv在删除

如果你不删除mnesia这个目录,可能会报结点错误或者Warning: PID file not written; -detached was passed等错误
然后访问ip地址:15672,就可以登录rabbitmq的web管理界面
在这里插入图片描述
你要去修改一下rabbitmq配置文件中/etc/rabbitmq/rabbitmq.config的{loopback_users, [<<“guest”>>]} 选项,改为{loopback_users, []},否则你登录的时候会报错,因为处于安全的考虑,3.3版本之后guest这个默认的用户只能通过localhost来登录,其他的IP无法直接使用这个账号

其他的命令扩展:
服务启动停止:
启动: rabbitmq-server -detached
停止: rabbitmqctl stop

插件管理:
插件列表: rabbitmq-plugins list
启动插件: rabbitmq-plugins enable XXX (XXX为插件名)
停用插件: rabbitmq-plugins disable XXX

用户管理:
添加用户: rabbitmqctl add_user username password
删除用户: rabbitmqctl delete_user username
修改密码: rabbitmqctl change_password username newpassword
设置用户角色: rabbitmqctl set_user_tags username tag
列出用户: rabbitmqctl list_users

权限管理:
列出所有用户权限: rabbitmqctl list_permissions
查看制定用户权限: rabbitmqctl list_user_permissions username
清除用户权限: rabbitmqctl clear_permissions [-p vhostpath] username
设置用户权限:
rabbitmqctl set_permissions [-p vhostpath] username conf write read
conf: 一个正则匹配哪些资源能被该用户访问
write:一个正则匹配哪些资源能被该用户写入
read:一个正则匹配哪些资源能被该用户读取

在python中使用rabbitmq:

发送方:

import pika  #导入pika模块,这是在python使用rabbitmq的库

#创建一个连接实例
connection = pika.BlockingConnection(pika.ConnectionParameters('10.10.21.189'))
#建立连接
channel = connection.channel()

#申明一个队列名叫hello
channel.queue_declare(queue='hello',durable=True)
#往队列中添加数据
channel.basic_publish(exchange='',  #指定交换机,我这里没有指定,暂时没用
                      routing_key='hello',#指定队列
                      body='world',#指定数据
                      properties=pika.BasicProperties(delivery_mode=2)#消息持久化
                      )
connection.close()  #关闭连接

接收方:

import pika

connection = pika.BlockingConnection(pika.ConnectionParameters('10.10.21.189'))
channel = connection.channel()
channel.queue_declare(queue='hello',durable=True)#接收方也要申明一下队列,方面,因为你不知道是发送方先启动还是接收方先启动

def callback(ch,method,properties,body):  #定义一个回调函数
    print(ch,method,properties)
    print("msg:")
    print(body)
    ch.basic_ack(delivery_tag=method.delivery_tag)  #确定这个传递标签

channel.basic_consume(queue='hello',on_message_callback=callback)  #从队列中拿消息,然后传回回调函数
channel.start_consuming()  #开始这个接收,这时候是阻塞的,其实可以通过消息驱动防止长时间阻塞,下次再说

这里提供了一个很小的发送以及接收消息的例子,其实还有
消息订阅与发布模式
消息组播模式
消息RPC等模式
下次再专门写一篇文章来讲解

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值