java 8 启动脚本优化 2
#!/bin/bash #链接文件
source /etc/profile #java虚拟机启动参数
#通过http://xxfox.perfma.com/jvm/check来检查参数的合理性
JAVA_OPTS="-server @run.memory@"
JAVA_OPTS="$JAVA_OPTS -XX:SurvivorRatio=8 -XX:MaxTenuringThreshold=5 -XX:GCTimeRatio=19 -XX:+UseParNewGC -XX:+UseConcMarkSweepGC -XX:+UseCMSCompactAtFullCollection -XX:-CMSParallelRemarkEnabled -XX:CMSInitiatingOccupancyFraction=70 -XX:SoftRefLRUPolicyMSPerMB=0"
JAVA_OPTS="$JAVA_OPTS -XX:+PrintTenuringDistribution -XX:+PrintClassHistogram -XX:+PrintGCDetails -XX:+PrintGCDateStamps -XX:+PrintHeapAtGC -XX:+UseGCLogFileRotation -XX:NumberOfGCLogFiles=5 -XX:GCLogFileSize=10M -Xloggc:/data/logs/@project.build.finalName@/gc.gclog"
JAVA_OPTS="$JAVA_OPTS -XX:-OmitStackTraceInFastThrow" #JAR包路径
APP_NAME=@project.build.finalName@.jar
#服务暂停后等待时间,默认为120秒
PAUSE_WAIT=120
#进程停止需等待多少秒
SHUTDOWN_WAIT=30 workdir=$(cd $(dirname $0); pwd) #使用说明,用来提示输入参数
usage() {
echo "Usage: sh 执行脚本.sh [start|stop|restart|status]"
exit 1
} #检查程序是否在运行
checkpid(){
pid=`ps -ef|grep $APP_NAME|grep -v grep|awk '{print $2}' `
if [ ! -z "${pid}" ]; then
return 0 # 0=true
fi return 1 # 1=false
} #检查程序端口是否已启动
checkport() {
if checkpid; then
port=$(netstat -ntlp | grep $pid | awk '{printf $4}' | cut -d':' -f4)
if [ ! -z "${port}" ]; then
return 0 # 0=true
else
return 1 # 1=false
fi
else
echo "${APP_NAME} is not running!"
return 1
fi
} checktcp() {
echo "start check connections, $SECONDS." if checkport; then
local count=0;
until [ `netstat -ntp | grep ESTABLISHED | awk -v port=":$port" '$4~port{print}' | wc -l` = '0' ] || [ ${count} -gt ${PAUSE_WAIT} ]
do
if [ `expr ${count} % 5` -eq 0 ]; then
echo "waiting for connections disconnect!"
fi
sleep 1
let count=$count+1;
done if [ ${count} -gt ${PAUSE_WAIT} ]; then
echo "wait for ${PAUSE_WAIT} seconds, still have connetion"
#打印所有的连接
netstat -ntp | grep ESTABLISHED | awk -v port=":$port" '$4~port{print}'
fi
fi
echo "end check connections, $SECONDS."
} #启动方法
start(){
echo "starting ..." if checkpid; then
echo "${APP_NAME} is already running. pid=${pid} ."
else
nohup java $JAVA_OPTS -jar $workdir/$APP_NAME > /dev/null 2>&1 &
fi
} pause() {
if checkport; then
url="http://localhost:$port/actuator/pause"
echo $url local curlRtn=$(curl -s -XPOST $url | cat)
echo "service pause $curlRtn"
fi
} #停止方法
stop(){
echo "stopping ..." if checkpid; then
#停止分为3个步骤:暂停、检测tcp连接、停止进程
pause
checktcp
kill $pid local kwait=$SHUTDOWN_WAIT
local count=0;
until [ `ps -p $pid | grep -c $pid` = '0' ] || [ $count -gt $kwait ]
do
echo "waiting for processes to exit";
sleep 1
let count=$count+1;
done if [ $count -gt $kwait ]; then
echo "killing processes didn't stop after $SHUTDOWN_WAIT seconds"
kill -9 $pid
fi echo "${APP_NAME} stopped."
else
echo "${APP_NAME} is not running"
fi
} #输出运行状态
status(){
if checkpid; then
echo "${APP_NAME} is running. pid is ${pid}"
else
echo "${APP_NAME} is NOT running."
fi
} #重启
restart(){
stop
start
} #根据输入参数,选择执行对应方法,不输入则执行使用说明
case "$1" in
"start")
start
;;
"stop")
stop
;;
"status")
status
;;
"restart")
restart
;;
"check")
checktcp
;;
*)
usage
;;
esac
java 8 启动脚本优化 2的更多相关文章
- java 8 启动脚本优化 3
#!/bin/bash #链接文件 source /etc/profile #java虚拟机启动参数 #通过http://xxfox.perfma.com/jvm/check来检查参数的合理性 #各参 ...
- java 8 启动脚本优化
1 #!/bin/bash 2 3 JAVA_HOME=/usr/java/default 4 5 #java虚拟机启动参数 6 JAVA_OPTS="-server -Xms1366m - ...
- 不错的linux下通用的java程序启动脚本
不错的linux下通用的java程序启动脚本(转载) 虽然写起动shell的频率非常不高...但是每次要写都要对付一大堆的jar文件路径,新加jar包也必须要修改起动shell. 在网上找到一个挺好的 ...
- 不错的linux下通用的java程序启动脚本(转载)
转自:http://www.cnblogs.com/langtianya/p/4164151.html 虽然写起动shell的频率非常不高...但是每次要写都要对付一大堆的jar文件路径,新加jar包 ...
- 【转】不错的linux下通用的java程序启动脚本
虽然写起动shell的频率非常不高...但是每次要写都要对付一大堆的jar文件路径,新加jar包也必须要修改起动shell. 在网上找到一个挺好的通用shell脚本. 只需要修改一些配置变量,就可以用 ...
- shell java应用启动脚本(app.sh)
#!/bin/sh # java服务中需要的jar文件或classpath路径,如业务程序.第三方jar文件log4j等 ShellAbsPath=$(cd "$(dirname " ...
- java程序启动脚本
#!/bin/bash appName=`ls|grep .jar$` if [ -z $appName ] then echo "Please check that this script ...
- java后台服务器启动脚本
最近由于经常在项目上线或者调试中启动服务,由于要设置环境变量这些,所以为了方便写了个启动脚本,希望能够帮助大家,也算是给自己做个小笔记: example_project_start.sh: # /bi ...
- linux下启动和终止JAVA程序shell脚本
1.启动脚本start.sh #run application backgroud nohup java -jar chess-admin->& & #record the pr ...
随机推荐
- mybatis-批量操作数据(list对象 )
在实际工作中老是忘记 传入的参数和数据库参数名称要一致还是与实体类型一致导致很多笑话发生. 那我还是做个记录吧! dao层: int addRemark(@Param("list" ...
- Codeforces 917D - Stranger Trees(矩阵树定理/推式子+组合意义)
Codeforces 题目传送门 & 洛谷题目传送门 刚好看到 wjz 在做这题,心想这题之前好像省选前做过,当时觉得是道挺不错的题,为啥没写题解呢?于是就过来补了,由此可见我真是个大鸽子(( ...
- 8核cpu,,负载
今天有一个电话面试,面试官问我:CentOS怎么查看CPU负载?我说:看top的第一行有load average.面试官又问:为什么从这就判定是负载高呢?依据是什么呢?然后... 然后我就尴尬了,挂了 ...
- Oracle-判断一个表的一列是否在另一张表的一列存在
select * from A where exists(select 1 from B where A.a = B.b)
- Volatile的3大特性
Volatile volatile是Java虚拟机提供的轻量级的同步机制 3大特性 1.保证可见性 当多个线程同时访问同一个变量时,一个线程修改了这个变量的值,其他线程能够立即看得到修改的值 案例代码 ...
- C#数据库连接方式【简版】
using System;using System.Collections.Generic;using System.ComponentModel;using System.Drawing;using ...
- linux 常用查看命令
linux 常用查看命令 目录 linux 常用查看命令 linux 查看内存/进程-ps/top linux 查看磁盘存储-df linux 查看io读写-iotop linux 查看端口占用-ne ...
- day12 keepalived高可用
day12 keepalived高可用 一.高可用介绍 1.什么是高可用 部署在整个集群中的一个高可用软件,作用是创建一个VIP(虚拟IP),在整个集群中有且只有一个机器上生成VIP,当这台机器出现问 ...
- Scala和Java的List集合互相转换
import java.util import scala.collection.mutable /** * 集合互相转换 */ object ScalaToJava { def main(args: ...
- 源码分析-Consumer
消息消费概述 消息消费以组的模式开展,一个消费组内可以包含多个消费者,每一个消费者组可订阅多个主题,消费组之间有集群模式和广播模式两种消费模式. 集群模式,主题下的同一条消息只允许被其中一个消费者消费 ...