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的启停部署脚本的更多相关文章

  1. Spring Boot jar包linux服务器部署

    Spring Boot 部署 一.使用命令行java -jar 常驻 nohup java -jar spring-boot-1.0-SNAPSHOT.jar > log.file 2>& ...

  2. Spring Boot Dubbo 应用启停源码分析

    作者:张乎兴 来源:Dubbo官方博客 背景介绍 Dubbo Spring Boot 工程致力于简化 Dubbo | grep tid | grep -v "daemon" tid ...

  3. 居然仅用浏览器,就完成了Spring Boot应用的开发与部署!

    最近有幸试用了一下阿里云的一个新产品:云开发平台,体验一把全新的开发模式!虽然中间也碰到了一些问题,但整体的体验透露着未来感,因为整个过程都不需要使用我们最常用的IDEA,仅依靠浏览器就把一个Spri ...

  4. 编写Redis启停服务脚本

    脚本内容如下; fi   esac   exit$RETVAL 下载脚本:艺搜下载 将下载下来的脚本放在/etc/init.d/目录下 更改脚本权限 chmod 777 /etc/init.d/red ...

  5. Redis windows版本的启停bat脚本命令

    Reids windows版本安装 redis windows官网推荐:https://github.com/MicrosoftArchive/redis/releases 下载解压即可. 启停bat ...

  6. Spring Boot Jar包转War包 部署到Tomcat下

    原文:https://my.oschina.net/sdlvzg/blog/1562998 我们都知道springBoot中已经内置了tomcat,是不需要我们额外的配置tomcat服务器的,但是有时 ...

  7. spring boot jar 部署linux服务器

    用命令启动spring boot 项目,一旦终端命令窗口关闭,项目也就关闭了,所以我们采用脚本的方式来运行jar 正常命令 java -jar xxx.jar 脚本启动,vim 创建 start.sh ...

  8. Spring Boot在Docker上的部署

    一.准备工作 1.1 安装Docker环境 Docker 给旧版本的WIN系统提供的是Docker Toolbox下载(https://docs.docker.com/toolbox/overview ...

  9. Spring boot centos7 后台服务安装部署

    Spring boot 应用服务安装部署(maven工程) 1.首先在maven工程的pom文件中引入以下标签并保存 <build> <plugins> <plugin& ...

  10. 关于spring boot jar包与war包的问题

    此文为转载:http://mrlee23.iteye.com/blog/2047968 在开发调试完成之后,可以将应用打成JAR包的形式,在Eclipse中可以直接使用Maven插件的package命 ...

随机推荐

  1. 11-verilog-有限状态机

    有限状态机 写RTL的时候,实现一个功能的时候有很多种方法 将系统划分为多个状态,状态之间有状态的转移,第一步,第二步......形成有限状态机 流水线技术设计,从输入到输出有多个步骤,多个步骤可以并 ...

  2. [转帖]ipv6相关内核参数配置的优化实践

    https://zhuanlan.zhihu.com/p/605217713 调整ARP缓存大小 这个参数通常需要在高负载的访问服务器上增加.比如繁忙的网络(或网关/防火墙 Linux 服务器),再比 ...

  3. [转帖]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 ...

  4. Nginx arm编译安装

    Nginx arm编译安装 背景 计划编译一套产品. 能够比较方便快捷的进行 nginx的交付. 主要思想是源码编译 不仅能够在arm上面运行 也可以在x86上面编译 考虑性能还有一些扩展性. 高效处 ...

  5. Linux 处理CPU和内存参数的方式总结

    Linux 处理CPU和内存参数的方式总结 关闭NUMA,关闭透明大页 比较简单的方法: vim /etc/default/grub 在 GRUB_CMDLINE_LINUX 里面添加配置: tran ...

  6. 【转帖】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   ...

  7. 使用rpm打包nacos然后部署为systemd服务开机自动启动的方法

    背景 Nacos是阿里开源的服务注册组件,能够简单的实现微服务的注册与发现机制. 但是官方并没有提供 sytemd的服务脚本, 也没有提供rpm包的方式. 公司里面使用 nacos的场景越来越多, 部 ...

  8. canvas实现添加水印

    canvas添加水印思路 1.在画布上写上水印的名称(时间加上用户名) 2.canvas转化为base64,作为body的背景色 3.优化倾斜度和透明度 4.如果用户去除body的style水印消失 ...

  9. js遍历树形结构并返回所有的子节点id值

    场景 很多时候我么需要返回返回tree结构下的所有自己节点 很显然这个时候需要遍历了 废话不多说 直接递归遍历 数据结构 var treeData = [{ id: 111, title: " ...

  10. ClickHouse(22)ClickHouse集成HDFS表引擎详细解析

    HDFS 这个引擎提供了与Apache Hadoop生态系统的集成,允许通过ClickHouse管理HDFS上的数据.这个引擎提供了Hadoop的特定功能. 用法 ENGINE = HDFS(URI, ...