# 常用shell脚本
# java 启动脚本
#!/bin/sh
if [ -z "$1" ]; then
echo "请在参数中指定进程Id文件的名称!"
exit 1
fi
CURRENT_DIR=$(pwd)
PROJECT_DIR=$CURRENT_DIR"/.."
## echo $PROJECT_DIR
CLASSPATH=
CLASSPATH=$CLASSPATH:$PROJECT_DIR
for i in "$PROJECT_DIR"/lib/*.jar;do
CLASSPATH="$CLASSPATH":"$i"
done
## echo $CLASSPATH
APPNAME=com.cosfuture.eiduo.ctb.CTBServerBootstrap
java -Xms${service.mem} -Xmx${service.mem} -classpath $CLASSPATH $APPNAME >/dev/null 2>&1 &
echo $! > "/var/pid/ctb-service-$1.pid"
echo "started"
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
# java 停止脚本
#!/bin/sh
if [ -z "$1" ]; then
echo "请在参数中指定进程Id文件的名称!"
exit 1
fi
kill -9 `cat "/var/pid/ctb-service-$1.pid"`
rm -f "/var/pid/ctb-service-$1.pid" >/dev/null 2>&1
echo "stoped"
1
2
3
4
5
6
7
8
9
10
11
12
13
2
3
4
5
6
7
8
9
10
11
12
13
# 切换到 es 用户启动 elasticsearch
#!/bin/bash
su - es <<EOF
echo "开始启动 ES1......"
nohup /mnt/es/es1/bin/elasticsearch >/dev/null 2>&1 &
echo "ES1 启动成功......"
sleep 3s
echo "开始启动 ES2......"
nohup /mnt/es/es2/bin/elasticsearch >/dev/null 2>&1 &
echo "ES2 启动成功......"
sleep 3s
echo "开始启动 ES3......"
nohup /mnt/es/es3/bin/elasticsearch >/dev/null 2>&1 &
echo "ES3 启动成功......"
EOF
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
# 批量杀进程脚本
#!/bin/bash
kill -9 $(ps -ef | grep elasticsearch | grep -v grep | awk '{print $2}')
## 杀指定端口
## kill -9 $(netstat -nlp | grep :9200 | awk '{print $7}' | awk -F"/" '{ print $1 }')
exit 0
1
2
3
4
5
6
7
8
2
3
4
5
6
7
8
# 基于docker容器使用Jacoco实现webapp测试覆盖率监控
自行下载jacoco最新版本,主要用到两个jar包:jacocoagent.jar,jacococli.jar 替换JVM参数,把jacoco两个jar包放在tomcat/bin目录,执行定时器设置脚本,auto.sh脚本内容:
# auto.sh
#!/bin/sh
sed -i 's/server/server -javaagent:jacocoagent.jar=includes=com.*,output=tcpserver,port=6300,address=127.0.0.1/g' /usr/local/tomcat/bin/setenv.sh
cd /usr/local/tomcat/bin && rm -rf jacoco*.jar && wget 192.168.195.93:9999/jacocoagent.jar && wget 192.168.195.93:9999/jacococli.jar
cd /usr/local/tomcat/bin && rm -rf auto_dump.sh && wget 192.168.195.93:9999/auto_dump.sh && chmod +x auto_dump.sh
echo '*/10 * * * * /usr/local/tomcat/bin/auto_dump.sh' >> /etc/crontabs/root
crond restart
1
2
3
4
5
6
2
3
4
5
6
每隔10分钟定时导出覆盖率报告,auto_dump.sh脚本内容:
# auto_dump.sh
#!/bin/sh
cd /usr/local/tomcat/webapps
fn=`basename *.war`
name="${fn%%.*}"
mkdir -p /usr/local/tomcat/webapps/jacoco
java -jar /usr/local/tomcat/bin/jacococli.jar dump --address localhost --port 6300 --destfile /usr/local/tomcat/webapps/jacoco/jacoco.exec
echo 'dump success'
java -jar /usr/local/tomcat/bin/jacococli.jar report /usr/local/tomcat/webapps/jacoco/jacoco.exec --html /usr/local/tomcat/webapps/jacoco --classfiles /usr/local/tomcat/webapps/$name/WEB-INF/classes/
echo 'report generate success'
1
2
3
4
5
6
7
8
9
2
3
4
5
6
7
8
9
# 每个容器都要执行以下命令:
RUN echo "cd /usr/local/tomcat/bin && rm -rf auto.sh && wget 192.168.195.93:9999/auto.sh && chmod +x auto.sh" >> /bin/startWeb && echo "/usr/local/tomcat/bin/auto.sh" >> /bin/startWeb
1