Dubbo之——Shell脚本维护Dubbo服务

转载请注明出处:http://blog.csdn.net/l1028386804/article/details/70509187

1、部署目录规范

目的:便于管理,避免应用迁移时的命名冲突。
我定义的目录结构如下(linux)下:
--home   ----------linux home目录下
    --liuyazhuang    -------------用户信息
        --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服务 (不建议使用)

执行命令:

[plain]  view plain  copy
  1. # java -jar edu-service-xxx.jar &  
检查一下有哪些java程序在运行:
[plain]  view plain  copy
  1. # ps -ef | grep java   
  2. kill PID 进程id  
  3. kill -9 PID  强杀,不建议使用,可能会照成数据丢失  

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

 脚本命名规范:
/home/liuyazhuang/dubboserver/service/xxx/service-xxx.sh
例如: /home/liuyazhuang/dubboserver/service/user/service-user.sh
效果: 
[plain]  view plain  copy
  1. cd /home/liuyazhuang/dubboserver/service/user  
  2. . /service-user.sh start  
  3. . /service-user.sh stop  
  4. . /service-user.sh restart  

4、服务维护注意事项

(1) 脚本规范---------尽可能通用
(2) 守护进程
(3) 内存调优设置-----按需调整
(4) 日志处理---------只保留应用Log4j输出的日志
(5) 避免服务冲突 ----进程名、端口
(6) 避免进程误杀-----全匹配
简单脚本实例:
[plain]  view plain  copy
  1. #!/bin/sh  
  2.   
  3. ## java env  
  4. export JAVA_HOME=/usr/local/java/jdk1.7.0_72  
  5. export JRE_HOME=$JAVA_HOME/jre  
  6.   
  7. ## service name  
  8. APP_NAME=user  
  9.   
  10. SERVICE_DIR=/home/liuyazhuang/dubboserver/service/$APP_NAME  
  11. SERVICE_NAME=dubbo-service-$APP_NAME  
  12. JAR_NAME=$SERVICE_NAME\.jar  
  13. PID=$SERVICE_NAME\.pid  
  14.   
  15. cd $SERVICE_DIR  
  16.   
  17. case "$1" in  
  18.   
  19.     start)  
  20.         nohup $JRE_HOME/bin/java -Xms256m -Xmx512m -jar $JAR_NAME >/dev/null 2>&1 &  
  21.         echo $! > $SERVICE_DIR/$PID  
  22.         echo "=== start $SERVICE_NAME"  
  23.         ;;  
  24.   
  25.     stop)  
  26.         kill `cat $SERVICE_DIR/$PID`  
  27.         rm -rf $SERVICE_DIR/$PID  
  28.         echo "=== stop $SERVICE_NAME"  
  29.   
  30.         sleep 5  
  31.         ##  
  32.         ## edu-service-aa.jar  
  33.         ## edu-service-aa-bb.jar  
  34.         P_ID=`ps -ef | grep -w "$SERVICE_NAME" | grep -v "grep" | awk '{print $2}'`  
  35.         if [ "$P_ID" == "" ]; then  
  36.             echo "=== $SERVICE_NAME process not exists or stop success"  
  37.         else  
  38.             echo "=== $SERVICE_NAME process pid is:$P_ID"  
  39.             echo "=== begin kill $SERVICE_NAME process, pid is:$P_ID"  
  40.             kill -9 $P_ID  
  41.         fi  
  42.         ;;  
  43.   
  44.     restart)  
  45.         $0 stop  
  46.         sleep 2  
  47.         $0 start  
  48.         echo "=== restart $SERVICE_NAME"  
  49.         ;;  
  50.   
  51.     *)  
  52.         ## restart  
  53.         $0 stop  
  54.         sleep 2  
  55.         $0 start  
  56.         ;;  
  57.   
  58. esac  
  59. exit 0  
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值