RabbitMQ的RPM包安装和Python读写操作

下载地址

bash 复制代码
## erlang 下载地址
https://packagecloud.io/rabbitmq/erlang?page=6

## rabbitmq 下载地址
https://packagecloud.io/rabbitmq/rabbitmq-server/packages/el/7/rabbitmq-server-3.8.29-1.el7.noarch.rpm?distro_version_id=140

Rabbitmq的RPM包安装

bash 复制代码
## 下载
wget --content-disposition "https://packagecloud.io/rabbitmq/erlang/packages/el/7/erlang-21.3.8.18-1.el7.x86_64.rpm/download.rpm?distro_version_id=140"

##
wget --content-disposition "https://packagecloud.io/rabbitmq/rabbitmq-server/packages/el/7/rabbitmq-server-3.8.29-1.el7.noarch.rpm/download.rpm?distro_version_id=140"

###
rpm --import https://www.rabbitmq.com/rabbitmq-release-signing-key.asc

默认账号密码:guest/guest,rabbitmq 从 3.3.0 开始禁止使用 guest/guest 权限通过除 localhost 外的访问。

创建后创建用户相关命令

bash 复制代码
## 创建用户,第二个knight 为密码
rabbitmqctl add_user knight knight

##设置用户分配操作权限
rabbitmqctl set_user_tags knight administrator

##
rabbitmqctl set_permissions -p / knight ".*" ".*" ".*"

##
systemctl status rabbitmq-server

## 开启 web 访问
rabbitmq-plugins enable rabbitmq_management

其他常用命令

bash 复制代码
##
https://blog.csdn.net/knight_zhou/article/details/132599796

Python读写

bash 复制代码
### 依赖库
pip install pika

参考文章

bash 复制代码
##
https://support.huaweicloud.com/intl/zh-cn/devg-rabbitmq/rabbitmq-devg-003.html

生产者

bash 复制代码
import pika
import random

random_int = random.randint(1,100)
#Connection information
conf = {
    'host': 'yy.cn',
    'port': 5672,
    'queue_name': 'queue-test',
    'username': 'admin',
    'password': 'admin'
}

credentials = pika.PlainCredentials(conf['username'], conf['password'])
parameters = pika.ConnectionParameters(conf['host'],
                                       conf['port'],
                                       '/',
                                       credentials)

connection = pika.BlockingConnection(parameters)
channel = connection.channel()

channel.queue_declare(conf['queue_name'])

# data = bytes(str(random_int), encoding="utf-8")
data = bytes("cc", encoding="utf-8")

channel.basic_publish(exchange='',
                      routing_key=conf['queue_name'],
                      body=data)

print("produce...")

connection.close()

消费者

python 复制代码
import pika

#Connection information
conf = {
    'host': 'yy.cn',
    'port': 5672,
    'queue_name': 'queue-test',
    'username': 'admin',
    'password': 'admin'
}

credentials = pika.PlainCredentials(conf['username'], conf['password'])
parameters = pika.ConnectionParameters(conf['host'],
                                       conf['port'],
                                       '/',
                                       credentials)

connection = pika.BlockingConnection(parameters)
channel = connection.channel()
channel.queue_declare(conf['queue_name'])


def callback(ch, method, properties, body):
    print(" [x] Received %r" % body.decode('utf-8'))


channel.basic_consume(queue=conf['queue_name'], on_message_callback=callback, auto_ack=True)

print(' [*] Waiting for messages. To exit press CTRL+C')
channel.start_consuming()
相关推荐
Zz_waiting.3 小时前
分布式部署
分布式
人间打气筒(Ada)6 小时前
Centos7 搭建hadoop2.7.2、hbase伪分布式集群
数据库·分布式·hbase
原来是好奇心8 小时前
消息队列终极选型:RabbitMQ、RocketMQ、Kafka与ActiveMQ深度对比
分布式·kafka·rabbitmq·rocketmq·activemq·mq
9ilk9 小时前
【仿RabbitMQ的发布订阅式消息队列】 ---- 功能测试联调
linux·服务器·c++·分布式·学习·rabbitmq
周杰伦_Jay9 小时前
【RPC:分布式跨节点透明通信协议】【Raft:简单易实现的分布式共识算法】
分布式·rpc·共识算法
嗝屁小孩纸10 小时前
免费测评RPC分布式博客平台(仅用云服务器支持高性能)
服务器·分布式·rpc
Alex艾力的IT数字空间10 小时前
完整事务性能瓶颈分析案例:支付系统事务雪崩优化
开发语言·数据结构·数据库·分布式·算法·中间件·php
mywpython11 小时前
Python使用消息队列rabbitmq
开发语言·python·rabbitmq
ANYOLY11 小时前
RabbitMQ 核心知识点
分布式·rabbitmq
炼金士15 小时前
分布式虚拟 Actor 技术在码头生产调度中的应用研究
分布式·dapr·actor·集装箱码头