在Linux操作系統上手工部署Dubbo服務 (1) 腳本規範---------儘可能通用 (2) 守護進程 (3) 記憶體調優設置-----按需調整 (4) 日誌處理---------只保留應用Log4j輸出的日誌 (5) 避免服務衝突 ----進程名、埠 (6) 避免進程誤殺-----全匹配
在Linux操作系統上手工部署Dubbo服務
1、環境變數配置
Java環境變數----只需要JRE
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、部署目錄規範
目的:便於管理,避免應用遷移時的命名衝突。
我定義的目錄結構如下(linux)下:
--home ----------linux home目錄下
--jeesml -------------用戶信息
--jeesml ------------項目類型
--app ------------app應用
--app1 -------------app應用1
--app2... -----------app應用2
--service ----------服務應用
--service1 ----------服務1
--service2... ---------服務2
--job ------------定時調度應用
--job1... ------------定時調度工程
--web ------------Web項目工程
--web1 ---------Web項目工程1
--web2... ---------Web項目工程2
3、手工維護Dubbo服務 (不建議使用)
執行命令:
# java -jar edu-service-xxx.jar &
檢查一下有哪些java程式在運行:
# ps -ef | grep java
kill PID 進程id
kill -9 PID 強殺,不建議使用,可能會照成數據丟失
4、自定義Dubbo服務維護的Shell腳本 (建議使用)
腳本命名規範:
/home/jeesml/jeesml/service/xxx/service-xxx.sh
例如: /home/jeesml/jeesml/service/user/service-user.sh
效果: cd /home/jeesml/jeesml/service/user
. /service-user.sh start
. /service-user.sh stop
. /service-user.sh restart
5、服務維護註意事項
(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/jeesml/jeesml/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
腳本配置靈活高深,滿足需求則可 可參考官方腳本樣例,具體請到交流群(446855438)裡面下載附件信息
請各位持續關註《跟我學習dubbo-在Linux操作系統上手工部署Dubbo服務(5)》
由於第一次寫關於dubbo的博客,還希望大家加入dubbo學習交流群(446855438),一起學習。