前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >RocketMQ性能优化【实战笔记】

RocketMQ性能优化【实战笔记】

作者头像
瓜农老梁
发布2019-08-30 21:19:21
6.4K0
发布2019-08-30 21:19:21
举报
文章被收录于专栏:瓜农老梁瓜农老梁
目录
代码语言:javascript
复制
一、系统优化
1.最大文件数
2.系统参数调整
二、RocketMQ性能调优
1.开启异步刷盘
2.开启堆外内存设置
3.开启文件预热
4.开启Slave读权限
5.关闭堆内存据传输
一、系统优化
1.最大文件数

limits.conf 设置用户能打开的最大文件数

代码语言:javascript
复制
vim /etc/security/limits.conf
# End of file
baseuser soft nofile 655360
baseuser hard nofile 655360
* soft nofile 655360
* hard nofile 655360
2.系统参数调整
代码语言:javascript
复制
vim /etc/sysctl.conf
vm.overcommit_memory=1
vm.drop_caches=1
vm.zone_reclaim_mode=0
vm.max_map_count=655360
vm.dirty_background_ratio=50
vm.dirty_ratio=50
vm.dirty_writeback_centisecs=360000
vm.page-cluster=3
vm.swappiness=1
sysctl -p
参数说明
1.overcommit_memory
代码语言:javascript
复制
是否允许内存的过量分配
当为0的时候,当用户申请内存的时候,内核会去检查是否有这么大的内存空间
当为1的时候,内核始终认为,有足够大的内存空间,直到它用完了为止
当为2的时候,内核禁止任何形式的过量分配内存
2.drop_caches
代码语言:javascript
复制
写入的时候,内核会清空缓存,腾出内存来,相当于sync
写1的时候,会清空页缓存,就是文件
写2的时候,会清空inode和目录树
写3的时候,都清空
This is a non-destructive operation and will only free things that are completely unused.
Dirty objects will continue to be in use until written out to disk and are not freeable.
If you run "sync" first to flush them out to disk, these drop operations will tend to free more memory.
3.zone_reclaim_mode
代码语言:javascript
复制
如果为0的话,那么系统会倾向于从其他节点分配内存
如果为1的话,那么系统会倾向于从本地节点回收Cache内存多数时候
4.max_map_count
代码语言:javascript
复制
定义了一个进程能拥有的最多的内存区域,默认为65536
5.dirty_background_bytes/dirty_background_ratio
代码语言:javascript
复制
当dirty cache到了多少的时候,就启动pdflush进程,将dirty cache写回磁盘
当有dirty_background_bytes存在的时候,dirty_background_ratio是被自动计算的
6.dirty_bytes/dirty_ratio
代码语言:javascript
复制
当一个进程的dirty cache到了多少的时候,启动pdflush进程,将dirty cache写回磁盘
当dirty_bytes存在的时候,dirty_ratio是被自动计算的
7.dirty_writeback_centisecs
代码语言:javascript
复制
pdflush每隔多久,自动运行一次(单位是百分之一秒)
8.page-cluster
代码语言:javascript
复制
每次swap in或者swap out操作多少内存页为2的指数。等于0的时候,为1页;等于1的时候,为2页;等于2的时候,为4页
9.swappiness
代码语言:javascript
复制
swappiness=0 仅在内存不足的情况下,当剩余空闲内存低于vm.min_free_kbytes limit时,使用交换空间
swappiness=1 内核版本3.5及以上、Red Hat内核版本2.6.32-303及以上,进行最少量的交换,而不禁用交换
swappiness=10 当系统存在足够内存时,推荐设置为该值以提高性能
swappiness=60 默认值
swappiness=100 内核将积极的使用交换空间
二、RocketMQ性能调优

线上RocketMQ的JVM未做调优,堆内存使用8G;主要从RocketMQ配置参数方面梳理下。

1.开启异步刷盘
代码语言:javascript
复制
flushDiskType=ASYNC_FLUSH
同步刷盘TPS过低,较难满足业务发展需求
2.开启堆外内存设置
代码语言:javascript
复制
transientStorePoolEnable=true
消息写入到堆外内存,消费时从pageCache消费,读写分离,提升集群性能
3.开启文件预热
代码语言:javascript
复制
warmMapedFileEnable=true
开启文件预热,避免日志文件在分配内存时缺页中断
4.开启Slave读权限
代码语言:javascript
复制
slaveReadEnable=true
消息占用物理内存的大小通过accessMessageInMemoryMaxRatio来配置默认为40%;如果消费的消息不在内存中,开启slaveReadEnable时会从slave节点读取;提高Master内存利用率
5.关闭堆内存据传输
代码语言:javascript
复制
transferMsgByHeap默认true设置为false
Broker响应消费请求时,不必将数据重新读到堆内存再发送给客户端;直接从PageCache将数据发送给客户端
本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2019-08-29,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 瓜农老梁 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 目录
  • 一、系统优化
  • 1.最大文件数
  • 2.系统参数调整
  • 参数说明
  • 1.overcommit_memory
  • 2.drop_caches
  • 3.zone_reclaim_mode
  • 4.max_map_count
  • 5.dirty_background_bytes/dirty_background_ratio
  • 6.dirty_bytes/dirty_ratio
  • 7.dirty_writeback_centisecs
  • 8.page-cluster
  • 9.swappiness
  • 二、RocketMQ性能调优
  • 1.开启异步刷盘
  • 2.开启堆外内存设置
  • 3.开启文件预热
  • 4.开启Slave读权限
  • 5.关闭堆内存据传输
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档