自己鼓捣了一晚上总算整明白了,有几个坑分享给小伙伴,希望能帮到你

前期准备 安装erlang

下载rpm包地址:https://github.com/rabbitmq/erlang-rpm (注意erlang版本 我下的rabbitmq版本是3.74需要erlang版本>=19.3) 

百度链接:https://pan.baidu.com/s/1KXeDKliMtOo0EHVgfKc1nA 密码:icnf

遇到了点坑:之前是yum和源码便宜安装erlang都失败导致在安装上面的rpm包时一直不成功,可以执行rpm -qa | grep erlang来查看安装了哪些包,然后执行yum remove 包名卸载即可

1.安装rabbitmq-server 服务篇

下载rabbitmq rpm包地址:http://www.rabbitmq.com/download.html 百度盘链接:https://pan.baidu.com/s/1Q6KKSuBmEW-fPz1-BvCD4w 密码:m1dy

根据你自己的情况,选择版本下载

开始安装

yum install rabbitmq-server-3.7.-.el7.noarch.rpm

进入安装目录

./rabbitmq-server #即可开启服务

#有些时候会报这样的错误ERROR: node with name "rabbit" already running
ps -aux | grep erl
kill掉rabbitmq相关进程就好了
#开启远程访问 执行
./rabbitmq-plugins enable rabbitmq_management

开启守护进程链接:http://www.fidding.me/article/67

2.安装rabbitmq-c

要安装amqp之前需要先安装rabbitmq-c扩展

下载地址:https://github.com/alanxz/rabbitmq-c/releases 百度盘链接:https://pan.baidu.com/s/1znRBtJydza93Ms4Kg2sRFQ 密码:f60y

tar -zxvf rabbitmq-c-0.8..tar.gz
cd rabbitmq-c-0.8.

#这一步是在rabbitmq-c的根目录下创建一个build子目录
mkdir build && cd build # 这一步是让cmake根据../CMakeList.txt,即rabbitmq-c的根目录下的CMakeList.txt创建Makefile文件
# Makefile文件会被创建到build目录中
cmake -DCMAKE_INSTALL_PREFIX=/usr/local/rabbitmq-c .. # 这一步是真正的build rabbitmq-c库的,注意,不要漏掉点 '.'
cmake --build . --target install 如果找不到cmake命令 就先安装cmake
yum install camke

到这里就已经安装完成了。不过这里有一个坑。你可以看一下/usr/local/rabbitmq-c下的目录只有includelib64。因为后面编译安装amqp扩展的时候系统会到/usr/local/rabbitmq-c/lib目录下搜索依赖库,导致错误。所以这里需要加一步:(这里引用了https://segmentfault.com/a/1190000012348103)

ln -s lib64 lib

3.安装amqp扩展

去pecl下载amqp包 地址:http://pecl.php.net/package/amqp 百度盘链接:https://pan.baidu.com/s/1A7KDZ42lONFzaTFyCskxaQ 密码:sz9z

解压进入目录

没有configure文件 需要先执行

phpize(没有全局 就写绝对路径)

./configure --with-php-config=/usr/local/php/bin/php-config --with-amqp --with-librabbitmq-dir=/usr/local/rabbitmq-c
make && make install

修改php.ini文件

vi /usr/local/php/etc/php.ini
添加 extension=amqp.so

遇到的坑:

1.

rabbitmq从3.3.0开始禁止使用guest/guest权限通过除localhost外的访问

解决办法:

如果想使用guest/guest通过远程机器访问,需要在rabbitmq配置文件中(找到/rabbitmq_server-3.6.14/ebin下面的rabbit.app文件)中设置 

{loopback_users, [<<"guest">>]},
改为
{loopback_users, []},

然后重启 
systemctl restart rabbitmq-server

2. 启动服务时可能会报这样的错误

# /sbin/systemctl start rabbitmq-server
Starting rabbitmq-server (via systemctl): Job for rabbitmq-server.service failed because the control process exited with error code. See "systemctl status rabbitmq-server.service" and "journalctl -xe" for details.

解决办法:参考地址http://stackoverflow.com/questions/8633882/rabbitmq-on-ubuntu-10-04-server

# vi /etc/rabbitmq/rabbitmq-env.conf  

NODENAME=rabbit@localhost 

rabbitmq默认是没有rabbitmq.config(参考http://www.rabbitmq.com/configure.html#config-items) 和 rabbitmq-env.conf(参考http://www.rabbitmq.com/configure.html#define-environment-variables)文件的 需要自行创建

centos7 安装rabbitmq rabbitmq-c以及amqp扩展 详细篇的更多相关文章

  1. Centos7 安装 erlang rabbitmq

    1.安装Erlang依赖采用官网的rpm包的形式进行安装,不采用yum(由系统进行自动安装 可能因为版本低的问题而出现一系列问题) erlang依赖 rpm包下载地址https://github.co ...

  2. Centos7 安装配置 Rabbitmq Cluster

    Rabbitmq介绍 RabbitMQ是由 LShift 提供的一个 Advanced Message Queuing Protocol (AMQP) 的开源实现,由以高性能.健壮以及可伸缩性出名的 ...

  3. Centos7安装部署Rabbitmq教程

    依赖关系: 版本依赖一定要提前看清楚. RabbitMQ相关版本依赖关系查看 https://www.rabbitmq.com/which-erlang.html 可以看到要求版本Erlang21.3 ...

  4. centos7 安装erlang rabbitMQ

    环境: 虚拟机 centos7 minimal 一.安装Erlang 1.安装依赖 yum install build-essential openssl openssl-devel unixODBC ...

  5. CentOS7安装搭建.Net Core 2.0环境-详细步骤

    一.构建.Net core 2的应用程web发布 因为是用来测试centos上的core 环境,先直接用vs17自带的core实例. 二.部署CentOS7的core环境 1.连接并启动之前安装的虚拟 ...

  6. centos7.6编译安装php7.2.11及redis/memcached/rabbitmq/openssl/curl等常见扩展

    centos7.6编译安装php7..11及redis/memcached/rabbitmq/openssl/curl等常见扩展 获取Php的编译参数方法: [root@eus-api-cms-bac ...

  7. (五)RabbitMQ消息队列-安装amqp扩展并订阅/发布Demo(PHP版)

    原文:(五)RabbitMQ消息队列-安装amqp扩展并订阅/发布Demo(PHP版) 本文将介绍在PHP中如何使用RabbitMQ来实现消息的订阅和发布.我使用的系统依然是Centos7,为了方便, ...

  8. Centos7 手动编译 RabbitMQ ,并安装php amqp

    RabbitMQ是一个在AMQP基础上完成的,可复用的企业消息系统,底层基于Erlang语言. 一:centos7安装RabbitMQ 这玩意儿安装很扯淡,官方推荐rpm安装,rpm安装本身是最简单的 ...

  9. php的amqp扩展 安装(windows) rabbitmq学习篇

    因为RabbitMQ是由erlang语言实现的,所以先要安装erlang环境erlang 下载安装 http://www.erlang.org/download.htmlrabbitmq 下载安装 h ...

随机推荐

  1. socket连接 代码

    dispatch_sync(dispatch_get_global_queue(, ), ^{ // 处理耗时操作的代码块... // 创建socket /* 1.AF_INET: ipv4 执行ip ...

  2. NOI2012 D2T1扩展欧几里得

    #include <bits/stdc++.h> using namespace std; #define ll long long ll extgcd(ll a,ll b,ll & ...

  3. python入门之lambda表达式、内置函数

    lambda 简单的函数就可以用lambda表达式 格式: abc = lambda a1,a2:a1+a2 其中,传参是a1和a2,返回值是a1+a2 内置函数 abs(a) #取绝对值 all(a ...

  4. python regex

    re.match: match from the beginning of the string re.search: scan through the whole string to find a ...

  5. Spark Mllib里如何将数值特征字段用StandardScaler进行标准化(图文详解)

    不多说,直接上干货! 首先,要明白为什么有时候,数值特征字段需要进行标准化? 答:因为,当我们若用回归分析算法时,必须将数值特征字段进行标准化,这是因为数值特征字段单位不同,数字差异很大,所以无法彼此 ...

  6. linux下php以fastcgi模式运行

    关于PHP以fastcgi方式运行的文章,网络上较多,也许由于转载的原因,有些地方不甚明了,笔者亲自测试,整理成文,供大家参考. 1.linux系统 [root@localhost /]# cat / ...

  7. 单线程单元(STA)线程都应使用泵式等待基元

    CLR 无法从 COM 上下文 0x20ad98 转换为 COM 上下文 0x20af08,这种状态已持续 60 秒.拥有目标上下文/单元的线程很有可能执行的是非泵式等待或者在不发送 Windows ...

  8. kafka基础五

    Kafka与Zookeeper Zookeeper存储了什么 kafka架构中角色: 1.producer: 消息生产者,发布消息到 kafka 集群的终端或服务. 2.broker: kafka 集 ...

  9. Django框架和前端的的基本结合

    1 昨日回顾 a socket b 路由关系 c 模板字符串替换(模板语言) 主流web框架总结: django a用别人的 b自己写的 c自己写的 flask a用别人的 b自己写的 c用别人的(j ...

  10. CString的GetBuffer和ReleaseBuffer

    GetBuffer()主要作用是将字符串的缓冲区长度锁定,releaseBuffer则是解除锁定,使得CString对象在以后的代码中继续可以实现长度自适应增长的功能. CString ::GetBu ...