适用于Spring Boot Jar的启停部署脚本
shell脚本参数
使用-z或-n对一个变量判空时, 若直接使用[ -n ARG ]这种形式,当{ARG}中有空格将会报错,
line 27: [: sd: binary operator expected
需要使用
[[ -n ${ARG} ]] 或 [ -n "${ARG}" ]
完整脚本
# Please define the absolute path of tomcat instance
JAVA_HOME=/opt/jdk/latest
BASE_DIR=/home/tomcat
JAVA_OPTS="-server -Xms512m -Xmx512m -XX:MaxNewSize=256m -Djava.awt.headless=true"
EXTRA_OPTS=""
TC_ERROR=0
start() {
echo -n "[$(date +%Y%m%d-%H%M%S)] Start: "
pid=`ps -ef|grep $1|grep -v 'grep'|grep 'java'|awk '{print $2}'`
if [ -z ${pid} ] ; then
if [ ! -e ${JAVA_HOME}/bin/java ]; then
echo ${JAVA_HOME} ' is not a valid JAVA_HOME path'
exit 2
fi
echo JAVA_HOME:${JAVA_HOME}, JAR:$1, port:$2
nohup ${JAVA_HOME}/bin/java ${JAVA_OPTS} -jar $1 --server.port=$2 ${EXTRA_OPTS} >/dev/null 2>&1 &
else
echo $1' is running at pid: '${pid}
fi
}
stop() {
echo -n "[$(date +%Y%m%d-%H%M%S)] Stop: "
pid=`ps -ef|grep $1|grep -v 'grep'|grep 'java'|awk '{print $2}'`
if [ -z $pid ] ; then
echo $1' is not running'
else
echo $1' is running at pid:'${pid}
kill $pid
sleep 5
fi
pid=`ps -ef|grep $1|grep -v 'grep'|grep 'java'|awk '{print $2}'`
if [ -z $pid ] ; then
echo 'Done'
else
echo 'Still running, now killing with pid:'${pid}
ps -ef|grep $1|grep -v 'grep'|grep 'java'|awk '{print $2}'|xargs kill -s 9
fi
}
restart() {
stop $1
start $1 $2
}
deploy() {
# -f filename - Check for regular file existence not a directory
[ -f ${BUILD_DIR}/$JAR_FILE ] || exit 1
stop $1
df -h
echo ''
echo -n "[$(date +%Y%m%d-%H%M%S)] Deploy: "
if [ -e $1 ]; then
echo -n "remove $1... "
rm $1
fi
echo -n "copy... "
cp -f ${BUILD_DIR}/$JAR_FILE ${RUN_DIR}/$JAR_FILE
echo 'done'
start $1 $2
}
help_func() {
echo "Usage:"
echo " $0 [-d BASE_DIR] [-j JAVA_HOME] [-f JAR_FILE] [-p PORT] [-m ACT_MODE] [-v VM_OPTION]"
echo "Description:"
echo "-d Path of the workspace, optional, default: $BASE_DIR"
echo "-f The jar file name, e.g. my-project.jar"
echo "-j Path to JDK home, optional, default: $JAVA_HOME"
echo "-m Action mode, e.g. start, restart, stop, etc."
echo "-p Service port, e.g. 8080"
echo "-e extra jar arguments, e.g. --asp.root_path=/path"
echo "-v JAVA_OPTS, optional, default: $JAVA_OPTS"
echo ""
echo "Examples:"
echo " $0 -f asp-commons.jar -p 8761 -m restart"
exit 0
}
# 如果字符后面没有冒号, 说明该字符的选项不需要值, 如 -i
# 如果字符后面跟着一个冒号, 表明该字符的选项需要一个值, 其参数和值之间需要空格分隔, 如 -j aaa.jar, 冒号和问号不能被用作选项字符
# getopts每次被调用时, 会将下一个选项字符放置到变量中, 通过OPTARG可以取到参数值
# 如果option前面加冒号, 代表忽略错误
while getopts 'd:e:j:f:m:p:v:h' OPT; do
case $OPT in
d) BASE_DIR="$OPTARG";;
f) JAR_FILE="$OPTARG";;
j) JAVA_HOME="$OPTARG";;
m) ACT_MODE="$OPTARG";;
p) PORT="$OPTARG";;
v) JAVA_OPTS="$OPTARG";;
e) EXTRA_OPTS="$OPTARG";;
h) help_func $0;;
?) help_func $0;;
esac
done
shift $(($OPTIND - 1))
# Print helpFunction in case parameters are empty
if [ -z "$ACT_MODE" ]
then
echo "Parameter -m is missing";
TC_ERROR=1
fi
if [ -z "$JAR_FILE" ]
then
echo "Parameter -f is missing";
TC_ERROR=1
fi
if [ $TC_ERROR -gt 0 ]
then
help_func
fi
RUN_DIR=${BASE_DIR}/run
BUILD_DIR=${BASE_DIR}/builds
ARCHIVE_DIR=${BASE_DIR}/archives
TMP_DIR=${BASE_DIR}/tmp
# -e Check for file existence regardless of type (node, directory, socket)
#if [ ! -e ${RUN_DIR}/${JAR_FILE} ]; then
# echo ${RUN_DIR}/${JAR_FILE} 'does not exist'
# exit 2
#fi
case "$ACT_MODE" in
start)
# -e Check for file existence regardless of type (node, directory, socket)
if [ ! -e ${RUN_DIR}/${JAR_FILE} ]; then
echo ${RUN_DIR}/${JAR_FILE} 'does not exist'
exit 2
fi
if [ -z "$PORT" ]
then
echo "Parameter -p is missing";
exit 2
fi
start ${RUN_DIR}/${JAR_FILE} $PORT
;;
stop)
stop ${RUN_DIR}/${JAR_FILE}
;;
restart)
restart ${RUN_DIR}/${JAR_FILE} $PORT
;;
deploy)
deploy ${RUN_DIR}/${JAR_FILE} $PORT
;;
*)
echo "Unknown action mode"
help_func
esac
使用方式
指定jvm参数
./scripts/tc2.sh -f ap-program.jar -m deploy -p 8082 -v "-server -Xms512m -Xmx512m -XX:MaxNewSize=256m -Djava.awt.headless=true -Dspringfox.documentation.enabled=true"
指定jar的启动参数, 对于参数值为空的参数, 两个引号需要转义一下
./scripts/tc2.sh -f ap-website2.jar -m restart -p 8090 -e "--ap.root_path=\"\" --ap.resource_path=/static --server.servlet.context-path=/"
适用于Spring Boot Jar的启停部署脚本的更多相关文章
- Spring Boot jar包linux服务器部署
Spring Boot 部署 一.使用命令行java -jar 常驻 nohup java -jar spring-boot-1.0-SNAPSHOT.jar > log.file 2>& ...
- Spring Boot Dubbo 应用启停源码分析
作者:张乎兴 来源:Dubbo官方博客 背景介绍 Dubbo Spring Boot 工程致力于简化 Dubbo | grep tid | grep -v "daemon" tid ...
- 居然仅用浏览器,就完成了Spring Boot应用的开发与部署!
最近有幸试用了一下阿里云的一个新产品:云开发平台,体验一把全新的开发模式!虽然中间也碰到了一些问题,但整体的体验透露着未来感,因为整个过程都不需要使用我们最常用的IDEA,仅依靠浏览器就把一个Spri ...
- 编写Redis启停服务脚本
脚本内容如下; fi esac exit$RETVAL 下载脚本:艺搜下载 将下载下来的脚本放在/etc/init.d/目录下 更改脚本权限 chmod 777 /etc/init.d/red ...
- Redis windows版本的启停bat脚本命令
Reids windows版本安装 redis windows官网推荐:https://github.com/MicrosoftArchive/redis/releases 下载解压即可. 启停bat ...
- Spring Boot Jar包转War包 部署到Tomcat下
原文:https://my.oschina.net/sdlvzg/blog/1562998 我们都知道springBoot中已经内置了tomcat,是不需要我们额外的配置tomcat服务器的,但是有时 ...
- spring boot jar 部署linux服务器
用命令启动spring boot 项目,一旦终端命令窗口关闭,项目也就关闭了,所以我们采用脚本的方式来运行jar 正常命令 java -jar xxx.jar 脚本启动,vim 创建 start.sh ...
- Spring Boot在Docker上的部署
一.准备工作 1.1 安装Docker环境 Docker 给旧版本的WIN系统提供的是Docker Toolbox下载(https://docs.docker.com/toolbox/overview ...
- Spring boot centos7 后台服务安装部署
Spring boot 应用服务安装部署(maven工程) 1.首先在maven工程的pom文件中引入以下标签并保存 <build> <plugins> <plugin& ...
- 关于spring boot jar包与war包的问题
此文为转载:http://mrlee23.iteye.com/blog/2047968 在开发调试完成之后,可以将应用打成JAR包的形式,在Eclipse中可以直接使用Maven插件的package命 ...
随机推荐
- 11-verilog-有限状态机
有限状态机 写RTL的时候,实现一个功能的时候有很多种方法 将系统划分为多个状态,状态之间有状态的转移,第一步,第二步......形成有限状态机 流水线技术设计,从输入到输出有多个步骤,多个步骤可以并 ...
- [转帖]ipv6相关内核参数配置的优化实践
https://zhuanlan.zhihu.com/p/605217713 调整ARP缓存大小 这个参数通常需要在高负载的访问服务器上增加.比如繁忙的网络(或网关/防火墙 Linux 服务器),再比 ...
- [转帖]CentOS-7-x86_64-Everything-2009 rpm包列表(CentOS7.9)
CentOS-7-x86_64-Everything-2009 rpm包列表(CentOS7.9) 共10073个文件 复制389-ds-base-1.3.10.2-6.el7.x86_64.rpm ...
- Nginx arm编译安装
Nginx arm编译安装 背景 计划编译一套产品. 能够比较方便快捷的进行 nginx的交付. 主要思想是源码编译 不仅能够在arm上面运行 也可以在x86上面编译 考虑性能还有一些扩展性. 高效处 ...
- Linux 处理CPU和内存参数的方式总结
Linux 处理CPU和内存参数的方式总结 关闭NUMA,关闭透明大页 比较简单的方法: vim /etc/default/grub 在 GRUB_CMDLINE_LINUX 里面添加配置: tran ...
- 【转帖】What are segfault rip/rsp numbers and how to use them
https://stackoverflow.com/questions/1456899/what-are-segfault-rip-rsp-numbers-and-how-to-use-them ...
- 使用rpm打包nacos然后部署为systemd服务开机自动启动的方法
背景 Nacos是阿里开源的服务注册组件,能够简单的实现微服务的注册与发现机制. 但是官方并没有提供 sytemd的服务脚本, 也没有提供rpm包的方式. 公司里面使用 nacos的场景越来越多, 部 ...
- canvas实现添加水印
canvas添加水印思路 1.在画布上写上水印的名称(时间加上用户名) 2.canvas转化为base64,作为body的背景色 3.优化倾斜度和透明度 4.如果用户去除body的style水印消失 ...
- js遍历树形结构并返回所有的子节点id值
场景 很多时候我么需要返回返回tree结构下的所有自己节点 很显然这个时候需要遍历了 废话不多说 直接递归遍历 数据结构 var treeData = [{ id: 111, title: " ...
- ClickHouse(22)ClickHouse集成HDFS表引擎详细解析
HDFS 这个引擎提供了与Apache Hadoop生态系统的集成,允许通过ClickHouse管理HDFS上的数据.这个引擎提供了Hadoop的特定功能. 用法 ENGINE = HDFS(URI, ...