RabbitMQ是一套开源的消息队列服务软件,是由LShift提供的一个Advanced Message Queuing Protcol(AMQP)的开源实现,由于高性能、健壮以及可sheng
1)每个节点都安装erlang
```
yum install -y erlang
````
2)每个节点都安装RabbitMQ
```
yum -y install rabbitmq-server
```
3)每个节点都启动rabbitmq及设置开机启动
```
systemctl enable rabbitmq-server.service
systemctl restart rabbitmq-server.service
systemctl status rabbitmq-server.service
systemctl list-unit-files | grep rabbitmq-server.service
```
4)创建openstack,注意将yjscloud替换为自己的合适密码
```
rabbitmqctl add_user openstack yjscloud #新增用户、设置密码
```
5)将openstack用户赋予权限
```
rabbitmqctl set_permissions openstack ".*" ".*" ".*"
rabbitmqctl set_user_tags openstack administrator
rabbitmqctl list_users
```
6)看下监听端口 rabbitmq用的是5672端口
```
netstat -ntlp | grep 5672
```
7)查看RabbitMQ插件
```
/usr/lib/rabbitmq/bin/rabbitmq-plugins list
```
8)每个节点都打开RabbitMQ相关插件
```
/usr/lib/rabbitmq/bin/rabbitmq-plugins enable rabbitmq_management mochiweb webmachine rabbitmq_web_dispath amqp_client rabbitmq_management_agent
systemctl restart rabbitmq-server
```
9)查看rabbitmq状态
浏览器输入192.168.0.150:15672 用户口令密码是 openstank/yjscloud登陆之后查看整个管理页面,可以看到节点上rabbitmq的运行状态和负载有关情况
![8-1-10](http://pded8ke3e.bkt.clouddn.com/8-1-10.jpg)
10)RabbitMQ集群配置
```
cat /var/lib/rabbitmq/.erlang.cookie # 到每个节点查看cookie
```
在controller1上操作:
```
scp /var/lib/rabbitmq/.erlang.cookie controller2:/var/lib/rabbitmq/.erlang.cookie
scp /var/lib/rabbitmq/.erlang.cookie controller3:/var/lib/rabbitmq/.erlang.cookie
```
在controller2上操作:
```
systemctl restart rabbitmq-server
rabbitmqctl stop_app
rabbitmqctl join_cluster --ram rabbit@controller1
rabbitmqctl start_app
```
在controller3上操作:
```
systemctl restart rabbitmq-server
rabbitmqctl stop_app
rabbitmqctl join_cluster --ram rabbit@controller1
rabbitmqctl start_app
```
11)验证效果
(1)通过此命令去查看集群中的所有节点
```
rabbitmqctl cluster_status
```
![8-1-11](http://pded8ke3e.bkt.clouddn.com/8-1-11.jpg)
(2)通过浏览器访问10.1.1.150:15672、10.1.1.151:15672、10.1.1.152:15672
![8-1-12](http://pded8ke3e.bkt.clouddn.com/8-1-12.jpg)
12)集群管理
如果遇到rabbitmq脑裂情况,按以下步骤操作,重新设置集群:
登录没有加入集群的节点:
```
rabbitmqctl stop_app
rabbitmqctl restart
rabbitmqctl start_app
```
登录以一个节点:
```
rabbitmqctl forget_cluster_node rabbit@controller1
rabbitmqctl forget_cluster_node rabbit@controller2
```
最后再重新执行添加集群操作即可!
如果某个节点下面路径/var/lib/rabbitmq有多余的文件,请全部删除掉!
13)RabbitMQ优化
RabbitMQ一般优化的地方比较少,对rabbitmq的优化总结了下面几点:
(1)尽可能的把RabbitMQ部署在单独的服务器中,因为使用专用节点,RabbitMQ服务能尽全部的享受cpu资源,这样性能更高。
(2)让RabbitMQ跑在HiPE模式下
RabbitMQ是用Erlang语言编写的,而开发HiPE能让Erlang预编译运行,这样性能可以提升30%以上。但是开启HiPE模式会让RabbitMQ第一次启动很慢,大概需要2分钟;另外就是如果启用了HiPE,RabbitMQ的调试可能变得很难,因为HiPE可以破坏回溯,使它们不可读。
enable HiPE方法:`vim /etc/rabbitmq/rabbitmq.config` 去掉`(hipe_compile,ture)` 前面注析即可,然后重启rabbitmq服务(重启的过程中,你会发现启动过程很慢)
```
scp -p /etc/rabbitmq/rabbitmq.configcontroller2:/etc/rabbitmq/rabbitmq.config
scp -p /etc/rabbitmq/rabbitmq.configcontroller3:/etc/rabbitmq/rabbitmq.config
```
(3)不要对RP队列使用队列镜像
研究表明,在3节点集群上启用队列镜像会使消息吞吐量下降两倍。另一方面,RPC消息变短丢失,它只导致当前正在进行的操作失败,因此没有镜像的整体RPC队列似乎是一个很好的权衡。不过也是所有的消息队列都不启用镜像,Ceilometer队列可以启用队列镜像,因此Ceilometer的消息必须保留;但是如果你的环境装了Ceilometer组件,最好是给Ceilometer单独一个rabbitmq集群,因为在通常情况下,Ceilometer不会产生大量的消息队列,但是,如果Ceilometer卡住有问题,那么关于Ceilometer的队列就会很多溢出,这会造成RabbitMQ集群的奔溃,这样必然导致其他的openstack服务中断。
(4)减少发送的指标数量或者频率
在openstack环境下运行RabbitMQ的另一个最佳实践是减少发送的指标数量和/或其频率。减少了相关指标数量和/或其频率,也自然减少了消息在RabbitMQ服务中堆积的机会,这样RabbitMQ就可以把更多的资源用来处理更重要的openstack服务队列,以间接的提高rabbitmq性能。一般Ceilometer和MondoDB的消息队列可以尽量的挪开。
(5)增加rabbitmq socket最大打开数
`vim /etc/sysctl.conf `最下面添加:`fs.file-max = 1000000`
`sysctl -p` 执行生效
设置ulimit最大打开数
`vim /etc/security/limits.conf`
添加:
```
* soft nofile 655350
* hard nofile 655350
```
设置systemctl管理的服务文件最大打开数为1024000
```
vim /etc/systemd/system.conf
```
添加:
```
DefaultLimitNOFILE=1024000
DefaultLimitNPROC=1024000
```
修改后服务器都重启下,重启完毕查看值是否更好,运行ulimit -Hn查看
修改后,登录rabbitmq web插件可以看到最大文件打开数和socket数都变大了,默认值是最大文件数是1024和socket数是829
- 献给我的朋友们
- 一、个人对学习的看法
- 二、运维技能图谱
- 三、运维常用技能
- 3.1 Vim(最好用的编辑器)
- 3.2 Nginx & Tengine(Web服务)
- 1. Nginx介绍和部署
- 2. Nginx配置解析
- 3. Nginx常用模块
- 4. Nginx 的session 一致性问题
- 3.3 Tomcat(Web中间件)
- 3.4 Keepalived(负载均衡高可用)
- 3.5 Memcache(分布式缓存)
- 3.6 Zookeeper(分布式协调系统)
- 3.7 KVM(开源虚拟化)
- 1. 虚拟化介绍
- 2. KVM基础
- 3. 设置VNC和时间同步
- 4. kvm虚拟机快照备份
- 5. kvm虚拟机在线扩展磁盘
- 6. kvm虚拟机静态迁移
- 7. kvm虚拟机动态迁移
- 8. kvm虚拟机存储池配置
- 9. cpu添加虚拟化功能
- 3.8 GitLab(版本控制)
- 3.8.1 GitLab安装与汉化
- 3.9 Jenkins(运维自动化)
- 3.10 WAF(Web防火墙)
- 3.10.1初探WAF
- 四、常用数据库
- 4.1 MySQL(关系型数据库)
- 1. MySQL源码安装
- 4.2 Mongodb(适用与大数据分析的数据库)
- 4.3 Redis(非关系数据库)
- 五、自动化运维工具
- 5.1 Cobbler(系统自动化部署)
- 5.2 Ansible(自动化部署)
- 5.3 Puppet(自动化部署)
- 5.4 SaltStack(自动化运维)
- 六、存储
- 6.1 GFS(文件型存储)
- 6.2 Ceph(后端存储)
- 七、运维监控工具
- 7.1 对监控的理解
- 7.2 Zabbix(运维监控)
- 7.2.1 Zabbix简介
- 7.2.2 Zabbix服务部署
- 1. Zabbix服务端部署
- 2. Zabbix客服端部署
- 3. 配置前端展示
- 4. zabbix告警配置
- 7.2.3 Zabbix监控服务
- 1. 监控网络设备
- 2. 自定义Nginx监控
- 7.3 云镜(安全监控)
- 7.4 ELK(日志收集展示)
- 八、运维云平台
- 8.1 OpenStack(开源云操作系统)
- 8.1.1 OpenStack简介
- 8.1.2 实验架构设计
- 8.1.3 集群环境准备
- 8.1.4 controller节点部署
- 1. 安装Mariadb Galera Cluster集群
- 2. 安装RabbitMQ Cluster集群
- 3. 安装Pacemaker
- 4. 安装HAProxy
- 5. 安装配置Keystone
- 6. 安装配置glance
- 1. 制作镜像模板
- 7. 安装配置nova
- 8. 安装配置neutron
- 1. 配置虚拟机网络
- 9. 安装Dashboard
- 10. 安装配置cinder
- 8.1.5 compute节点部署
- 1. 安装相关软件包
- 2. 安装Neutron
- 3. 配置cinder
- 4. 创建第一个虚拟机
- 8.1.6 OpenStack报错处理
- 1. cinder僵尸卷删除
- 8.1.7 快速孵化虚拟机方案
- 8.1.8 Kolla容器化部署OpenStack
- 1. 单点部署
- 2. 多节点部署
- 8.2 Tstack(腾讯云平台)
- 8.3 K8s(微服务容器化)
- 九、运维编程技能
- 9.1 Shell(运维必会语言)
- 9.2 Python(万能的胶水语言)
- 十、Devops运维
- 10.1 理念
- 10.2 Devops实战