Linux+Docker+SpringBoot 简单部署

1、安装docker

查看docker版本,验证是否验证成功:docker -v

查看docker信息:docker info

2、cmd打包Springboot项目,mvn方式:mvn clean package -Dmaven.test.skip=true

3、服务器设置开放防火墙端口(8025),上传jar包至云服务器文件夹中,并创建dockerfile文件

dockerfile模板:

4、Dockerfile构建镜像

#docker build --f (dockerfile文件路径) --t/-d 镜像名称:版本 .

docker build -f ./gpt_df -t gpt:1.0 .

5、创建容器

#docker run -id -p 主机端口号:容器端口号 --name容器名字 镜像名称:版本

docker run -id -p 8025:8025 --name=gpt_st gpt:1.0

查看正在运行的容器:docker ps

6、测试项目是否运行

ip地址:端口号/访问地址

7、Docker日志配置及日志常用详解

日志存放的位置在/var/lib/docker/containers/

使用docker system df 查看Docker镜像及日志等占用情况

提供一个清理日志的脚本 相当于手动删除日志

echo "======== start clean docker containers logs ========"

logs=$(find /var/lib/docker/containers/ -name *-json.log)

for log in $logs

do

echo "clean logs : $log"

cat /dev/null > $log

done

echo "======== end clean docker containers logs ========"

chmod +x clean_docker_log.sh 增加执行权限

./clean_docker_log.sh 运行脚本

自动空间清理

docker system prune

在docker run的时候加上以下参数 可以控制某个容器生成日志的大小

--log-driver json-file #日志驱动

--log-opt max-size=[0-9+][k|m|g] #文件的大小

--log-opt max-file=[0-9+] #文件数量

--restart=always #服务器重启-容器自动启动

Docker 全局日志控制

#新建/etc/docker/daemon.json 若有就不用新建了 添加log-dirver和log-opts参数

vim /etc/docker/daemon.json

{

"log-driver":"json-file",

"log-opts": {"max-size":"500m", "max-file":"3"}

}

max-size=500m,意味着一个容器日志大小上限是500M,

max-file=3,意味着一个容器有三个日志,分别是id+.json、id+1.json、id+2.json

// 重启docker守护进程

systemctl daemon-reload

systemctl restart docker

tail-f filename:把最新内容刷新显示到屏幕上

docker logs -f <CONTAINER>

tail-n 5 filename :显示最后5行的内容 可以结合-f查看实时日志

docker logs --tail 5 <CONTAINER>

查找所有包含 "error" 的log

docker logs <CONTAINER> | grep error

使用 --since 选项,显示从指定时间点到最新的日志

docker logs --since 2019-10-17T12:01:46.452616Z <CONTAINER>

since指定了开始时间点,还可以指定结束时间点,使用选项 --until,显示二者之间的日志

docker logs --since 2019-10-17T12:01:46.452616Z --until 2019-10-25T12:01:48.561714Z <CONTAINER>

这些选项都可以放在一起使用

docker logs --tail 10 <CONTAINER> | grep info

docker logs -f --since 2019-10-17T12:01:46.452616Z --tail=10 <CONTAINER>

把 error 日志都写到指定文件

docker logs -t <CONTAINER> | grep error >> logs_error.txt

相关推荐
Java之路行者3 小时前
Spring Boot防重复提交实战:让接口安全提升200%!
spring boot·后端·安全
染指秃头4 小时前
VM虚拟机共享宿主机代理(Ubuntu24.04)
linux·运维·服务器
Wang's Blog4 小时前
Linux小课堂: Squid代理缓存服务器部署与访问控制实战指南
linux·服务器·缓存
梁正雄4 小时前
7-linux命令-用户管理
linux
江公望4 小时前
磁盘分区方案GPT和MBR的区别浅谈
linux
---学无止境---5 小时前
Linux中动态修改页面映射属性函数change_page_attr的实现
linux
gfdgd xi5 小时前
GXDE OS 25.2.1 更新了!引入 dtk6,修复系统 bug 若干
linux·运维·ubuntu·操作系统·bug·移植·桌面
qing222222225 小时前
Ubuntu:设置程序开机自启动
linux·运维·ubuntu
Eiceblue6 小时前
使用 Python 向 PDF 添加附件与附件注释
linux·开发语言·vscode·python·pdf