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 ...
随机推荐
- Entity Framework with MySQL 学习笔记一(继承)
基本上sql中要表示继承关系有3中方式. 分别是,1表继承(TPH),2表继承(TPC),3表继承(TPT) 1表 : Person id type name classroom office 1 s ...
- 调整altium designer15的十字光标大小
在左上角的DXP下preferences中调整.首先打开该窗口. 1.原理图:schematic-----graphical editing,此窗口中cursor栏有个cursor type,其下拉菜 ...
- iOS 9之Shared Links Extension(Safari Extensibility)
金田 (github示例源码) 在之前的Blog中有介绍了关于Safari Extensibility的 Content Blocking部分,详情可以看这里 --- iOS 9之Safari广告拦截 ...
- Google Code Jam 2012 round 2 problem A: Swinging Wild
题目连接 题意:你要从起点经过绳子荡到终点,每次你必须抓住另一个绳子,在空中不能向下爬.问是否有合理的方案 做法: 直接模拟 #include <iostream> #include &l ...
- python部落刷题宝学到的内置函数(二)
感觉到刷题宝有一个好处,也许也不是好处,它的答案必须是真正输出的值,也就是说应该输出字符串aaaa的时候,答案必须写成界面上返回的值,即'aaaa'.有利于真正记忆返回值类型,但是....太繁琐了 1 ...
- MySQL慢查询(一) - 开启慢查询
一.简介 开启慢查询日志,可以让MySQL记录下查询超过指定时间的语句,通过定位分析性能的瓶颈,才能更好的优化数据库系统的性能. 二.参数说明 slow_query_log 慢查询开启状态slow_q ...
- IOS设计模式学习(18)模板方法
1 前言 模板方法模式是面向对象软件设计中一种非常简单的设计模式.其基本思想是在抽象类的一个方法定义“标准”算法.在这个方法中调用的基本操作由子类重载予以实现.这个方法成为“模板”.因为方法定义的算法 ...
- XMPP通讯开发-好友获取界面设计
在XMPP通讯开发-服务器连接 中我们成功连接到服务器上面,然后进入到主界面,接下来就是获取好友列表,这里我们分段开发,首先就是界面的设计,这里仿照QQ好友界面,里面的数据先是用模拟的,下一章获取服务 ...
- FZU 1686 神龙的难题(DLX反复覆盖)
FZU 1686 神龙的难题 pid=1686" target="_blank" style="">题目链接 题意:中文题 思路:每个1看成列, ...
- openwrt interface
orige : http://www.cnblogs.com/preorder69/p/3959187.html 这篇算是对openwrt网络接口的一个翻译吧,源地址:http://wiki.open ...