#!/bin/bash

#链接文件
source /etc/profile #java虚拟机启动参数
#通过http://xxfox.perfma.com/jvm/check来检查参数的合理性
#各参数详解:http://calvin1978.blogcn.com/?p=1602
JAVA_OPTS="-server @run.memory@"
#使用CMS GC算法
JAVA_OPTS="$JAVA_OPTS -XX:+UseParNewGC -XX:+UseConcMarkSweepGC -XX:+PrintFlagsFinal"
#启动时预申请内存
JAVA_OPTS="$JAVA_OPTS -XX:+AlwaysPreTouch"
#Eden区与2个Survivor区总和的大小比值,8:1:1
JAVA_OPTS="$JAVA_OPTS -XX:SurvivorRatio=8"
#老年代内存占用达到70%触发CMS,这个比例有计算公式
JAVA_OPTS="$JAVA_OPTS -XX:+UseCMSInitiatingOccupancyOnly -XX:CMSInitiatingOccupancyFraction=70"
#在CMS初始标记阶段、重新标记阶段启用并发标记
JAVA_OPTS="$JAVA_OPTS -XX:+ParallelRefProcEnabled -XX:+CMSParallelInitialMarkEnabled -XX:-CMSParallelRemarkEnabled"
#在CMS重新标记阶段之前执行一次Young GC,减少GC Root扫描开销
JAVA_OPTS="$JAVA_OPTS -XX:+CMSScavengeBeforeRemark"
#减少对象在新生代停留时间,加快YGC速度
JAVA_OPTS="$JAVA_OPTS -XX:MaxTenuringThreshold=5"
#在FULL GC的时候执行堆压缩
JAVA_OPTS="$JAVA_OPTS -XX:+UseCMSCompactAtFullCollection -XX:CMSFullGCsBeforeCompaction=0"
# System.gc() 使用CMS算法
JAVA_OPTS="$JAVA_OPTS -XX:+ExplicitGCInvokesConcurrent"
#在OOM时转储堆内存
JAVA_OPTS="$JAVA_OPTS -XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=/data/logs/@project.build.finalName@/"
#应用崩溃时生成一个error文件
JAVA_OPTS="$JAVA_OPTS -XX:ErrorFile==/data/logs/@project.build.finalName@/hs_err_%p.error"
#打印详细GC数据
JAVA_OPTS="$JAVA_OPTS -XX:+PrintTenuringDistribution -XX:+PrintGCApplicationStoppedTime -XX:+PrintPromotionFailure -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 启动脚本优化 3的更多相关文章

  1. java 8 启动脚本优化 2

    #!/bin/bash #链接文件 source /etc/profile #java虚拟机启动参数 #通过http://xxfox.perfma.com/jvm/check来检查参数的合理性 JAV ...

  2. java 8 启动脚本优化

    1 #!/bin/bash 2 3 JAVA_HOME=/usr/java/default 4 5 #java虚拟机启动参数 6 JAVA_OPTS="-server -Xms1366m - ...

  3. 不错的linux下通用的java程序启动脚本

    不错的linux下通用的java程序启动脚本(转载) 虽然写起动shell的频率非常不高...但是每次要写都要对付一大堆的jar文件路径,新加jar包也必须要修改起动shell. 在网上找到一个挺好的 ...

  4. 不错的linux下通用的java程序启动脚本(转载)

    转自:http://www.cnblogs.com/langtianya/p/4164151.html 虽然写起动shell的频率非常不高...但是每次要写都要对付一大堆的jar文件路径,新加jar包 ...

  5. 【转】不错的linux下通用的java程序启动脚本

    虽然写起动shell的频率非常不高...但是每次要写都要对付一大堆的jar文件路径,新加jar包也必须要修改起动shell. 在网上找到一个挺好的通用shell脚本. 只需要修改一些配置变量,就可以用 ...

  6. shell java应用启动脚本(app.sh)

    #!/bin/sh # java服务中需要的jar文件或classpath路径,如业务程序.第三方jar文件log4j等 ShellAbsPath=$(cd "$(dirname " ...

  7. java程序启动脚本

    #!/bin/bash appName=`ls|grep .jar$` if [ -z $appName ] then echo "Please check that this script ...

  8. java后台服务器启动脚本

    最近由于经常在项目上线或者调试中启动服务,由于要设置环境变量这些,所以为了方便写了个启动脚本,希望能够帮助大家,也算是给自己做个小笔记: example_project_start.sh: # /bi ...

  9. linux下启动和终止JAVA程序shell脚本

    1.启动脚本start.sh #run application backgroud nohup java -jar chess-admin->& & #record the pr ...

随机推荐

  1. springboot访问静态资源404

    <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring- ...

  2. es基本概念

    电商实时数据分析平台需要学些什么?  [运营指标,流量指标,销售转化指标,客户价值指标,商品指标,营销指标,风险控制指标,市场竞争指标]等电商指标数据. 检索,数据更新,排序,分词,query等缓存机 ...

  3. ElasticJob分布式任务调度应用v2.5.2

    为何要使用分布式任务调度 **本人博客网站 **IT小神 www.itxiaoshen.com 演示项目源码地址** https://gitee.com/yongzhebuju/spring-task ...

  4. 联盛德 HLK-W806 (三): 免按键自动下载和复位

    目录 联盛德 HLK-W806 (一): Ubuntu20.04下的开发环境配置, 编译和烧录说明 联盛德 HLK-W806 (二): Win10下的开发环境配置, 编译和烧录说明 联盛德 HLK-W ...

  5. redis的RDB和AOF两种持久化机制

    思维导图:我的redis基础知识汇总 RDB持久化机制的优点 (1)RDB会生成多个数据文件,每个数据文件都代表了某一个时刻中redis的数据,这种多个数据文件的方式,非常适合做冷备,可以将这种完整的 ...

  6. 洛谷 P3214 - [HNOI2011]卡农(线性 dp)

    洛谷题面传送门 又是一道我不会的代码超短的题( 一开始想着用生成函数搞,结果怎么都搞不粗来/ll 首先不妨假设音阶之间存在顺序关系,最终答案除以 \(m!\) 即可. 本题个人认为一个比较亮的地方在于 ...

  7. 洛谷 P6788 - 「EZEC-3」四月樱花(整除分块)

    题面传送门 题意: 求 \[\prod\limits_{x=1}^n\prod\limits_{y|x}\frac{y^{d(y)}}{\prod\limits_{z|y}z+1} \pmod{p} ...

  8. 洛谷 P7718 -「EZEC-10」Equalization(差分转化+状压 dp)

    洛谷题面传送门 一道挺有意思的题,现场切掉还是挺有成就感的. 首先看到区间操作我们可以想到差分转换,将区间操作转化为差分序列上的一个或两个单点操作,具体来说我们设 \(b_i=a_{i+1}-a_i\ ...

  9. GWAS初探

    原理 GWAS 的主要方法学依据是归纳法中的共变法,是探究复杂因果关系最主要的科学思维和方法.所谓共变法,是通过考察被研究现象发生变化的若干场合中,确定是否只有一个情况发生相应变化,如果是,那么这个发 ...

  10. 如何利用官方SDK文件来辅助开发

    如何利用官方SDK文件来辅助开发 1.首先要先知道什么是SDK? SDK或者SDK包指的是,半导体厂商针对自己研发的芯片,同步推出的一个软件开发工具包. 它可以简单的为某个程序设计语言提供应用程序接口 ...