提高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
  1. 用户级别,配置文件为:/etc/security/limits.conf
* - nofile 65536
  1. 进程级别,即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
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值