怎么修改RocketMQ中nameServer使用内存大小
- RocketMQ
- 时间:2025-01-17 13:01
- 13人已阅读
🔔🔔🔔好消息!好消息!🔔🔔🔔
有需要的朋友👉:联系凯哥
问题:
我的rocketMQ位置:/tol/rocketmq/bin
我现在想要修改nameserver的内存大小。
cat mqnamesrv 内容如下:
cat mqnamesrv
if [ -z "$ROCKETMQ_HOME" ] ; then
## resolve links - $0 may be a link to maven's home
PRG="$0"
# need this for relative symlinks
while [ -h "$PRG" ] ; do
ls=`ls -ld "$PRG"`
link=`expr "$ls" : '.*-> \(.*\)$'`
if expr "$link" : '/.*' > /dev/null; then
PRG="$link"
else
PRG="`dirname "$PRG"`/$link"
fi
done
saveddir=`pwd`
ROCKETMQ_HOME=`dirname "$PRG"`/..
# make it fully qualified
ROCKETMQ_HOME=`cd "$ROCKETMQ_HOME" && pwd`
cd "$saveddir"
fi
export ROCKETMQ_HOME
JAVA_OPT="${JAVA_OPT} -server -Xms2g -Xmx2g -Xmn1g"
sh ${ROCKETMQ_HOME}/bin/runserver.sh org.apache.rocketmq.namesrv.NamesrvStartup $@
怎么修改启动脚本中添加:
JAVA_OPT="${JAVA_OPT} -server -Xms2g -Xmx2g -Xmn1g"
然后重启nameserve怎么重启?
修改 RocketMQ NameServer 的内存大小
你的 mqnamesrv
脚本已经包含了如下 JVM 内存参数:
sh复制代码JAVA_OPT="${JAVA_OPT} -server -Xms2g -Xmx2g -Xmn1g"
如果你想调整 NameServer 的内存大小,比如改成:
最小内存 (
-Xms
):1GB最大内存 (
-Xmx
):1GB新生代内存 (
-Xmn
):512MB
可以修改 mqnamesrv
中的这一行:
sh复制代码JAVA_OPT="${JAVA_OPT} -server -Xms1g -Xmx1g -Xmn512m"
修改步骤
打开
mqnamesrv
脚本进行编辑sh复制代码vi /tol/rocketmq/bin/mqnamesrv
找到如下行:
sh复制代码JAVA_OPT="${JAVA_OPT} -server -Xms2g -Xmx2g -Xmn1g"
修改成你需要的配置,例如
sh复制代码JAVA_OPT="${JAVA_OPT} -server -Xms1g -Xmx1g -Xmn512m"
保存并退出 (
vi
操作)按
Esc
退出编辑模式输入
:wq
并回车,保存退出
重启 RocketMQ NameServer
1. 先停止 NameServer
sh复制代码ps -ef | grep NamesrvStartup
找到 mqnamesrv
进程的 PID,假设是 12345
,然后执行:
sh复制代码kill -9 12345
或者:
sh复制代码sh /tol/rocketmq/bin/mqshutdown namesrv
2. 启动 NameServer
sh复制代码sh /tol/rocketmq/bin/mqnamesrv &
3. 确认 NameServer 运行状态
sh复制代码ps -ef | grep NamesrvStartup
或者:
sh复制代码netstat -tlnp | grep 9876
如果 NameServer 监听的 9876 端口 正常开启,则表示运行成功。
验证修改是否生效
检查 JVM 进程内存参数
sh复制代码jps -lvm | grep NamesrvStartup
你应该能看到
-Xms1g -Xmx1g -Xmn512m
这些参数。检查 NameServer 日志
sh复制代码tail -f ~/logs/rocketmqlogs/namesrv.log
确保没有异常错误。
这样,你的 RocketMQ NameServer 内存大小就修改成功了!
问题2:
我在我的脚本中没有找到JAVA_OPT这个啊
如果你的 mqnamesrv
脚本中没有 JAVA_OPT
相关配置,你可能需要在 runserver.sh
或 runbroker.sh
这些文件中寻找,或者在环境变量中定义。下面是详细的检查和修改方法:
1. 在 runserver.sh
文件中查找 JAVA_OPT
你的 mqnamesrv
最终执行了:
sh复制代码sh ${ROCKETMQ_HOME}/bin/runserver.sh org.apache.rocketmq.namesrv.NamesrvStartup $@
这意味着 JAVA_OPT
可能在 runserver.sh
中被定义。
(1) 打开 runserver.sh
文件
sh复制代码vi /tol/rocketmq/bin/runserver.sh
(2) 查找 JAVA_OPT
相关设置
在 vi
中输入:
sh复制代码/ JAVA_OPT
然后按 Enter
逐行查找 JAVA_OPT
变量。
(3) 可能的 JAVA 选项
你可能会找到类似的内容:
sh复制代码JAVA_OPT="-server -Xms256m -Xmx256m -Xmn128m"
如果找到这一行,你可以修改 -Xms
、-Xmx
、-Xmn
的值。例如:
sh复制代码JAVA_OPT="-server -Xms2g -Xmx2g -Xmn1g"
(4) 保存并退出
按
Esc
退出编辑模式输入
:wq
并回车,保存退出
2. 在 mqnamesrv
中手动添加 JAVA_OPT
如果 runserver.sh
也没有 JAVA_OPT
,你可以在 mqnamesrv
里自己添加。
(1) 编辑 mqnamesrv
sh复制代码vi /tol/rocketmq/bin/mqnamesrv
(2) 在 export ROCKETMQ_HOME
下面添加
sh复制代码JAVA_OPT="-server -Xms2g -Xmx2g -Xmn1g"export JAVA_OPT
(3) 保存并退出
按
Esc
退出编辑模式输入
:wq
并回车,保存退出
3. 重新启动 NameServer
(1) 先停止 NameServer
sh复制代码ps -ef | grep NamesrvStartup
找到进程的 PID(例如 12345
),然后执行:
sh复制代码kill -9 12345
或者:
sh复制代码sh /tol/rocketmq/bin/mqshutdown namesrv
(2) 启动 NameServer
sh复制代码sh /tol/rocketmq/bin/mqnamesrv &
(3) 确认 NameServer 运行状态
sh复制代码ps -ef | grep NamesrvStartup
或者:
sh复制代码netstat -tlnp | grep 9876
4. 验证 JAVA 参数是否生效
sh复制代码jps -lvm | grep NamesrvStartup
你应该能看到 -Xms2g -Xmx2g -Xmn1g
这些参数,说明修改成功。
如果 mqnamesrv
和 runserver.sh
里都找不到 JAVA_OPT
,可以在 ROCKETMQ_HOME/conf
目录下寻找 runserver.sh
、runbroker.sh
等其他 RocketMQ 启动脚本,并按照相同方法修改。
这样,你就能成功修改 RocketMQ NameServer 的内存大小了!
上一篇: 分库分表用同一算法会有什么问题