开发项目采用Dubbo分布式开发基本上都是Linux服务器部署项目,多个项目模块部署需要按照规范进行部署,方便项目管理以及迁移。
项目模块部署规范:
i1. 建立项目部署目录文件夹。通常以项目名为根节点。
i2. 二级目录为项目类型名。例如:app、service、timer、web。
i3. 三级目录为子模块项目名。
自定义Dubbo服务维护的Shell脚本。
脚本命名规范:
/root/edu/service/xxx/service-xxx.sh
例如:
/root/edu/service/user/service-user.sh效果:
# cd /root/edu/service/user
# ./service-user.sh start
# ./service-user.sh stop
# ./service-user.sh restart
以下是自定脚本代码:
#!/bin/sh
## java env
export JAVA_HOME=/root/jdk1.7.0_79
export JRE_HOME=$JAVA_HOME/jre
## service name
APP_NAME=user
SERVICE_DIR=/root/edu/service/$APP_NAME
SERVICE_NAME=edu-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
注:使用这个批处理文件只需要将修改定义变量路径修改正确既可以使用。
点击下载批处理文件