跟我學習dubbo-在Linux操作系統上手工部署Dubbo服務(5)


在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),一起學習。

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM