网站首页 > java教程 正文
Java项目主机启停脚本示例
启动脚本
示例脚本如下:
# 定义变量
JAVA_HOME=/usr/local/java/jdk1.8.0_301
LOG_HOME=/app/iacctapp/applog/rd-cbn
JVM_ARGS="-XX:-UseAdaptiveSizePolicy -XX:SurvivorRatio=8 -Xms1024m -Xmx1024m"
# 启动项目
nohup ${JAVA_HOME}/bin/java ${JVM_ARGS} -Dloader.path=.,lib,classes -Dacctmgr.ms.instid=funddmdbcbn -jar acctmgr-boot.jar --server.port=32210 >${LOG_HOME}/consoleDmdbFund.log 2>&1 &
# 查看日志
tail -f ${LOG_HOME}/consoleDmdbFund.log
定义变量
- JAVA_HOME:jdk安装目录
- LOG_HOME:程序日志输出目录
- JVM_ARGS:jvm启动参数
启动项目
- nohup :不挂断地运行命令。语法:nohup Command [ Arg … ] [ & ]
- & :在后台运行一般nohup 和&一起用 :nohup command &
- -Dloader.path:jvm加载目录,有多个用逗号分隔
- -Dacctmgr.ms.instid=funddmdbcbn:自定义,方便进程定位
- --server.port:端口暴露
- 2>&1:将标准错误输出重定向到标准输出(屏幕)
名称 | 名称 | 操作符 | Java中表示 |
标准输入(stdin) | 0 | < 或 << | System.in |
标准输出(stdout) | 1 | >, >>, 1> 或 1>> | System.out |
标准错误输出(stderr) | 2 | 2> 或 2>> | System.err |
2>&1一般放在最后,标准错误输出和程序日志才会都写到日志文件中。如果不放到最后,文件中只会输入日志,而标准错误输出是输出到屏幕
linux命令三剑客可参考Linux命令三剑客
查看日志
tail -f:动态输出日志文件内容到屏幕中
停止脚本
示例脚本如下:
#!/bin/bash
# 查找对应进程并杀掉
ps -ef | grep "Dacctmgr.ms.instid=fundcbn"| grep -v grep | awk '{print $2}' | while read processId
do
echo "stop acctmgr process $processId."
kill $processId
done
# 显示杀进程过程与结果
waitTimes=0
while true
do
let waitTimes++
commanderNum=`ps -ef | grep "Dacctmgr.ms.instid=fundcbn"| grep -v grep | wc -l`
if [ ${commanderNum} -eq 0 ]; then
echo "acctmgr process has been stopped."
break;
else
echo "Wait for acctmgr process to exit, waitTimes ${waitTimes} ..."
fi
sleep 1;
done
查找对应进程
ps -ef:用标准的格式显示进程
grep "Dacctmgr.ms.instid=fundcbn":控制ps命令只输出Dacctmgr.ms.instid=fundcbn相关的进程
grep -v grep:过滤掉grep本身进程
awk '{print $2}':每行以空格或分隔符切割,输出第3位(从0计起)
杀进程
while read processId
do
echo "stop acctmgr process $processId."
kill $processId
done
将上面读到的进程杀掉,直到所有进程停止为止
显示杀进程过程与结果
while true
do
let waitTimes++
commanderNum=`ps -ef | grep "Dacctmgr.ms.instid=fundcbn"| grep -v grep | wc -l`
if [ ${commanderNum} -eq 0 ]; then
echo "acctmgr process has been stopped."
break;
else
echo "Wait for acctmgr process to exit, waitTimes ${waitTimes} ..."
fi
sleep 1;
done
该段代码的作用是每隔一秒循环对应进程的扫描,如果的进程还存在对应进程,输出提示语句,直到进程不存在为止
分类: [Linux]
猜你喜欢
- 2024-11-13 Java+Redis 通过Lua 完成库存扣减,创建消息队列,异步处理消息
- 2024-11-13 [每日一题][Redis]为什么Lua脚本可以保证原子性?
- 2024-11-13 python脚本查找java类所属jar包(python 调用jar)
- 2024-11-13 Gradle 6.4 RC4 发布,带来 Java 模块、Groovy DSL 脚本插件
- 2024-11-13 Scala声明变量 定义函数 编写脚本
- 2024-11-13 Javacom英文脚本手写字体(java脚本怎么写)
- 2024-11-13 宝藏脚本!Linux系统快速启动Java应用服务,提升开发效率!
- 2024-11-13 分享一个实用脚本——服务器日志清理脚本
- 2024-11-13 只因知晓Java平台的脚本引擎,面试官当场录用:这小子还不错
- 2024-11-13 Shell编程:命令列表 && 和 ||
你 发表评论:
欢迎- 最近发表
- 标签列表
-
- java反编译工具 (77)
- java反射 (57)
- java接口 (61)
- java随机数 (63)
- java7下载 (59)
- java数据结构 (61)
- java 三目运算符 (65)
- java对象转map (63)
- Java继承 (69)
- java字符串替换 (60)
- 快速排序java (59)
- java并发编程 (58)
- java api文档 (60)
- centos安装java (57)
- java调用webservice接口 (61)
- java深拷贝 (61)
- 工厂模式java (59)
- java代理模式 (59)
- java.lang (57)
- java连接mysql数据库 (67)
- java重载 (68)
- java 循环语句 (66)
- java反序列化 (58)
- java时间函数 (60)
- java是值传递还是引用传递 (62)
本文暂时没有评论,来添加一个吧(●'◡'●)