提高RabbitMQ的File descriptors

1. 问题描述

按默认配置安装完RabbitMQ后,发现其File descriptors(即文件描述符)和Socket descriptors都特别低,分别为924和829。客户端(消费者)保持长连接时很容易就将socket占满。

[root@hadoop1 ~]# rabbitmqctl status
Status of node rabbit@hadoop1 ...
[{pid,18946},
 {running_applications,
     [{rabbitmq_management,"RabbitMQ Management Console","3.7.7"},
 ..........................................................................
 ..........................................................................
 ..........................................................................
 {disk_free_limit,50000000},
 {disk_free,45836664832},
 {file_descriptors,
     [{total_limit,924},
      {total_used,503},
      {sockets_limit,829},
      {sockets_used,501}]},
 {processes,[{limit,1048576},{used,3890}]},
 {run_queue,0},
 {uptime,6841},
 {kernel,{net_ticktime,60}}]

经查该问题是由于系统当前的ulimit -n仅为1024,rabbitmq在启动时会进行如下换算:

file_limit = 1024 - 100; // 924
sockets_limit = trunc((1024 - 100) * 0.9 - 2); //829

2. 解决步骤

RabbitMQ的File descriptors(文件描述符)的数量受到三个参数的约束:

  1. 系统级别,配置文件为:/proc/sys/fs/file-max,如果太小需要修改。
[root@hadoop1 ~]# cat /proc/sys/fs/file-max 
778230
[root@hadoop1 ~]# cat /proc/sys/fs/file-nr 
2432	0	778230

2.用户级别,配置文件为:/etc/security/limits.conf

* - nofile 65536

3.进程级别,即ulimit -n

#修改
[root@hadoop1 ~]# ulimit -n 65536

以上三个参数都确认>=我们需要的连接数后,重启RabbitMQ,注意需要连Erlang一起重启:

#彻底关闭rabbitmq,包括erlang进程
[root@hadoop1 ~]# rabbitmqctl stop
Stopping and halting node rabbit@hadoop1 ...

#在后台启动rabbitmq服务
[root@hadoop1 ~]# rabbitmq-server -detached
Warning: PID file not written; -detached was passed.

#查询重启后rabbitmq的file_descriptors参数
[root@hadoop1 ~]# rabbitmqctl status
Status of node rabbit@hadoop1 ...
[{pid,5381},
.........................................
 {file_descriptors,
     [{total_limit,65436},
      {total_used,2},
      {sockets_limit,58890},
      {sockets_used,0}]},
 {processes,[{limit,1048576},{used,243}]},
 {run_queue,0},
 {uptime,3},
 {kernel,{net_ticktime,60}}]

重启后即可看到效果。

3. RabbitMQ 集群的故障单机的重新加入

1. rabbitmqctl stop_app
2. 杀掉 erlang进程   

ps -aux | grep mq
kill -9 进程
3.修改 
[root@hadoop1 ~]# vim  /etc/security/limits.conf
* - nofile 65536
[root@hadoop1 ~]# ulimit -n 65536
4.重启
rabbitmq-server -detached

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,以下是在 Linux 系统下安装 RabbitMQ 的步骤: 1. 安装 Erlang:RabbitMQ 是使用 Erlang 语言开发的,因此需要先安装 Erlang。可以通过以下命令在 Ubuntu 系统上安装 Erlang: ``` sudo apt-get update sudo apt-get install erlang ``` 2. 添加 RabbitMQ 的 APT 源:RabbitMQ 官方提供了 APT 源,可以通过以下命令添加: ``` curl -s https://packagecloud.io/install/repositories/rabbitmq/rabbitmq-server/script.deb.sh | sudo bash ``` 3. 安装 RabbitMQ:使用以下命令安装 RabbitMQ: ``` sudo apt-get update sudo apt-get install rabbitmq-server ``` 4. 启动 RabbitMQ:使用以下命令启动 RabbitMQ: ``` sudo service rabbitmq-server start ``` 5. 验证 RabbitMQ 是否运行:使用以下命令验证 RabbitMQ 是否已经运行: ``` sudo rabbitmqctl status ``` 如果输出类似于以下内容,则说明 RabbitMQ 已经成功安装并启动: ``` Status of node rabbit@localhost ... [{pid,1593}, {running_applications, [{rabbitmq_management,"RabbitMQ Management Console","3.7.8"}, {rabbitmq_web_dispatch,"RabbitMQ Web Dispatcher","3.7.8"}, {rabbitmq_management_agent,"RabbitMQ Management Agent","3.7.8"}, {rabbit,"RabbitMQ","3.7.8"}, {rabbit_common,[],"3.7.8"}, {cowlib,"Cowboy 2.2.0 adapter for Erlang/OTP","2.7.0"}, {ranch,"Socket acceptor pool for TCP protocols.","1.7.1"}, {cowboy,"Small, fast, modern HTTP server.","2.7.0"}]}, {os,{unix,linux}}, {erlang_version,"21.1.4"}, {memory,[{total,36291120}, {connection_readers,0}, {connection_writers,0}, {connection_channels,0}, {connection_other,0}, {queue_procs,0}, {queue_slave_procs,0}, {plugins,0}, {other_proc,10419336}, {mnesia,0}, {mgmt_db,0}, {msg_index,0}, {other_ets,0}, {binary,85736}, {code,27291943}, {atom,922993}, {other_system,1985722}]}, {alarms,[]}, {listeners,[{clustering,25672,"::"},{amqp,5672,"::"}]}, {vm_memory_high_watermark,0.4}, {vm_memory_limit,1337729233}, {disk_free_limit,50000000}, {disk_free,16445234176}, {file_descriptors,[{total_limit,1048576}, {total_used,2}, {sockets_limit,943626}, {sockets_used,0}]}, {processes,[{limit,1048576},{used,288}]}, {run_queue,0}, {uptime,1504}] ``` 至此,RabbitMQ 已经在 Linux 系统上安装成功。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值