RabbitMQ 内存控制 硬盘控制
一、内存控制:
vm_memory_high_watermark 该值为内存阈值,默认为0.4。意思为物理内存的40%。40%的内存并不是内存的最大的限制,它是一个发布的节制,当达到40%时Erlang会做GC。最坏的情况是使用内存80%。如果把该值配置为0,将关闭所有的publishing 。
rabbitmqctl set_vm_memory_high_watermark 0
Paging 内存阈值,该值为默认为0.5,该值为vm_memory_high_watermark的20%时,将把内存数据写到磁盘。
如机器内存16G,当RABBITMQ占用内存1.28G(16*0.4*0.2)时把内存数据放到磁盘。
二、硬盘控制:
当RabbitMQ的磁盘空闲空间小于50M(默认),生产者将被BLOCK,
如果采用集群模式,磁盘节点空闲空间小于50M将导致其他节点的生产者都被block
可以通过disk_free_limit来对进行配置。
------------------------------------------------------------------\
可以修改rabbitmq-env.conf配置文件:
[{rabbit,[{vm_memory_high_watermark,0.6}]}].
或者设置成固定值:
[{rabbit,[{vm_memory_high_watermark,{absolute,1073741824}}]}].也就是1024MB.
如果要在broker运行过程中修改,则rabbitmqctl set_vm_memory_high_watermark 0.6
-------------------------------------------------\
三. 配置
/usr/local/rabbitmq/sbin目录下
rabbitmq-env 环境配置
rabbitmq-defaults 默认参数设置
rabbitmqctl 管理工具
rabbitmq-plugins 插件管理工具
rabbitmq-server rabbitmq服务
# vim rabbitmq-defaults
| 
 1 
2 
3 
4 
5 
6 
7 
8 
9 
10 
 | 
 SYS_PREFIX=${RABBITMQ_HOME} 
ERL_DIR=/usr/local/erlang/bin/ //设置erl命令路径 
CLEAN_BOOT_FILE=start_clean 
SASL_BOOT_FILE=start_sasl 
CONFIG_FILE=${SYS_PREFIX}/etc/rabbitmq/rabbitmq //设置rabbitmq运行参数 
LOG_BASE=${SYS_PREFIX}/var/log/rabbitmq 
MNESIA_BASE=${SYS_PREFIX}/var/lib/rabbitmq/mnesia 
ENABLED_PLUGINS_FILE=${SYS_PREFIX}/etc/rabbitmq/enabled_plugins //允许插件列表配置文件 
PLUGINS_DIR="${RABBITMQ_HOME}/plugins" 
CONF_ENV_FILE=${SYS_PREFIX}/etc/rabbitmq/rabbitmq-env.conf 
 | 
主要配置文件
1. enabled_plugins:设置允许的插件列表,格式如下:
| 
 1 
2 
3 
4 
5 
 | 
 [rabbitmq_jsonrpc_channel, 
rabbitmq_jsonrpc_channel_examples, 
rabbitmq_management, 
rabbitmq_management_visualiser, 
rabbitmq_tracing]. 
 | 
2. rabbitmq.config:设置rabbitmq运行参数。结构为hash数组格式。如
| 
 1 
2 
3 
4 
5 
6 
7 
8 
9 
 | 
 [ 
{mnesia, [{dump_log_write_threshold, 1000}]}, 
{rabbit, [{vm_memory_high_watermark, 0.4}]} 
{rabbitmq_management, 
[{listener, [{port, 55673}, 
{ip, "0.0.0.0"} 
]} 
]} 
]. 
 | 
其中几个关键参数为:
tcp_listerners 设置rabbimq的监听端口,默认为[5672]。
disk_free_limit 磁盘低水位线,若磁盘容量低于指定值则停止接收数据,默认值为{mem_relative, 1.0},即与内存相关联1:1,也可定制为多少byte.
vm_memory_high_watermark,设置内存低水位线,若低于该水位线,则开启流控机制,默认值是0.4,即内存总量的40%。
hipe_compile 将部分rabbimq代码用High Performance Erlang compiler编译,可提升性能,该参数是实验性,若出现erlang vm segfaults,应关掉。
force_fine_statistics, 该参数属于rabbimq_management,若为true则进行精细化的统计,但会影响性能。
/usr/local/etc/rabbitmq/rabbitmq.config
[{auth_backends,[rabbit_auth_backend_internal]},
{auth_mechanisms,['PLAIN','AMQPLAIN']},
{backing_queue_module,rabbit_variable_queue},
{cluster_nodes,[]},
{collect_statistics,fine},
{collect_statistics_interval,5000},
{default_permissions,[<<".*">>,<<".*">>,<<".*">>]},
{default_user,<<"guest">>},
{default_user_tags,[administrator]},
{default_vhost,<<"/">>},
{delegate_count,16},
{error_logger,{file,"/usr/local/var/log/rabbitmq/rabbit@Technophiliac.log"}},
{frame_max,131072},
{hipe_compile,false},
{included_applications,[]},
{msg_store_file_size_limit,16777216},
{msg_store_index_module,rabbit_msg_store_ets_index},
{queue_index_max_journal_entries,262144},
{sasl_error_logger,{file,"/usr/local/var/log/rabbitmq/rabbit@Technophiliac-sasl.log"}},
{server_properties,[]},
{ssl_listeners,[]},
{ssl_options,[]},
{tcp_listen_options,
[binary,
{packet,raw},
{reuseaddr,true},
{backlog,128},
{nodelay,true},
{exit_on_close,false}]},
{tcp_listeners,[5672]},
{trace_vhosts,[<<"/">>]},
{vm_memory_high_watermark,0.4}]
3. rabbitmq-env.conf rabbitmq环境参数配置
| 
 1 
2 
3 
4 
5 
6 
 | 
 RABBITMQ_NODENAME=FZTEC-240088 节点名称 
RABBITMQ_NODE_IP_ADDRESS=127.0.0.1 监听IP 
RABBITMQ_NODE_PORT=5672 监听端口 
RABBITMQ_LOG_BASE=/data/rabbitmq/log 日志目录 
RABBITMQ_PLUGINS_DIR=/data/rabbitmq/plugins 插件目录 
RABBITMQ_MNESIA_BASE=/data/rabbitmq/mnesia 后端存储目录 
 | 
更详细的配置参见: http://www.rabbitmq.com/configure.html#configuration-file
4. 启动
| 
 1 
 | 
 # /usr/local/rabbitmq/sbin/rabbitmq-server -detached 
 | 
四. rabbitmq插件管理
启用rabbitmq web管理插件
| 
 1 
 | 
 # ./rabbitmq-plugins enable rabbitmq_management 
 | 
列出所有插件
| 
 1 
 | 
 # ./rabbitmq-plugins list 
 | 
RabbitMQ 内存控制 硬盘控制的更多相关文章
- 归纳整理Linux下C语言常用的库函数----内存及字符串控制及操作
		
在没有IDE的时候,记住一些常用的库函数的函数名.参数.基本用法及注意事项是很有必要的. 参照Linux_C_HS.chm的目录,我大致将常用的函数分为一下几类: 1. 内存及字符串控制及操作 2. ...
 - PC-改变电脑的CPU,内存,硬盘大小!
		
如何修改CPU频率及内存容量和硬盘大小 改变电脑的CPU,内存,硬盘大小!--------------------------------------------------------------- ...
 - (转载)CPU、内存、硬盘、指令以及他们之间的关系
		
CPU.内存.硬盘.指令以及他们之间的关系 最近读完<程序是怎样跑起来的>以及<深入理解计算机系统>的3.6.9章节后对计算机的组成有了更深入细致的了解,现总结一下对CPU.内 ...
 - 网络互联技术(2)——前篇—【转载】电脑结构和CPU、内存、硬盘三者之间的关系
		
原文链接:传送门 详细内容: 电脑结构和CPU.内存.硬盘三者之间的关系 前面提到了,电脑之父——冯·诺伊曼提出了计算机的五大部件:输入设备.输出设备.存储器.运算器和控制器. 我们看一下现在我们电脑 ...
 - RabbitMQ内存爆出
		
RabbitMQ升级到3.6.1版本后,随着业务和系统功能的增加,出现RabbitMQ内存陡增直至服务宕掉的情况.内存增加时,在management管理控制台上可以见到如下警告: The manage ...
 - RabbitMQ内存爆出问题解决思路
		
http://www.bubuko.com/infodetail-2121050.html RabbitMQ升级到3.6.1版本后,随着业务和系统功能的增加,出现RabbitMQ内存陡增直至服务宕掉的 ...
 - CPU、内存、硬盘之间的关系
		
要完完全全地讲清楚cpu.内存.硬盘之间的关系,博客的篇幅是不够的.这里简单的介绍以下它们之间的关系,抛砖引玉. 1.CPU即中央处理器,是英语“Central Processing Unit”的缩写 ...
 - 使用内存虚拟硬盘 提高ArcGIS server并发性能的一种方法
		
1 问题提出 1.1 概述 提高ArcGIS server并发性能的方法很多,本文讨论在用户硬件足够强大的情况下(主要是内存足够大),使用内存模拟硬盘来提高数据的读取效率,以达到提高ArcGIS se ...
 - Linux 查看CPU,内存,硬盘 !转
		
Linux 查看CPU,内存,硬盘 本文转自:http://hi.baidu.com/mumachuntian/item/a401368dbe8a66cab07154e8 1 查看CPU 1.1 查看 ...
 
随机推荐
- git checkout -b mybranch和git checkout mybranch
			
创建分支: $ git branch mybranch切换分支: $ git checkout mybranch创建并切换分支: $ git checkout -b mybranch更新maste ...
 - Centos7安装SVN服务器
			
1.关闭防火墙systemctl stop firewalld.service 2.安装svn服务器yum install subversion 3.创建放置项目project的地方mkdir /sv ...
 - Nginx 状态信息功能配置
			
Nginx 状态信息功能介绍 Nginx 有一个 ngx_http_stub_status_module 模块,主要功能是记录 Nginx 的基本访问状态信息,让使用者了解 Nginx 的工作状态 要 ...
 - 【iCore1S 双核心板_ARM】例程四:USART通信实验——通过命令控制LED
			
实验原理: 开发板上自带一片CH340芯片,完成本实验电脑需要安装CH340驱动, CH340的TXD连接STM32的GPIO(PB6),CH340的RXD连接STM32的 GPIO(PB7),通过串 ...
 - 数据中心内负载均衡-ECMP的使用分析
			
背景 数据中心的网络拓扑通常采用CLOS结构,主机之间常存在多条路径.数据中心为满足吞吐量敏感型流量的需求会提供大量的带宽资源.那么利用数据中心这种网络拓扑已知,路径资源.带宽资源丰富的特性,可以更好 ...
 - svn-checkout后,循环遍历查找包含某字符串的文件
			
这里涉及几个知识点: 1.安装subversion,不多说了,网上有教程 2.循环遍历所有目录层级,找相 关文件 #!/bin/bash #########svn checkout项目出来 svn_d ...
 - Linux下使用vim命令编辑与修改文本内容
			
输入 vim --help VIM - Vi IMproved 8.0 (2016 Sep 12, compiled Jul 26 2017 20:13:43) 用法: vim [参数] [文件 .. ...
 - Cisco HSRP热备份路由器协议配置
			
HSRP热备份路由器协议: HSRP是 Hot Standby Routing Protocol(热备份路由协议)的缩写,它的作用是当核心路由器不能正常工作时, 备用路由器能够实现自动平滑的替换,以保 ...
 - CentOS7主机名修改
			
1.命令行更改主机名,重启终端即生效. #hostnamectl --static set-hostname k8s-master
 - [Tensorflow] Practice - The Tensorflow Way
			
该系列主要是<Tensorflow 实战Google深度学习框架 >阅读笔记:有了Cookbook的热身后,以这本书作为基础形成个人知识体系. Ref: [Tensorflow] Cook ...