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

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

1、部署目录规范


目的:便于管理,避免应用迁移时的命名冲突。

我定义的目录结构如下(linux)下:


--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服务 (不建议使用)


执行命令:


# java -jar edu-service-xxx.jar &


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


# 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

效果:


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) 避免进程误杀-----全匹配


简单脚本实例:


#!/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
相关文章
|
14天前
|
Shell
Shell脚本有哪些基本语法?
【9月更文挑战第4天】
36 17
|
14天前
|
存储 Unix Shell
shell脚本编程基础
【9月更文挑战第4天】
28 12
|
13天前
|
网络协议 关系型数据库 MySQL
Shell 脚本案例
Shell 脚本案例
27 8
|
14天前
|
Shell Linux 开发工具
linux shell 脚本调试技巧
【9月更文挑战第3天】在Linux中调试shell脚本可采用多种技巧:使用`-x`选项显示每行命令及变量扩展情况;通过`read`或`trap`设置断点;利用`echo`检查变量值,`set`显示所有变量;检查退出状态码 `$?` 进行错误处理;使用`bashdb`等调试工具实现更复杂调试功能。
|
26天前
|
JSON Dubbo Java
【Dubbo协议指南】揭秘高性能服务通信,选择最佳协议的终极攻略!
【8月更文挑战第24天】在分布式服务架构中,Apache Dubbo作为一款高性能的Java RPC框架,支持多种通信协议,包括Dubbo协议、HTTP协议及Hessian协议等。Dubbo协议是默认选择,采用NIO异步通讯,适用于高要求的内部服务通信。HTTP协议通用性强,利于跨语言调用;Hessian协议则在数据传输效率上有优势。选择合适协议需综合考虑性能需求、序列化方式、网络环境及安全性等因素。通过合理配置,可实现服务性能最优化及系统可靠性提升。
38 3
|
18天前
|
C# 开发者 Windows
勇敢迈出第一步:手把手教你如何在WPF开源项目中贡献你的第一行代码,从选择项目到提交PR的全过程解析与实战技巧分享
【8月更文挑战第31天】本文指导您如何在Windows Presentation Foundation(WPF)相关的开源项目中贡献代码。无论您是初学者还是有经验的开发者,参与这类项目都能加深对WPF框架的理解并拓展职业履历。文章推荐了一些适合入门的项目如MvvmLight和MahApps.Metro,并详细介绍了从选择项目、设置开发环境到提交代码的全过程。通过具体示例,如添加按钮点击事件处理程序,帮助您迈出第一步。此外,还强调了提交Pull Request时保持专业沟通的重要性。参与开源不仅能提升技能,还能促进社区交流。
27 0
|
18天前
|
运维 监控 Shell
自动化运维之宝:编写高效的Shell脚本
【8月更文挑战第31天】在运维的世界里,Shell脚本是一把瑞士军刀,它让日常任务变得简单而高效。本文将通过浅显易懂的语言和实际案例,带你领略Shell脚本的魅力,并教你如何打造属于自己的自动化工具箱。无论你是初学者还是资深运维,这篇文章都将为你打开一扇窗,让你看到不一样的风景。让我们一起探索Shell脚本的世界吧!
|
26天前
|
存储 Shell 数据安全/隐私保护
minio一键安装脚本分享(shell和python)
minio一键安装脚本分享(shell和python)
38 0
|
26天前
|
关系型数据库 Shell 数据库
postgres14一键安装脚本分享(shell和python)
postgres14一键安装脚本分享(shell和python)
21 0
|
27天前
|
监控 Shell Linux
在Linux中,如何使用shell脚本检测磁盘使用率?
在Linux中,如何使用shell脚本检测磁盘使用率?