Docker 运行多个Springboot的详细教程(Docker 运行多个Springboot的详细教程)
Docker 运行多个Springboot的详细教程
Docker 运行多个Springboot的详细教程docker 运行多个Springboot
第一个:端口映射
第二个:指定内存大小
第三个:读取、写入物理文件
第四个:日志文件
第五个:多个容器内部网络访问
第六个:遇到的问题
第一个:端口映射
Nginx使用的是转发,那么这个是最简单的。
[hn@iZbp1gp1t778obaz5m8vk8Z guides]$ docker run -d -p 8093:8093 guides-collect 将物理的端口映射为虚拟的端口即可,这个很简单
第二个:指定内存大小
-m,--memory 内存限制,格式是数字加单位,单位可以为 b,k,m,g。最小为 4M --memory-swap 内存+交换分区大小总限制。格式同上。必须比-m设置的大 --memory-reservation 内存的软性限制。格式同上 --oom-kill-disable 是否阻止 OOM killer 杀死容器,默认没设置 --oom-score-adj 容器被 OOM killer 杀死的优先级,范围是[-1000, 1000],默认为 0 --memory-swappiness 用于设置容器的虚拟内存控制行为。值为 0~100 之间的整数 --kernel-memory 核心内存限制。格式同上,最小为 4M
样例: [hn@iZbp1gp1t778obaz5m8vk8Z guides]$ docker run -d -m 1G --memory-swap 4G -p 8093:8093 guides-collect
第三个:读取物理文件、写入物理文件
上面两个情况启动时就加载,但是运行时需要不断读取本地文件该怎么办嘞 ?
[hn-docker@iZbp1gp1t778obaz5m8vk8Z ~]$ docker run -d -m 1G --memory-swap 4G -p 8092:8092 \ -v /home/hn-docker/docker/wechat:/springboot/wechat \ guides-message message容器的启动相当于是先从把镜像内的文件地址,映射到物理机器上的地址;如 镜像地址:/springboot/wechat 物理地址:/home/hn-docker/docker/wechat
Bind mounts
Bind mounts模式和Volumes非常相似,不同点在于Bind mounts模式是将宿主机上的任意文件或文件夹挂载到容器,而Volumes本质上是将Docker服务管理的一块区域(默认是/var/lib/docker/volumes下的文件夹)挂载到容器。
Bind mounts的使用和Volumes类似,也是通过-v
或--mount
参数将宿主机文件挂载容器中。下面是一个例子:
使用--mount
参数时,需要指定type=bind
:
$ docker run -d \ --name=nginxtest \ --mount type=bind,source=/usr/local/web,destination=/usr/share/nginx/html \ nginx:latest
上面的例子将宿主机上的/usr/local/web文件夹挂载到容器中的/usr/share/nginx/html文件夹。
或者使用-v
参数:
$ docker run -d \ --name=nginxtest \ -v /usr/local/web:/usr/share/nginx/html \ nginx:latest
具体内容请参考:Docker数据存储之Bind mounts详解
第四个:日志文件
第一步:先获取运行容器的ID:da3199e9d032 [hn@iZbp1gp1t778obaz5m8vk8Z guides]$ docker ps CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES da3199e9d032 guides-collect "java -Djava.secur..." 2 hours ago Up 2 hours 0.0.0.0:8093->8093/tcp sharp_mirzakhani 第二步:查询运行日志 - 搞定 [hn@iZbp1gp1t778obaz5m8vk8Z guides]$ docker logs -f 51c384b8afee
参考信息:
命令格式:
$ docker logs [OPTIONS] CONTAINER Options: --details 显示更多的信息 -f, --follow 跟踪实时日志 --since string 显示自某个timestamp之后的日志,或相对时间,如42m(即42分钟) --tail string 从日志末尾显示多少行日志, 默认是all -t, --timestamps 显示时间戳 --until string 显示自某个timestamp之前的日志,或相对时间,如42m(即42分钟)
例子:
查看指定时间后的日志,只显示最后100行:
$ docker logs -f -t --since="2018-02-08" --tail=100 CONTAINER_ID
查看最近30分钟的日志:
$ docker logs --since 30m CONTAINER_ID
查看某时间之后的日志:
$ docker logs -t --since="2018-02-08T13:23:37" CONTAINER_ID
查看某时间段日志:
$ docker logs -t --since="2018-02-08T13:23:37" --until "2018-02-09T12:23:37" CONTAINER_ID
第五个:宿主机与容器网络交互
问题描述:当你docker内运行的springboot想访问宿主机的Redis、获取其他容器的MySQL时,朋友你是否傻眼了
解决方案:需要查询到宿主机容器的软连接ip,使用内网ip访问就ok了 docker inspect -f '{{range .NetworkSettings.Networks}}{{.IPAddress}}{{end}}' xxxid (容器id) 例如: [yn@iZbp1gp1t778obaz5m8vk8Z logs]$ docker ps -a CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES abe77b60254a assistant "java -Djava.secur..." 6 minutes ago Up 6 minutes 0.0.0.0:9304->8091/tcp nostalgic_albattani 37c6dd777636 collect "java -Djava.secur..." 30 hours ago Up 30 hours 0.0.0.0:8093->8093/tcp silly_poincare 4dcb9fcae281 message "java -Djava.secur..." 3 days ago Up 3 days 0.0.0.0:8092->8092/tcp reverent_galileo 比如要查:abe77b60254a 这个容器的网络地址 [yn@iZbp1gp1t778obaz5m8vk8Z logs]$ docker inspect -f '{{range .NetworkSettings.Networks}}{{.IPAddress}}{{end}}' abe77b60254a 172.17.0.4 这个时候: abe77b60254a 这个容器的IP地址就是:172.17.0.4 想访问就走内网地址 172.17.0.4 即可 同时也可得知宿主机的IP就应该是 172.17.0.1
第六个:你会遇到的坑
一:镜像启动失败,然后怎么看日志
启动失败后,需要知道是哪个镜像的ID、然后用日志去查:docker logs -f 镜像id
例如: [yn@iZbp1gp1t778obaz5m8vk8Z logs]$ docker ps -a CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES abe77b60254a assistant "java -Djava.secur..." 6 minutes ago Up 6 minutes 0.0.0.0:9304->8091/tcp nostalgic_albattani 37c6dd777636 collect "java -Djava.secur..." 30 hours ago Up 30 hours 0.0.0.0:8093->8093/tcp silly_poincare 4dcb9fcae281 message "java -Djava.secur..." 3 days ago Up 3 days 0.0.0.0:8092->8092/tcp reverent_galileo 查这个容器日志最新的10行 [yn@iZbp1gp1t778obaz5m8vk8Z ~]$ docker logs -f -t --tail 10 abe77b60254a
二:日志时间或者数据存储至数据库比实际时间小8个小时
RUN /bin/cp /usr/share/zoneinfo/Asia/Shanghai /etc/localtime && echo 'Asia/Shanghai' >/etc/timezone
到此这篇关于Docker 运行多个Springboot的详细教程的文章就介绍到这了,更多相关Docker 运行多个Springboot内容请搜索开心学习网以前的文章或继续浏览下面的相关文章希望大家以后多多支持开心学习网!
- centos装docker稳定吗(Centos8无法安装docker问题的解决方法)
- docker和tomcat建立连接(如何基于Dockerfile构建tomcat镜像)
- Docker 运行多个Springboot的详细教程(Docker 运行多个Springboot的详细教程)
- docker搭建编译开发环境(Shell脚本构建Docker 半自动化编译打包发布应用操作)
- dockerrun执行脚本(docker run和start的区别说明)
- docker装redis(通过Docker部署Redis 6.x集群的方法)
- dockerfile挂载目录(解决docker run中使用 ./ 相对路径挂载文件或目录失败的问题)
- docker启动命令大全(Docker常用命令Study03详解)
- docker 镜像导入导出(Docker镜像的导入导出代码实例)
- docker容器端口和内部进程(Docker动态给容器Container暴露端口操作)
- docker容器的使用过程(详解docker容器的层的概念)
- docker创建mysql环境(docker上部署MySQL的示例)
- linux hadoop client 连接hbase(使用docker部署hbase的方法)
- docker部署golang(如何使用Docker部署Go Web应用的实现)
- idea连接不上docker(IDEA使用Docker插件远程部署项目到云服务器的方法步骤)
- 如何使用docker部署(使用远程Docker进行集成测试的环境搭建过程)
- 硕博期刊 SCI SSCI CSSCI分不清 一文带你看懂主流期刊分类(硕博期刊SCISSCI)
- 辱华品牌新百伦官宣新代言人IU,个别粉丝希望get爱豆同款(辱华品牌新百伦官宣新代言人IU)
- 巅峰时期被爆床照,曾被选国民最讨厌女星,IU不为人知的黑历史(巅峰时期被爆床照)
- 每天1万吨牛奶倒进下水道,美国大萧条一幕重现(每天1万吨牛奶倒进下水道)
- 如何看待美国数十万加仑牛奶倒下水道 历史又重演了(如何看待美国数十万加仑牛奶倒下水道)
- 历史惊人的相似,美国80万加仑牛奶倒入下水道,意味着什么(历史惊人的相似)
热门推荐
- python分支的描述(学习python分支结构)
- ubuntu下vscode的使用教程(Vscode远程连接Ubuntu出错问题的解决方法)
- python使用django搭建简单网页(Python后台开发Django的教程详解启动)
- html5炫酷代码(HTML5实现视频弹幕功能)
- mysql底层原理是什么(MySQL 页完全指南—浅入深出页的原理)
- css3渐变动画(CSS3径向渐变radial-gradient实现波浪边框和内倒角的方法)
- css复选框按钮(css 单选按钮图标替换的方法)
- php数组写法(php文件操作之文件写入字符串、数组的方法分析)
- dedecms栏目页更改(dedecms系统列表页调用tag标签同时带上链接)
- 宝塔面板怎么用ip访问站点(宝塔面板设置禁止通过IP直接访问网站防止恶意解析)
排行榜
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9