centos上安装rabbitmq并且python测试
把我的阿里云重置了一下,重新安装rabbitmq,看看会出现什么问题。
首先,把erlang环境安装一下,直接
yum list | grep erlang
erlang.x86_64 R16B-03.16.el7 epel
会找到上面这个库,直接安装就可以了。
yum install erlang.x86_64
安装好erlang环境,再下载rabbitmq包。
为了方便,直接下载rpm包,rpm包地址是:http://www.rabbitmq.com/releases/rabbitmq-server/v3.6.1/rabbitmq-server-3.6.1-1.noarch.rpm
下载好以后,直接安装、启动
rpm -ivh rabbitmq-server-3.6.-.noarch.rpm
service rabbitmq-server start
启动好以后,可以看看当前有哪些用户
[root@iZ94mr3pnsgZ download]# rabbitmqctl list_users
Listing users ...
guest [administrator]
只有一个guest,要不再加一个吧。
[root@iZ94mr3pnsgZ download]# rabbitmqctl add_user yueer01 password
好了,现在有第二个用户 yueer01,密码自己设置一个。但是这个yueer01没有权限,
[root@iZ94mr3pnsgZ download]# rabbitmqctl list_users
Listing users ...
yueer01 []
guest [administrator]
再给它加一个权限,目前rabbitmq提供4种权限。
none
不能访问 management plugin
management
用户可以通过AMQP做的任何事外加:
列出自己可以通过AMQP登入的virtual hosts
查看自己的virtual hosts中的queues, exchanges 和 bindings
查看和关闭自己的channels 和 connections
查看有关自己的virtual hosts的“全局”的统计信息,包含其他用户在这些virtual hosts中的活动。
policymaker
management可以做的任何事外加:
查看、创建和删除自己的virtual hosts所属的policies和parameters
monitoring
management可以做的任何事外加:
列出所有virtual hosts,包括他们不能登录的virtual hosts
查看其他用户的connections和channels
查看节点级别的数据如clustering和memory使用情况
查看真正的关于所有virtual hosts的全局的统计信息
administrator
policymaker和monitoring可以做的任何事外加:
创建和删除virtual hosts
查看、创建和删除users
查看创建和删除permissions
关闭其他用户的connections
为了省事,我们设置为administrator吧。
[root@iZ94mr3pnsgZ download]# rabbitmqctl set_user_tags yueer01 administrator
Setting tags for user "yueer01" to [administrator] ...
[root@iZ94mr3pnsgZ download]# rabbitmqctl list_users
Listing users ...
yueer01 [administrator]
guest [administrator]
都是管理员了,但老是命令行,还是不够清晰,rabbitmq为我们提供了一套非常容易的web管理,只要一条命令就可以启动了。
[root@iZ94mr3pnsgZ download]# rabbitmq-plugins enable rabbitmq_management
The following plugins have been enabled:
mochiweb
webmachine
rabbitmq_web_dispatch
amqp_client
rabbitmq_management_agent
rabbitmq_management
打开浏览器,输入id地址和端口,看看到底是什么。。。
http://your_ip_address:15672/
输入刚才申请的用户名密码,yueer01 password
进入web页面。看我下面的:

这就可以了,至于详细内容,可以自己去研究。
好了,至此,整个安装过程已经完毕,那我们用python代码在本地运行一下,看看会发生什么情况。
从rabbitmq官方找它的例子,修改一下,例子如下:
# coding:utf-8
import pika username = 'yueer01'
password = 'password'
host = '10.10.10.10' credentials = pika.PlainCredentials(username, password)
connection = pika.BlockingConnection(pika.ConnectionParameters(host=host, credentials=credentials, port=5672))
channel = connection.channel() channel.queue_declare(queue='hello') channel.basic_publish(exchange='',
routing_key='hello',
body='Hello World!') print "[x] Sent 'Hello World!'"
connection.close()
呀!居然报错了,看看错误原因
pika.exceptions.ProbableAccessDeniedError
被拒绝了,一般任何网络服务,对于权限都有设置的,比如mysql, redis,允许远程访问的时候,都需要自己配置的,所以我们也要把rabbitmq设置远程访问功能。
原来我们还少设置了permissions,直接打开网页,切换到admin目录下面,可以看到下面的截图

No access,你可以直接点击用户名,设置一个默认的,也可以用命令设置
命令设置权限方式为:
[root@iZ94mr3pnsgZ rabbitmq]# rabbitmqctl set_permissions -p '/' yueer01 ".*" ".*" ".*"
Setting permissions for user "yueer01" in vhost "/" ...
再截图,就可以发现明显变化了

再次运行脚本,结果完美
[x] Sent 'Hello World!' Process finished with exit code
这时候,你可以在网页的图表中,观察各种数据,整个过程非常清晰。
下面再写一个接受的脚本,还是从官网找个例子,修改一下,代码如下:
# coding:utf-8
import pika username = 'yueer01'
password = 'password'
host = 'your_ip_address' credentials = pika.PlainCredentials(username, password)
connection = pika.BlockingConnection(pika.ConnectionParameters(
host=host, credentials=credentials, port=5672
)) channel = connection.channel()
channel.queue_declare(queue='Hello') def callback(ch, method, properties, body):
print "[x] Received %r" % body channel.basic_consume(callback, queue='hello', no_ack=True) print '[*] Waiting for messages. To exit press CTRL+C'
channel.start_consuming()
运行一下,就可以看到结果了。。
[*] Waiting for messages. To exit press CTRL+C
[x] Received 'Hello World!'
[x] Received 'Hello World!'
我刚才运行了2次publish,所以接受到2个数据包。
至此,rabbitmq的基本应用已经基本完成。以后我们还会讲到怎么在twisted里面接受和发送数据,异步执行rabbitmq,还是蛮有意思的。
centos上安装rabbitmq并且python测试的更多相关文章
- 在Centos上安装RabbitMQ流程(转)
在Centos上安装RabbitMQ流程------------------------ 1. 需求 由于项目中要用到消息队列,经过ActiveMQ与RabbitMQ的比较,最终选择了RabbbitM ...
- CentOS上安装RabbitMQ
所需环境 操作系统:Centos服务一台 网络环境:可以访问公网 安装Erlang RabbitMQ是一个开源的AMQP实现,服务器端用Erlang语言编写,支持多种客户端,如:Python.Ruby ...
- 在CentOS上安装rabbitmq-server
***在 CentOS 6.4上安装python*** 注意啊,自己手动安装python2.7.5,不要动系统上面其他的版本 1,先安装GCC,用如下命令yum install gcc gcc-c++ ...
- 在 CentOS 7上安装并配置 Python 3.6 环境
前言 按照此方法安装保证以下报错什么的统统都没有! 基础环境 系统:centos7.4 软件:python3 Retrying (Retry(total=0, connect=None, read=N ...
- centos上安装python环境
1.安装python-pip 首先安装epel扩展源: yum -y install epel-release 更新完成之后,安装pip: yum -y install python- ...
- centos上安装supervisor来管理dotnetcore等应用程序
supervisor 介绍: 这是一款用python编写的进程管理工具,可以守护他管理的所有进程,防止异常退出,以及提供一个可视化的web界面来手动管理,打开关闭重启各种应用,界面如下: 关于在cen ...
- NoSql1 在Linux(CentOS)上安装memcached及使用
前言: 今天是初五,生活基本要从过年的节奏中回归到正常的生活了,所以想想也该想想与工作有关的事情了.我之前在工作中会经常使用memcached和redis,但是自己一直没有时间系统的好好看 ...
- 在Ubuntu|CentOS上安装Shutter截图工具及快捷键设置
简介 Shutter前身叫GScrot,它是一款相当棒的截图软件. 通过Shutter,你可以截取包括选定区域.全屏幕.窗口.窗口内的控件甚至网页的图像.通过内置的强大插件机制,你可以在截图后,对图像 ...
- CentOS上安装Node.js
CentOS上安装Node.js [日期:2014-07-21] 来源:Linux社区 作者:maskdfe [字体:大 中 小] CentOS上安装Node.js(想在Linux上学习No ...
随机推荐
- 转:fopen与open可以转换吗
绝对不可以.fopen是C运行库级别的函数,而open是system call的wrapper routine.fopen返回FILE *的指针,这个结构本身维护着一些关于这个文件的信息,而open返 ...
- MSSQL显错注入爆数字型数据的一点思考
Title:MSSQL显错注入爆数字型数据的一点思考 --2011-02-22 15:23 MSSQL+ASP 最近在弄个站点,密码是纯数字的,convert(int,())转换出来不报错,也不知道其 ...
- Baidu Map Web API 案例
<html> <head> <meta http-equiv="Content-Type" content="text/html; char ...
- BZOJ1176---[Balkan2007]Mokia (CDQ分治 + 树状数组)
题目链接:http://www.lydsy.com/JudgeOnline/problem.php?id=1176 CDQ第一题,warush了好久.. CDQ分治推荐论文: 1 <从<C ...
- INTELLIJ IDEA集成CHECKSTYLE(转)
转自:http://www.cnblogs.com/kiwi-wang/p/4166410.html 本文中使用intelliJ IDEA版本为14.0.1,其他版本差异不大,可同样安装. 下载安装C ...
- SQL-MICK基础
/*Select语句完整的执行顺序:1.from子句组装来自不同数据源的数据:2.where子句基于指定的条件对记录行进行筛选:3.group by子句将数据划分为多个分组:4.使用聚集函数进行计算: ...
- 怎么给iOS项目打包
1 首先要选中项目中的真机測试,不要模拟器 ,然后从上边的菜单条中找product watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvc29tZXJhaW43 ...
- QT中关于窗口全屏显示与退出全屏的实现
近期在学习QT时遇到了很多问题这也是其中一个,个人通过在各种书籍和网络上的查阅找到了一些关于这方面的答案,希望能给大家一些帮助. 首先,在QT中对于窗口显示常用的有这么几个方法可以调用: Qt全屏显示 ...
- html中编写js的方式
第一种:引用外部的js文件 <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http ...
- Android中的创建型模式总结
共5种,单例模式.工厂方法模式.抽象工厂模式.建造者模式.原型模式 单例模式 定义:确保某一个类的实例只有一个,而且向其他类提供这个实例. 单例模式的使用场景:某个类的创建需要消耗大量资源,new一个 ...