提高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}}]

重启后即可看到效果。

### 如何访问和配置 RabbitMQ 管理控制台 #### 启动带有管理插件的 Docker 容器 为了能够通过浏览器访问 RabbitMQ 的 Web 控制台,需先启动一个包含 `rabbitmq_management` 插件在内的 RabbitMQ 实例。可以利用 Docker 来快速部署这样的环境: ```bash docker run -d --name rabbit \ -p 5672:5672 \ -p 15672:15672 \ -v /etc/rabbitmq/rabbitmq.conf:/etc/rabbitmq/rabbitmq.conf \ -e RABBITMQ_CONFIG_FILE=/etc/rabbitmq/rabbitmq.conf \ --restart=always \ rabbitmq:management ``` 上述命令会创建并运行一个新的名为 "rabbit" 的容器实例,并映射必要的端口以便外部访问[^2]。 #### 配置文件设置 如果需要自定义配置,则可以通过挂载卷的方式将本地配置文件注入到容器内。这里假设 `/etc/rabbitmq/rabbitmq.conf` 是主机上的路径,在此位置放置合适的配置文件即可影响容器内的行为。 #### 访问管理界面 一旦成功启动了服务,就可以打开网页浏览器输入地址 http://localhost:15672/ 登录到 RabbitMQ 的管理界面上去了。默认情况下用户名密码都是 guest/guest。 #### 解决无法访问的问题 遇到无法正常加载页面的情况时,可能是因为缺少启用管理插件的操作。此时应该进入正在运行中的容器内部并通过如下指令来激活它: ```bash docker exec -it rabbitmq /bin/bash rabbitmq-plugins enable rabbitmq_management ``` 这一步骤确保了即使之前忘记开启该功能也能够在不停止现有服务的前提下完成补救措施[^3]。 #### 关键指标监控 在管理界面上还可以查看诸如 Socket descriptors 这样的重要性能参数。Broker 所能处理的最大网络套接字数决定了其可承载的同时在线连接数目;当达到上限之后,任何新的尝试都将遭到拒绝[^4]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值