您的位置:首页 > 运维架构 > Shell

[置顶] dubbo -4在linux手工部署dubbo(shell脚本)

2017-11-14 20:14 267 查看
1.环境变量配置

vi /etc/profile

## java env

export JAVA_HOME=/usr/local/java/jdk1.7.0_72

export JRE_HOME=$JAVA_HOME/jre

export CLASSPATH=.:$JAVA_HOME/lib/dt.jar:$JAVA_HOME/li/tools.jar:$JRE_HOME/lib/rt.jar

export PATH=$PATH:$JAVA_HOME/bin:$JRE_HOME/bin

source /etc/profile

2.部署目录规范

图片

3.手工维护Dubbo服务

java -jar edu-service-xxx.jar &

kill PID

kill -9 PID

4.防火墙开启20880端口,用root用户修改/etc/sysconfig/iptables

vi /etc/sysconfig/iptables
增加
-A INPUT -m state --state NEW -m tcp -p tcp --dport 20880 -j ACCEPT
重启防火墙
service iptables restart

5、自定义Dubbo服务维护的Shell脚本

脚本命名规范:

/home/wusc/edu/service/xxx/service-xxx.sh

例如:

/home/wusc/edu/service/user/service-user.sh

效果:

cd /home/wusc/edu/service/user

. /service-user.sh start

. /service-user.sh stop

. /service-user.sh restart

(service-user.sh)shell脚本

nohup 守护进程

sleep 5 用fro循环更合理

-w 全名匹配

#!/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/wusc/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

6、服务维护注意事项(结合自定义的Shell脚本)

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

(2) 守护进程

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

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

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

(6) 避免进程误杀-----全匹配
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: