把我的阿里云重置了一下,重新安装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测试的更多相关文章

  1. 在Centos上安装RabbitMQ流程(转)

    在Centos上安装RabbitMQ流程------------------------ 1. 需求 由于项目中要用到消息队列,经过ActiveMQ与RabbitMQ的比较,最终选择了RabbbitM ...

  2. CentOS上安装RabbitMQ

    所需环境 操作系统:Centos服务一台 网络环境:可以访问公网 安装Erlang RabbitMQ是一个开源的AMQP实现,服务器端用Erlang语言编写,支持多种客户端,如:Python.Ruby ...

  3. 在CentOS上安装rabbitmq-server

    ***在 CentOS 6.4上安装python*** 注意啊,自己手动安装python2.7.5,不要动系统上面其他的版本 1,先安装GCC,用如下命令yum install gcc gcc-c++ ...

  4. 在 CentOS 7上安装并配置 Python 3.6 环境

    前言 按照此方法安装保证以下报错什么的统统都没有! 基础环境 系统:centos7.4 软件:python3 Retrying (Retry(total=0, connect=None, read=N ...

  5. centos上安装python环境

    1.安装python-pip ​ 首先安装epel扩展源: ​ yum -y install epel-release ​ 更新完成之后,安装pip: ​ yum -y install python- ...

  6. centos上安装supervisor来管理dotnetcore等应用程序

    supervisor 介绍: 这是一款用python编写的进程管理工具,可以守护他管理的所有进程,防止异常退出,以及提供一个可视化的web界面来手动管理,打开关闭重启各种应用,界面如下: 关于在cen ...

  7. NoSql1 在Linux(CentOS)上安装memcached及使用

    前言:       今天是初五,生活基本要从过年的节奏中回归到正常的生活了,所以想想也该想想与工作有关的事情了.我之前在工作中会经常使用memcached和redis,但是自己一直没有时间系统的好好看 ...

  8. 在Ubuntu|CentOS上安装Shutter截图工具及快捷键设置

    简介 Shutter前身叫GScrot,它是一款相当棒的截图软件. 通过Shutter,你可以截取包括选定区域.全屏幕.窗口.窗口内的控件甚至网页的图像.通过内置的强大插件机制,你可以在截图后,对图像 ...

  9. CentOS上安装Node.js

    CentOS上安装Node.js [日期:2014-07-21] 来源:Linux社区  作者:maskdfe [字体:大 中 小]     CentOS上安装Node.js(想在Linux上学习No ...

随机推荐

  1. ural 1353. Milliard Vasya's Function

    http://acm.timus.ru/problem.aspx?space=1&num=1353 #include <cstdio> #include <cstring&g ...

  2. easyUI treeGrid 的小例子

    今天由于业务的需要,于是采用了easyui的的treeGrid控件. <table title="Folder Browser" class="easyui-tre ...

  3. vmware-vdiskmanager

    vmware workstation可以用自带的程序vmware-vdiskmanager分成多个2G大小的文件. vmware-vdiskmanager -r Mavericks.vmdk -t 1 ...

  4. 【转】[c/c++ ]字节序与大小端转换--不错

    原文网址:http://blog.csdn.net/kuai0705/article/details/20841133 注明: 以下内容均为学习内容整理,记录,便于自己学习,并非完全意义上的自产,如有 ...

  5. HDU5141--LIS again (LIS变形)

    题意一个序列的LIS为MAX, 求连续子序列的LIS为MAX的个数. 先求出LIS,记录以a[i]结尾的LIS的长度,以及LIS起始位置(靠右的起始位置). 然后线性扫一遍,,线段树与树状数组的差距还 ...

  6. java--字节数组输入、输出流

    在java网络编程中,字节数组很重要,它可以传输任何资料(文本,音频,视频,图片等),因此掌握字节数组和其它数据类型的相互转化尤为重要. 示例代码: package com.lky.util; imp ...

  7. Thinking In Web [原创作品]

    (转载请注明:http://zhutty.cnblogs.com, 交流请加群:164858883) 可能在大部分人来讲,前端就是可见的页面数据呈现正确就行.然而这样是不正确的,页面呈现是一部分,更多 ...

  8. fetch策略

    @OneToMany(mappedBy="image",cascade=CascadeType.ALL,fetch=FetchType.EAGER) @Fetch(value=Fe ...

  9. JAVA程序猿怎么才干高速查找到学习资料?

    JAVA程序猿怎么才干高速查找到学习资料? JAVA学习资料在互联网上较为零散,并且大多是英文的.以下介绍3种方式,让程序猿能够高速地找到自己想要的资料. 一.导航站点: 有非常多类似hao123的站 ...

  10. cocos2d-x 3.0 画图节点——Node

    ***************************************转载请注明出处:http://blog.csdn.net/lttree************************** ...