怎么修改RocketMQ中nameServer使用内存大小

  • 作者: 凯哥Java(公众号:凯哥Java)
  • RocketMQ
  • 时间:2025-01-17 13:01
  • 13人已阅读
简介 问题:我的rocketMQ位置:/tol/rocketmq/bin我现在想要修改nameserver的内存大小。catmqnamesrv 内容如下:catmqnamesrvif[-z"$ROCKETMQ_HOME"];then ##resolvelinks-$0maybealinktomaven'shome PRG="$0&quo

🔔🔔🔔好消息!好消息!🔔🔔🔔

有需要的朋友👉:联系凯哥 微信号 kaigejava2022

问题:

我的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"

修改步骤

  1. 打开 mqnamesrv 脚本进行编辑

    sh复制代码vi /tol/rocketmq/bin/mqnamesrv
  2. 找到如下行:

    sh复制代码JAVA_OPT="${JAVA_OPT} -server -Xms2g -Xmx2g -Xmn1g"
  3. 修改成你需要的配置,例如

    sh复制代码JAVA_OPT="${JAVA_OPT} -server -Xms1g -Xmx1g -Xmn512m"
  4. 保存并退出 (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 端口 正常开启,则表示运行成功。


验证修改是否生效

  1. 检查 JVM 进程内存参数

    sh复制代码jps -lvm | grep NamesrvStartup

    你应该能看到 -Xms1g -Xmx1g -Xmn512m 这些参数。

  2. 检查 NameServer 日志

    sh复制代码tail -f ~/logs/rocketmqlogs/namesrv.log

    确保没有异常错误。


这样,你的 RocketMQ NameServer 内存大小就修改成功了!


问题2:

我在我的脚本中没有找到JAVA_OPT这个啊

如果你的 mqnamesrv 脚本中没有 JAVA_OPT 相关配置,你可能需要在 runserver.shrunbroker.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 这些参数,说明修改成功。


如果 mqnamesrvrunserver.sh 里都找不到 JAVA_OPT,可以在 ROCKETMQ_HOME/conf 目录下寻找 runserver.shrunbroker.sh 等其他 RocketMQ 启动脚本,并按照相同方法修改。

这样,你就能成功修改 RocketMQ NameServer 的内存大小了!


TopTop