前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Dubbo服务治理篇——使用Shell脚本维护Dubbo服务

Dubbo服务治理篇——使用Shell脚本维护Dubbo服务

作者头像
冰河
发布2020-10-29 15:29:09
5190
发布2020-10-29 15:29:09
举报
文章被收录于专栏:冰河技术

1、部署目录规范

目的:便于管理,避免应用迁移时的命名冲突。 我定义的目录结构如下(linux)下:

代码语言:javascript
复制
--home   ----------linux home目录下
    --binghe-------------用户信息
        --dubboserver  ------------项目类型
              --app  ------------app应用
                    --app1  -------------app应用1
                    --app2...  -----------app应用2
            --service ----------服务应用
                    --service1  ----------服务1
                    --service2... ---------服务2
            --timer  ------------定时调度应用
                --timer1...  ------------定时调度工程1
                --timer2...  ------------定时调度工程2
            --web   ------------Web项目工程
                --web1  ---------Web项目工程1
                --web2... ---------Web项目工程2

2、手工维护Dubbo服务 (不建议使用)

执行命令:

代码语言:javascript
复制
# java -jar edu-service-xxx.jar &

检查一下有哪些java程序在运行:

代码语言:javascript
复制
# ps -ef | grep java 
kill PID 进程id
kill -9 PID  强杀,不建议使用,可能会造成数据丢失

3、自定义Dubbo服务维护的Shell脚本 (建议使用)

脚本命名规范:

/home/binghe/dubboserver/service/xxx/service-xxx.sh

例如:/home/binghe/dubboserver/service/user/service-user.sh

效果:

代码语言:javascript
复制
cd /home/binghe/dubboserver/service/user
. /service-user.sh start
. /service-user.sh stop
. /service-user.sh restart

4、服务维护注意事项

(1) 脚本规范---------尽可能通用

(2) 守护进程

(3) 内存调优设置-----按需调整

(4) 日志处理---------只保留应用Log4j输出的日志

(5) 避免服务冲突 ----进程名、端口

(6) 避免进程误杀-----全匹配

简单脚本实例:

代码语言:javascript
复制
#!/bin/sh

## java env
export JAVA_HOME=/usr/local/java/jdk1.7.0_72
export JRE_HOME=$JAVA_HOME/jre

## service name
APP_NAME=user

SERVICE_DIR=/home/binghe/dubboserver/service/$APP_NAME
SERVICE_NAME=dubbo-service-$APP_NAME
JAR_NAME=$SERVICE_NAME\.jar
PID=$SERVICE_NAME\.pid

cd $SERVICE_DIR

case "$1" in

    start)
        nohup $JRE_HOME/bin/java -Xms256m -Xmx512m -jar $JAR_NAME >/dev/null 2>&1 &
        echo $! > $SERVICE_DIR/$PID
        echo "=== start $SERVICE_NAME"
        ;;

    stop)
        kill `cat $SERVICE_DIR/$PID`
        rm -rf $SERVICE_DIR/$PID
        echo "=== stop $SERVICE_NAME"

        sleep 5
        ##
        ## edu-service-aa.jar
        ## edu-service-aa-bb.jar
        P_ID=`ps -ef | grep -w "$SERVICE_NAME" | grep -v "grep" | awk '{print $2}'`
        if [ "$P_ID" == "" ]; then
            echo "=== $SERVICE_NAME process not exists or stop success"
        else
            echo "=== $SERVICE_NAME process pid is:$P_ID"
            echo "=== begin kill $SERVICE_NAME process, pid is:$P_ID"
            kill -9 $P_ID
        fi
        ;;

    restart)
        $0 stop
        sleep 2
        $0 start
        echo "=== restart $SERVICE_NAME"
        ;;

    *)
        ## restart
        $0 stop
        sleep 2
        $0 start
        ;;

esac
exit 0

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2019-12-23,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 冰河技术 微信公众号,前往查看

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

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

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 1、部署目录规范
  • 2、手工维护Dubbo服务 (不建议使用)
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档