一、容器创建脚本
#!/bin/sh
docker ps -a | grep ContainerName &> /dev/null
if [ $? -ne 0 ]; then
docker run -itd --name ContainerName --network host --user $(id -u ${USER}):$(id -g ${USER}) --w /mnt/jar --restart=always -p 9010:9010 -v /etc/localtime:/etc/localtime -v /mnt/docker/workspace:/mnt/jar jdk8 /mnt/jar/gatewayStartup.sh
else
docker restart ContainerName
fi
脚本逻辑:先判断是否存在名称为 ContainerName 的容器,如果不存在则创建,否则则重启该容器.
参数说明:
-itd
--name 指定 容器名称
--network host 指定容器的内网IP,当微服务架构,多台服务器跑docker的时候 ,这里的IP很重要,否则不在相同物理机上的容器不能相互访问,如果是相同服务器,那么不指定这个参数也是可以的。 当然也可以指定外网IP,具体百度。
--user $(id -u ${USER}):$(id -g ${USER})
指定Docker以当前登陆用户创建容器,如果不指定那么容器生成的日志文件就是root的,非root的用户没权限查看
--w /mnt/jar
指定容器的默认工作目录,如果不指定好像是 /usr/local 目录,如果容器跑的项目输出日志为相对路径,就最好指定一下
--restart=always
容器自动重启
-p 9010:9010
指定端口 服务器的端口:容器的端口
挂在目录
-v /etc/localtime:/etc/localtime
-v /mnt/docker/workspace:/mnt/jar
jdk8 /mnt/jar/gatewayStartup.sh
使用jdk8镜像 后面为启动容器后自动启动的脚本,这个脚本是放在宿主机上的,但是用-v 挂载到了容器,所以容器就可以启动宿主机上的文件了。
二、项目启动文件
#!/bin/bash
AppName=/mnt/jar/202111180903/gateway.jar
JVM_OPTS="-Dspring.profiles.active=prod -Duser.timezone=GMT+08 -Dfile.encoding=UTF-8 -Xms512m -Xmx512m -XX:+UseG1GC -XX:+PrintGCDateStamps -XX:+PrintGC -XX:+PrintGCDetails -Xloggc:/mnt/jar/gclog/gateway-%t.log -XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=/mnt/jar/gclog/gateway.hprof"
nohup java -jar $JVM_OPTS $AppName >> gatewayStartup.log 2>&1 &
echo $(date +%F%n%T) Start $AppName success...
tail -f /dev/null
为什么要有这个项目启动文件呢?这样不用每次发布新版本都创建容器,只要修改下启动文件要启动的项目就可以了。这个启动文件是在容器里执行的,所以这里面的路径要写容器内的路径。
-Dspring.profiles.active=prod
在yml文件中可以获取到这个变量,根据这个切换使用的环境
-Duser.timezone=GMT+08
指定时区,如果不指定在中国项目调用时间就会差8个小时
-Dfile.encoding=UTF-8
指定文件编码,如果不指定日志输出中文就会乱码
后面是 jvm的设置,就不多说了
-Xms512m -Xmx512m -XX:+UseG1GC -XX:+PrintGCDateStamps -XX:+PrintGC -XX:+PrintGCDetails -Xloggc:/mnt/jar/gclog/gateway-%t.log -XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=/mnt/jar/gclog/gateway.hprof
Docker不支持使用Tab键补全命令 解决办法: # yum install -y bash-completion 退出系统,重新登录。