跟我学习dubbo-在Linux操作系统上手工部署Dubbo服务(5)

原创
2016/01/08 03:28
阅读数 2.6K

在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 jeesmlsz-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=jeesmlsz-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
        ##
        ## jeesmlsz-service-aa.jar
        ## jeesmlsz-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-构建Dubbo服务消费者Web应用的war包并在Tomcat中部署(6)》


1.     项目核心代码结构截图

分布式框架介绍 - kafkaee - kafkaee的博客

   项目模块依赖

分布式框架介绍 - kafkaee - kafkaee的博客

特别提醒:开发人员在开发的时候可以将自己的业务REST服务化或者Dubbo服务化

2.    项目依赖介绍

   2.1 后台管理系统、Rest服务系统、Scheculer定时调度系统依赖如下图:

 

分布式框架介绍 - kafkaee - kafkaee的博客

       2.2 Dubbo独立服务项目依赖如下图:

 

分布式框架介绍 - kafkaee - kafkaee的博客

3.  项目功能部分截图:

分布式框架介绍 - kafkaee - kafkaee的博客

 

分布式框架介绍 - kafkaee - kafkaee的博客

 

分布式框架介绍 - kafkaee - kafkaee的博客

 

分布式框架介绍 - kafkaee - kafkaee的博客

 

分布式框架介绍 - kafkaee - kafkaee的博客

 

分布式框架介绍 - kafkaee - kafkaee的博客

 

分布式框架介绍 - kafkaee - kafkaee的博客
 

zookeeper、dubbo服务启动

分布式框架介绍 - kafkaee - kafkaee的博客

 

分布式框架介绍 - kafkaee - kafkaee的博客
 

dubbo管控台

分布式框架介绍 - kafkaee - kafkaee的博客

 

分布式框架介绍 - kafkaee - kafkaee的博客

 

分布式框架介绍 - kafkaee - kafkaee的博客

 

分布式框架介绍 - kafkaee - kafkaee的博客

 

分布式框架介绍 - kafkaee - kafkaee的博客

 

分布式框架介绍 - kafkaee - kafkaee的博客

 

分布式框架介绍 - kafkaee - kafkaee的博客

 REST服务平台

分布式框架介绍 - kafkaee - kafkaee的博客

 

分布式框架介绍 - kafkaee - kafkaee的博客

 

分布式框架介绍 - kafkaee - kafkaee的博客

 

分布式框架介绍 - kafkaee - kafkaee的博客

 

 

展开阅读全文
加载中

作者的其它热门文章

打赏
1
17 收藏
分享
打赏
3 评论
17 收藏
1
分享
返回顶部
顶部