RabbitMQ是实现了高级消息队列协议(AMQP)的开源消息代理软件(亦称面向消息的中间件)。RabbitMQ服务器是用Erlang语言编写的,而群集和故障转移是构建在开放电信平台框架上的。所有主要的编程语言均有与代理接口通讯的客户端库。
下载Erlang和RabbitMQ安装包:rlang-21.1-1.el7.centos.x86_64.rpm
和rpm -ivh rabbitmq-server-3.7.8-1.el7.noarch.rpm。
wget https://zysd-shanghai.oss-cn-shanghai.aliyuncs.com/software/linux/erlang/erlang-21.1-1.el7.centos.x86_64.rpm
wget https://zysd-shanghai.oss-cn-shanghai.aliyuncs.com/software/linux/rabbitmq/rabbitmq-server-3.7.8-1.el7.noarch.rpm
本站rabbitmq以3.7.8版本为例
rpm -ivh erlang-21.1-1.el7.centos.x86_64.rpm
rpm -ivh rabbitmq-server-3.7.8-1.el7.noarch.rpm
cd /usr/lib/rabbitmq/bin 后台启动:./rabbitmq-server start -detached
./rabbitmqctl stop
./rabbitmqctl status
./rabbitmq-plugins enable rabbitmq_management
后台管理访问地址: http://localhost:15672/
默认账号密码都是:guest
./rabbitmqctl add_user 账号 密码 ./rabbitmqctl add_user customer Ewsd@159357
./rabbitmqctl delete_user username
./rabbimqctl change_password username newpassword
./rabbitmqctl set_user_tags customer administrator
./rabbitmqctl set_permissions -p "/" customer ".*" ".*" ".*"
chkconfig rabbitmq-server on
在访问管理界面使用guest用户登录时出现login failed错误。
到服务器上查询日志显示出现错误的原因是:HTTP access denied: user ‘guest’ - User can only log in via localhost。
解决:
rabbitmq从3.3.0开始禁止使用guest/guest权限通过除localhost外的访问。我的是3.6
如果想使用guest/guest通过远程机器访问,需要在rabbitmq配置文件中(找到/rabbitmq_server-3.6.14/ebin下面的rabbit.app文件)中设置loopback_users为[]。
找到/rabbitmq_server-3.6.14/ebin下面的rabbit.app文件文件完整内容如下(注意后面的半角句号):
找到:loopback_users里的<<”guest”>>删除。
[{rabbit, [{loopback_users, []}]}].
然后重启
systemctl restart rabbitmq-server.service
MQTT(消息队列遥测传输)是ISO 标准(ISO/IEC PRF 20922)下基于发布/订阅范式的消息协议。它工作在 TCP/IP协议族上,是为硬件性能低下的远程设备以及网络状况糟糕的情况下而设计的发布/订阅型消息协议,为此,它需要一个消息中间件 。
MQTT是一个基于客户端-服务器的消息发布/订阅传输协议。MQTT协议是轻量、简单、开放和易于实现的,这些特点使它适用范围非常广泛。在很多情况下,包括受限的环境中,如:机器与机器(M2M)通信和物联网(IoT)。其在,通过卫星链路通信传感器、偶尔拨号的医疗设备、智能家居、及一些小型化设备中已广泛使用。
rabbitmq-plugins enable rabbitmq_mqtt
rabbitmq-plugins enable rabbitmq_web_mqtt