[置顶] 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 全名匹配
6、服务维护注意事项(结合自定义的Shell脚本)
(1) 脚本规范---------尽可能通用
(2) 守护进程
(3) 内存调优设置-----按需调整
(4) 日志处理---------只保留应用Log4j输出的日志
(5) 避免服务冲突 ----进程名、端口
(6) 避免进程误杀-----全匹配
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) 避免进程误杀-----全匹配
相关文章推荐
- dubbo基础篇三_linux部署dubbo服务以及shell脚本编写
- 基于Dubbo的分布式系统架构(五):在Linux操作系统上手工部署Dubbo服务
- Dubbo基础篇--在Linux操作系统上手工部署Dubbo服务
- linux下使用shell脚本自动化部署项目
- [置顶] Linux下eclipse中shell脚本编程环境的搭建
- linux下自定义dubbo的shell脚本
- Dubbo基础篇_05_在Linux操作系统上手工部署Dubbo服务
- 分布式服务框架dubbo-在Linux操作系统上手工部署Dubbo服务(5)
- 跟我学习dubbo-在Linux操作系统上手工部署Dubbo服务(5)
- 跟我学习dubbo-在Linux操作系统上手工部署Dubbo服务(5)
- linux 下部署spring定时任务执行shell脚本,shell脚本执行spoon
- LINUX用户建立秘钥认证实现SHELL脚本管理,分发,部署
- 跟我学习dubbo-在Linux操作系统上手工部署Dubbo服务(5)
- LINUX用户建立秘钥认证实现SHELL脚本管理,分发,部署
- [置顶] 编写shell脚本以及利用函数实现批量安装Linux服务配置
- linux下使用shell脚本自动化部署项目
- Java服务部署上linux主机及shell脚本启停
- [置顶] linux常用命令与shell脚本编程
- 基于Dubbo的分布式系统架构-在Linux操作系统上手工部署Dubbo服务
- Linux下实现SSH免密码登录和实现秘钥的管理、分发、部署SHELL脚本分享