RabbitMQ安装遇到的问题(转载)_no package socat available.-程序员宅基地

技术标签: RabbitMQ  

转载 引自:RabbitMQ(二)CentOS6.7 下的 HelloWorld

前一篇写了在Windows下的安装使用,这次记录下CentOS6.7下的安装使用.

其实在CentOS下和Windows下过程是一样的,都是 先安装Erlang环境,再安装RabbitMQ Server.

只不过CentOS下经常遇到各种问题,所以感觉上麻烦点.


版本是 CentOS6.7+RabbitMQ3.6.5,官方文档地址 http://www.rabbitmq.com/install-rpm.html


主要分以下部分

1) 安装Erlang环境

2)安装RabbitMQ Server

3)启动server,并启用管理台插件

4)新增用户并设置权限

5)外网登录管理台

6)代码连接CentOS下的MQ

7)遇到的问题及解决办法



1)安装Erlang环境

官网提供了3种安装方法,我这里用第一种.

按官网指引,来到 https://www.erlang-solutions.com/resources/download.html 页面, 这里可以选择Linux的版本进行对应的下载.

我最开始 选择了centos,然后下载19.1.5这个版本, 然后进行安装发现少一堆包.

最后还是安装网页下发的 说明进行在线安装



首先

[html]  view plain   copy
  print ?
  1. wget https://packages.erlang-solutions.com/erlang-solutions-1.0-1.noarch.rpm  
  2. rpm -Uvh erlang-solutions-1.0-1.noarch.rpm  


这2句一般不会遇到问题,然后

[html]  view plain   copy
  print ? 在CODE上查看代码片 派生到我的代码片
  1. sudo yum install erlang  

遇到问题1

[html]  view plain   copy
  print ? 在CODE上查看代码片 派生到我的代码片
  1. http://packages.erlang-solutions.com/rpm/centos/6/x86_64/repodata/primary.xml.gz: [Errno -1] Metadata file does not match checksum  
  2. Trying other mirror.  
  3. erlang-solutions/primary                                                                                                                                                   | 869 kB     00:00       
  4. http://packages.erlang-solutions.com/rpm/centos/6/x86_64/repodata/primary.xml.gz: [Errno -1] Metadata file does not match checksum  
  5. Trying other mirror.  
  6. Error: failure: repodata/primary.xml.gz from erlang-solutions: [Errno 256] No more mirrors to try.  


解决方法见7)中的问题1.解决后继续


因为网速慢,遇到问题2

[html]  view plain   copy
  print ? 在CODE上查看代码片 派生到我的代码片
  1. [Errno 12] Timeout on  

解决方法见7)中的问题2.解决后继续

Erlang安装完成.



2)安装RabbitMQ Server

需要先下载 rpm文件 , (上面给的官网安装地址 最上面就有下载的地方)

然后执行下面命令

[html]  view plain   copy
  print ? 在CODE上查看代码片 派生到我的代码片
  1. rpm --import https://www.rabbitmq.com/rabbitmq-release-signing-key.asc  
  2. yum install rabbitmq-server-3.6.5-1.noarch.rpm  
注:上面yum命令  要在 下载的rpm文件的目录下进行


遇到问题3

[html]  view plain   copy
  print ? 在CODE上查看代码片 派生到我的代码片
  1. Error: Package: rabbitmq-server-3.6.5-1.noarch (/rabbitmq-server-3.6.5-1.noarch)  
  2.            Requires: socat  


解决方法见7)中的问题3.解决后继续

完成安装


3)启动server,并启用管理台插件

[html]  view plain   copy
  print ? 在CODE上查看代码片 派生到我的代码片
  1. 执行  whereis rabbitmq  
  2. 结果  rabbitmq: /etc/rabbitmq /usr/lib/rabbitmq  
  3. 执行  cd /usr/lib/rabbitmq/bin  
  4. 执行  rabbitmq-server start  

结果如下

[html]  view plain   copy
  print ? 在CODE上查看代码片 派生到我的代码片
  1.             RabbitMQ 3.6.5. Copyright (C) 2007-2016 Pivotal Software, Inc.  
  2. ##  ##      Licensed under the MPL.  See http://www.rabbitmq.com/  
  3. ##  ##  
  4. ##########  Logs: /var/log/rabbitmq/[email protected]  
  5. ######  ##        /var/log/rabbitmq/[email protected]  
  6. ##########  
  7.             Starting broker...  
  8. ompleted with 0 plugins.  


可以看到默认没有插件,然后我们去启动管理台的插件

[html]  view plain   copy
  print ? 在CODE上查看代码片 派生到我的代码片
  1. [root@localhost bin]# rabbitmq-plugins enable rabbitmq_management  
  2. The following plugins have been enabled:  
  3.   mochiweb  
  4.   webmachine  
  5.   rabbitmq_web_dispatch  
  6.   amqp_client  
  7.   rabbitmq_management_agent  
  8.   rabbitmq_management  
  9.   
  10. Applying plugin configuration to rabbit@localhost... failed.  
  11.  * Could not contact node rabbit@localhost.  
  12.    Changes will take effect at broker restart.  
  13.  * Options: --online  - fail if broker cannot be contacted.  
  14.             --offline - do not try to contact broker.  


这里出现了 contact node rabbit@localhost 的提示,但是当时没注意,就继续往下了

执行启动命令. 启动完成

整体如下图


启动完成.



4)新增用户并设置权限

因为假想中这是服务器,我们平时访问肯定都是在外网,所以默认的guest只能在本机使用肯定不行了.(官方推荐删掉guest或者修改密码)

所以我们需要新增一个可以外网访问的用户.

可以在页面新增(更简单一点),也可以用命令新增. 我们这里用命令

[html]  view plain   copy
  print ? 在CODE上查看代码片 派生到我的代码片
  1. rabbitmqctl  add_user  admin  123456  


遇到问题4,和启动插件时候有点类似 Error: unable to connect to node rabbit@localhost: nodedown



解决方法见7)中的问题4.解决后继续

[html]  view plain   copy
  print ? 在CODE上查看代码片 派生到我的代码片
  1. rabbitmqctl set_user_tags admin administrator  
  2. rabbitmqctl set_permissions -p "/" admin ".*" ".*" ".*"  

上面2句分别是设置角色(非官方说法),设置外网登录权限

OK.新增用户授权完成.


5)外网登录管理台

在本地浏览器输入CentOS的管理台地址 http://192.168.1.100:15672/

这里要注意下centos的防火墙状态,我测试就直接把防火墙关了

[html]  view plain   copy
  print ? 在CODE上查看代码片 派生到我的代码片
  1. 关闭防火墙  
  2. /etc/init.d/iptables stop  

使用刚才创建的admin登录后,如下图



如果登录失败,返回状态是401的话,就是权限设置的有问题.



6)代码连接CentOS下的MQ

代码和上一篇Windows下的基本一样,只是需要指定下IP,用户名,密码

[java]  view plain   copy
  print ? 在CODE上查看代码片 派生到我的代码片
  1. import com.rabbitmq.client.Channel;  
  2. import com.rabbitmq.client.Connection;  
  3. import com.rabbitmq.client.ConnectionFactory;  
  4.   
  5.   
  6. public class Send {  
  7.   private final static String QUEUE_NAME = "hello";  
  8.   
  9.   
  10.   public static void main(String[] argv) throws Exception {  
  11.     ConnectionFactory factory = new ConnectionFactory();  
  12.     factory.setHost("192.168.1.100");  
  13.     factory.setUsername("admin");  
  14.     factory.setPassword("123456");  
  15.     Connection connection = factory.newConnection();  
  16.     Channel channel = connection.createChannel();  
  17.   
  18.   
  19.     channel.queueDeclare(QUEUE_NAME, falsefalsefalsenull);  
  20.     String message = "Hello World!";  
  21.     channel.basicPublish("", QUEUE_NAME, null, message.getBytes("UTF-8"));  
  22.     System.out.println(" [x] Sent '" + message + "'");  
  23.   
  24.   
  25.     channel.close();  
  26.     connection.close();  
  27.   }  
  28. }  


[java]  view plain   copy
  print ? 在CODE上查看代码片 派生到我的代码片
  1.   

接收的类也一样

[java]  view plain   copy
  print ? 在CODE上查看代码片 派生到我的代码片
  1. import com.rabbitmq.client.*;  
  2.   
  3.   
  4. import java.io.IOException;  
  5.   
  6.   
  7. public class Recv {  
  8.   
  9.   private final static String QUEUE_NAME = "hello";  
  10.   
  11.   public static void main(String[] argv) throws Exception {  
  12.     ConnectionFactory factory = new ConnectionFactory();  
  13.     factory.setHost("192.168.1.100");  
  14.     factory.setUsername("admin");  
  15.     factory.setPassword("123456");  
  16.     Connection connection = factory.newConnection();  
  17.     Channel channel = connection.createChannel();  
  18.   
  19.     channel.queueDeclare(QUEUE_NAME, falsefalsefalsenull);  
  20.     System.out.println(" [*] Waiting for messages. To exit press CTRL+C");  
  21.   
  22.     Consumer consumer = new DefaultConsumer(channel) {  
  23.       @Override  
  24.       public void handleDelivery(String consumerTag, Envelope envelope, AMQP.BasicProperties properties, byte[] body)  
  25.           throws IOException {  
  26.           System.out.println("consumerTag"+consumerTag);  
  27.           System.out.println("properties"+properties.getMessageId());  
  28.         String message = new String(body, "UTF-8");  
  29.         System.out.println(" [x] Received '" + message + "'");  
  30.       }  
  31.     };  
  32.     channel.basicConsume(QUEUE_NAME, true, consumer);  
  33.   }  
  34. }  


端口号因为是默认的,指定不指定无所谓了.

运行代码,成功执行.






7)遇到的问题及解决办法


问题1

[html]  view plain   copy
  print ? 在CODE上查看代码片 派生到我的代码片
  1. http://packages.erlang-solutions.com/rpm/centos/6/x86_64/repodata/primary.xml.gz: [Errno -1] Metadata file does not match checksum  
  2. Trying other mirror.  


解决1

先安装网上的  yum clean all 发现没解决.

继续深入

[html]  view plain   copy
  print ? 在CODE上查看代码片 派生到我的代码片
  1. wget --no-cache http://packages.erlang-solutions.com/rpm/centos/6/x86_64/repodata/primary.xml.gz  
  2. sha1sum primary.xml.gz  
  3.   
  4. 得到下面的  
  5. 1572f7949d751054a14e0b24ea3f2592633d06c4  primary.xml.gz  


然后找到本地的

[html]  view plain   copy
  print ? 在CODE上查看代码片 派生到我的代码片
  1. cd /var/cache/yum/x86_64/6/erlang-solutions  
  2. vim repomd.xml  


发现里面的数值和我们计算的不一致,则修改成上面计算的.(下面是我修改后的)

[html]  view plain   copy
  print ? 在CODE上查看代码片 派生到我的代码片
  1. <data type="primary">  
  2.   <location href="repodata/primary.xml.gz"/>  
  3.   <checksum type="sha">1572f7949d751054a14e0b24ea3f2592633d06c4</checksum>  
  4.   <timestamp>1478542719</timestamp>  
  5.   <open-checksum type="sha">61989f5a64efd4daecd0d719457a47a2290b7126</open-checksum>  
  6. </data>  

保存,退出.继续执行 sudo yum install erlang, 我这还有个这种提示,但是继续往下运行了. 问题解决

参考 http://tilt.lib.tsinghua.edu.cn/node/385

搞定!


问题2

[html]  view plain   copy
  print ? 在CODE上查看代码片 派生到我的代码片
  1. [Errno 12] Timeout on  


解决2

[html]  view plain   copy
  print ? 在CODE上查看代码片 派生到我的代码片
  1. vim /etc/yum.conf     
设置超时时间 加上 timeout=1200
网速慢可以设置更长点.
搞定!

问题3

[html]  view plain   copy
  print ? 在CODE上查看代码片 派生到我的代码片
  1. Error: Package: rabbitmq-server-3.6.5-1.noarch (/rabbitmq-server-3.6.5-1.noarch)  
  2.            Requires: socat  


解决3
看提示就是需要socat的包,
去下载socat
[html]  view plain   copy
  print ? 在CODE上查看代码片 派生到我的代码片
  1. yum install socat  

结果出现
[html]  view plain   copy
  print ? 在CODE上查看代码片 派生到我的代码片
  1. Loaded plugins: fastestmirror, refresh-packagekit, security  
  2. Setting up Install Process  
  3. Loading mirror speeds from cached hostfile  
  4.  * base: mirrors.btte.net  
  5.  * extras: mirrors.btte.net  
  6.  * updates: mirror.bit.edu.cn  
  7. No package socat available.  
  8. Error: Nothing to do  

继续解决,更新源
[html]  view plain   copy
  print ? 在CODE上查看代码片 派生到我的代码片
  1. wget --no-cache http://www.convirture.com/repos/definitions/rhel/6.x/convirt.repo -O /etc/yum.repos.d/convirt.repo  
  2. yum install socat  
  3. yum install rabbitmq-server-3.6.5-1.noarch.rpm  

搞定!


问题4
[html]  view plain   copy
  print ? 在CODE上查看代码片 派生到我的代码片
  1. Error: unable to connect to node rabbit@localhost: nodedown  

解决4
这个问题官网也提到过,说是cookie不一致之类的问题.
网上搜了好多,其实在我们 开启管理台插件的时候,就已经看到提示了. 那就是重启解决.
最后执行
[html]  view plain   copy
  print ? 在CODE上查看代码片 派生到我的代码片
  1. service rabbitmq-server restart  
然后再执行命令, 果然OK.

搞定!


总结下.在centos下安装,不同的机器可能遇到不同的问题.我安装了3次就分别遇到不同的问题.都记录在里面了.
一般通过网上搜索都可以解决!

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/alex_bean/article/details/56675694

智能推荐

java毕业设计球馆预约管理系统mybatis+源码+调试部署+系统+数据库+lw-程序员宅基地

文章浏览阅读446次。java毕业设计球馆预约管理系统mybatis+源码+调试部署+系统+数据库+lw。JSP基于JAVA的邮件过滤系统的设计与实现sqlserver。springboot基于SpringBoot的自助旅游导航系统。ssh基于java的网上手机销售管理系统的开发与实现mysql。jsp本科生实习管理系统的设计与实现sqlserver。JSP酒店餐饮管理系统的设计与实现sqlserver。JSP宠物食品店系统的设计与实现sqlserver。基于SSM框架的校园爱心公益平台的设计与实现。

iOS应用沙盒机制浅析_inhouse app sandbox-程序员宅基地

文章浏览阅读1.9k次。iOS应用程序只能在为该程序创建的文件系统中读取文件,不可以去其他地方访问,此区域被称为沙盒。所有的非代码文件都要保存在此,例如图像,图标,声音,属性列表(plist文件),文本文件等。沙盒机制作为一种安全体系,核心内容是:沙盒对应用程序执行各种操作的权限限制。(1)每个应用程序都有自己的存储空间;(2)应用程序不能翻过自己的围墙去访问别的存储空间的内容;(3)应用程序请求的数据都要通_inhouse app sandbox

eclipse 连接 mysql-程序员宅基地

文章浏览阅读4.5k次,点赞4次,收藏33次。连接时报错:Loading class `com.mysql.jdbc.Driver'. This is deprecated. The new driver class is `com.mysql.cj.jdbc.Driver'. The driver is automatically registered via the SPI and manual loading of the dri...

目标检测数据集:摄像头镜头缺陷检测数据集_摄像头遮挡检测数据集-程序员宅基地

文章浏览阅读746次。摄像头镜头缺陷数据集用于缺陷检测项目_摄像头遮挡检测数据集

JS+ES6新增字符串操作方法大汇总,共四十七种方法_js es6 字符串填充-程序员宅基地

文章浏览阅读2.2k次,点赞69次,收藏4次。让我为大家介绍一下字符串的操作方法吧,你知道与不知道的大部分都在这!_js es6 字符串填充

多线程实现多客户端通信_用多线程模拟多个客户端吗-程序员宅基地

文章浏览阅读731次。在Java Socket(下)中写了服务器端和客户端进行通信的例子,但是在实际应用当中,不是这样的一对一通信,通常都是一台服务器,对应着很多很多客户端进行通信,可以通过多线程来实现多客户端与服务器端进行通信。 (注:只是根据所学知识点写一个小例子,线程安全暂未考虑进去)首先是Server端的代码段:import java.io.IOException;import java.net.InetAd_用多线程模拟多个客户端吗

随便推点

pycharm中import caffe/caffe2-程序员宅基地

文章浏览阅读1.1w次。pycharm中import caffe/caffe2_import caffe

[AIGC] ComfyUI 节点解释_comfyui节点介绍-程序员宅基地

文章浏览阅读1.4k次,点赞2次,收藏4次。我们如何了解实际发生的情况以便我们可以创建和修改工作流程?要了解节点,我们必须了解一些稳定扩散的工作原理。让我们看一下默认的工作流程。如果您没有使用默认工作流程,或者您一直在搞乱界面,请单击右侧边栏上的“Load Default”。_comfyui节点介绍

C/C++:计算N的N次方的个位数(巧用快速幂与模运算性质)_用c++计算n的n次方-程序员宅基地

文章浏览阅读3k次,点赞6次,收藏18次。题目描述(源自杭电OJ):相关数学知识一:取模运算的性质a乘b的结果对p取模等于a对p取模的结果乘b对p取模的结果再整体取模于p,详见下图证明过程如下:相关数学知识二:快速幂运算 以求a的b次方为例,由于要乘b次a,此时的时间复杂度为O(b);如果要求a的的平方的b/2次,只需要乘b/2次(如果b是奇数,要再乘一个a),时间复杂度减半,以此类推,直到b=1时,此时的时间复杂度变成了log以2位到的b的对数,运算次数实现了最小化,时间复杂度为O(log以2为..._用c++计算n的n次方

(附源码)springboot+mysql+基于JAVA的学员代言人评选投票系统设计与实现 毕业设计161825_基于springboot的在线投票系统的源码有5000字代码吗-程序员宅基地

文章浏览阅读67次。学员代言人评选投票系统主要功能模块包括管理员、首页、站点管理(轮播图、公告栏)用户管理(管理员、普通用户、企业用户)内容管理(投票资讯、资讯分类)更多管理(主题类别、投票信息、用户投票、投票结果)采取面对对象的开发模式进行软件的开发和硬体的架设,能很好的满足实际使用的需求,完善了对应的软体架设以及程序编码的工作,采取MySQL作为后台数据的主要存储单元,采用java技术、Ajax技术进行业务系统的编码及其开发,实现了本系统的全部功能。_基于springboot的在线投票系统的源码有5000字代码吗

【AI绘画】Stablediffusion必不可少的使用方法之关键词(2)_stablediffusion添加关键词-程序员宅基地

文章浏览阅读803次,点赞21次,收藏14次。我相信很多已经下载好Stablediffusion或者midjourney软件的朋友,第一反应都是看着满屏看不懂的各种选项发懵吧,而当你稳住心神,准备在文生图或者图生图这两块基础操作力大显身手,想创造出属于自己的艺术设计之时,难免会对着下面这个框框陷入两难:我应该填什么呢?我应该如何描述呢?_stablediffusion添加关键词

服务器文档检索,知识库文档快速检索方法、应用服务器计算机可读存储介专利_专利查询 - 天眼查...-程序员宅基地

文章浏览阅读243次。1. 一种知识库文档快速检索方法,应用于应用服务器,其特征在于,所述方法包括步 骤: 接收用户输入的检索信息; 对所述检索信息进行分析、处理以获取查询词; 根据所述查询词对知识库中的文档进行搜索,并根据搜索匹配度对搜索结果进行排 序; 通过摘要生成模型及关键词生成模型获得各文档的摘要及关键词;及 输出排序后的搜索结果,并对应输出目标文档的所述摘要及关键词。2. 如权利要求1所述的知识库文档快速检索..._产品知识库快速查询

推荐文章

热门文章

相关标签