跟我学习dubbo-在Linux操作系统上手工部署Dubbo服务(5)
2016-01-08 03:32
501 查看
在Linux操作系统上手工部署Dubbo服务
1、环境变量配置
Java环境变量----只需要JRE
vi /etc/profile
## java env
export J***A_HOME=/usr/local/java/jdk1.7.0_72
export JRE_HOME=$J***A_HOME/jre
export CLASSPATH=.:$J***A_HOME/lib/dt.jar:$J***A_HOME/li/tools.jar:$JRE_HOME/lib/rt.jar
export PATH=$PATH:$J***A_HOME/bin:$JRE_HOME/bin
source /etc/profile
2、部署目录规范
目的:便于管理,避免应用迁移时的命名冲突。
我定义的目录结构如下(linux)下:
--home ----------linux home目录下
--jeesml -------------用户信息
--jeesml
------------项目类型
--app ------------app应用
--app1 -------------app应用1
--app2... -----------app应用2
--service[b] ----------服务应用[/b]
--service1 ----------服务1
--service2...
[b]---------服务2[/b]
--job
[b]------------定时调度应用[/b]
--job1...
[b][b]------------[/b]定时调度工程
[/b]
--web
[b]------------Web项目工程[/b]
--web1
[b]---------[b][b]Web项目工程[/b]1[/b][/b]
--web2...
[b][b]---------[b][b]Web项目工程2[/b][/b][/b][/b][b][b][/b][/b][b][/b]
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 J***A_HOME=/usr/local/java/jdk1.7.0_72
export JRE_HOME=$J***A_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),一起学习。
1、环境变量配置
Java环境变量----只需要JRE
vi /etc/profile
## java env
export J***A_HOME=/usr/local/java/jdk1.7.0_72
export JRE_HOME=$J***A_HOME/jre
export CLASSPATH=.:$J***A_HOME/lib/dt.jar:$J***A_HOME/li/tools.jar:$JRE_HOME/lib/rt.jar
export PATH=$PATH:$J***A_HOME/bin:$JRE_HOME/bin
source /etc/profile
2、部署目录规范
目的:便于管理,避免应用迁移时的命名冲突。
我定义的目录结构如下(linux)下:
--home ----------linux home目录下
--jeesml -------------用户信息
--jeesml
------------项目类型
--app ------------app应用
--app1 -------------app应用1
--app2... -----------app应用2
--service[b] ----------服务应用[/b]
--service1 ----------服务1
--service2...
[b]---------服务2[/b]
--job
[b]------------定时调度应用[/b]
--job1...
[b][b]------------[/b]定时调度工程
[/b]
--web
[b]------------Web项目工程[/b]
--web1
[b]---------[b][b]Web项目工程[/b]1[/b][/b]
--web2...
[b][b]---------[b][b]Web项目工程2[/b][/b][/b][/b][b][b][/b][/b][b][/b]
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 J***A_HOME=/usr/local/java/jdk1.7.0_72
export JRE_HOME=$J***A_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),一起学习。
相关文章推荐
- 跟我学习dubbo-在Linux操作系统上手工部署Dubbo服务(5)
- 跟我学习dubbo-在Linux操作系统上手工部署Dubbo服务(5)
- Windows IOCP模型与Linux EPOLL模块之比较
- CentOS 6.5(64bit)安装GCC4.8.2+Qt5.2.1(替换GCC的链接库)
- wvware linux NAT 配置
- Git版本服务器搭建(CentOS)--gitblit
- CentOs6.5中安装和配置vsftp简明教程
- Linux开发五_构建根文件系统
- linux socket套接字超时之setsockopt
- Linux开发四_bootloader启动linux内核
- Linux设置socket客户端的连接超时(转)
- linux c socket之异步IO
- linux 设置connect 超时
- Linux Socket编程中的心跳机制
- Linux中设置服务自启动的三种方式
- linux下如何添加一个用户并且让用户获得root权限
- Linux培训之cpio命令详解
- Linux培训之系统升级
- Windows/Linux 下生成Thread Dump的方法
- 【linux】linux基础知识的总结