#!/usr/bin/env bash
INPUT=$2 #接收第二个参数(jar文件)
FILE_PATH=`readlink -f ${INPUT}` #获取jar文件的绝对路径
SERVICE=${INPUT##*/}
SERVICE_NAME=${SERVICE%.*}
DAYTIME=$(date -d today +%Y%m%d_%H%M%S)
DEPLOY_DIR=`pwd`
JVM_OPTS="-server -Xms64m -Xmx128m" # java JVM 参数 根据实际情况修改该参数
if [[ "$1" = "" ]];
then
echo -e "\033[0;31m 未输入操作名 \033[0m \033[0;34m {start|stop|restart|status} \033[0m"
exit 1
fi
if [[ "$SERVICE" = "" ]];
then
echo -e "\033[0;31m 未输入应用名 \033[0m"
exit 1
fi
LOGS_DIR="$DEPLOY_DIR/logs/$SERVICE_NAME"
echo "$LOGS_DIR"
if [[ ! -d "$LOGS_DIR" ]]; then
mkdir -p ${LOGS_DIR}
fi
LOG_PATH="$LOGS_DIR/stdout.out"
pid=0
#备份文件
backup()
{
BAC_DIR="$DEPLOY_DIR/bac/$SERVICE_NAME"
echo "$BAC_DIR"
if [[ ! -d "$BAC_DIR" ]]; then
mkdir -p ${BAC_DIR}
fi
cp ${FILE_PATH} "${BAC_DIR}/${SERVICE_NAME}-${DAYTIME}.jar"
echo "$SERVICE_NAME backup succeed"
}
start()
{
checkPid
if [[ ! -n "$pid" ]]; then
BUILD_ID=dontKillMe nohup java ${JVM_OPTS} -jar ${FILE_PATH} >> ${LOG_PATH} 2>&1 &
echo "$SERVICE_NAME is starting you can check the $LOG_PATH"
else
echo "$SERVICE_NAME is runing PID: $pid"
fi
}
checkPid()
{
pid=`ps -ef |grep ${FILE_PATH} |grep -v grep |awk '{print $2}'`
}
stop()
{
checkPid
if [[ ! -n "$pid" ]]; then
echo "$SERVICE_NAME not runing"
else
echo "$SERVICE_NAME stop..."
kill -9 ${pid}
fi
}
restart()
{
stop
sleep 2
start
}
status()
{
checkPid
if [[ ! -n "$pid" ]]; then
echo "$SERVICE_NAME not runing"
else
echo "$SERVICE_NAME runing PID: $pid"
fi
}
debug()
{
JVM_OPT=" -agentlib:jdwp=transport=dt_socket,server=y,suspend=n,address=4000 "
export JAVA_OPTS=" -agentlib:jdwp=transport=dt_socket,server=y,suspend=n,address=4000 "
echo $JVM_OPT
echo ${JAVA_OPTS}
java ${JVM_OPTS} -jar ${FILE_PATH}
}
case $1 in
start) start;;
stop) stop;;
restart) restart;;
debug) debug;;
status) status;;
backup) backup;;
*) echo "require start|stop|restart|status|backup" ;;
esac
- 启动: ./start.sh start xxxx.jar
- debug启动: ./start.sh debug xxxx.jar
- 重启: ./start.sh restart xxxx.jar
- 关闭: ./start.sh stop xxxx.jar
- 备份: ./start.sh backup xxxx.jar
假设物理内存是8G,设置多大堆内存比较合适?
比如说系统有8G物理内存,系统自己可能会用掉一点,大概还有7.5G可以用,那
么建议配置‐Xmx6g。
说明:7.5G*0.8=6G,如果知道系统里有明确使用堆外内存的地方,还需要
进一步降低这个值。
设置的值与JVM进程所占用的内存有什么关系?
JVM总内存=栈+堆+非堆+堆外+Native
开启G1GC
‐XX:+UseG1GC