浅谈近期关于Docker部署产生的一些问题

一、前言

由于这不算正式博客,只是记录当下使用Docker时产生的一些小问题,所以我不会用严格的格式去讲,只是作为一个小随笔去记录。

二、Docker-compose

前面我也使用过docker-compose,但是用得不够熟练,以前确实是没啥问题的,毕竟当时虚拟机上装的也就那么一两个项目所需的容器,而且多半都是mysql、redis这些最常用的容器,所以我当时就懒得去动了,直接几个项目共用同一个容器,几个月以来也是没出什么大问题的。

但是现在问题就来了,到现在我已经有五六个项目需要共用同一个容器了,所以我痛定思痛,决定不能懒了,要拆出来了,事实上本来就应该拆除,全怪我前面太懒了。

所以现在重新来熟悉docker-compose,首先docker-compose本来就是为了便于创建容器的一个工具,只需要把所有的命令写在一个yml文件上,就能同时拉取没有的镜像并且按照指令创建对应容器,同时将对这些容器进行统一管理。

docker-compose有几个特性:

1.如果本地没有镜像,就会自动拉镜像(这和普通的指令是一样的)。

2.整个docker-compose的名字由yml文件所在文件夹名来命名。

3.容器如果没有手动设置名字就自动生成默认的名字。(格式是文件夹名+服务名+序号)

因此由于这几个特性,我们创建的步骤也应该规范:

1.在虚拟机中创建一个文件夹,名字为项目的名称(文件夹的根目录尽量在opt/)

2.检查docker-compose.yml中容器的名字是否手动设置(这里建议保持自动,这样就可以避免冲突问题,一会儿会提到)

3.将docker-compose.yml复制到虚拟机中的项目文件夹中

4.cd到项目文件夹,运行指令,自动创建容器。

这里有几个点需要注意:

1.容器名冲突的问题,docker-compose看上去是和其他容器分隔开的,但是事实上,只要是在同一个docker中的容器都算一个整体,因此就不允许出现两个同名容器,所以docker-compose中的容器名也不能和外面的容器名冲突。

比如下面两个容器名就不能冲突:

所以这里为啥我建议自动生成容器名,因为默认策略会根据文件夹名来命名,同时也不要担心认不到服务是哪个,因为docker-compose下面有两级目录,第一级是以服务名命名的,点开第一级目录才是容器(显示真正的容器名)

至于执行命令应该如下:(新版的,老板命令是docker-compose -f)

bash 复制代码
docker compose -f docker-compose-xxx.yml up -d

最后呢建议还是尽量去使用Docker-compose,因为他还有个好处,就是一旦对容器配置有改动,直接修改docker-compose.yml文件内容即可,然后重新执行一次命令就行了,很方便。

如果是按照以前的做法,就必须要把容器删了,然后重新写命令行(更麻烦的是由于不是用文件装的命令,以前的命令多半都不见了,这就导致要重新写了)

相关推荐
爱喝水的鱼丶1 小时前
SAP-ABAP:变量、常量、结构与内表声明(10篇博客合集) 第六篇:ABAP 7.40+新特性:声明语法的简化写法与兼容注意事项
运维·服务器·开发语言·学习·算法·sap·abap
青梅橘子皮1 小时前
Linux---进程状态与优先级
linux·运维·服务器
日取其半万世不竭2 小时前
给 Docker 容器设置 CPU 和内存限制,避免单个服务拖垮整机
java·docker·容器
H Journey2 小时前
Linux VIM介绍与常用命令
linux·运维·vim
bukeyiwanshui2 小时前
20260526 综合实践:企业网站上云部署实践
运维·服务器
齐潇宇2 小时前
DevOps介绍与工具链全解析
运维·devops·cicd
Arik~朽木2 小时前
Ubuntu 安装指南
linux·运维·ubuntu
IMPYLH2 小时前
Linux 的 yes 命令
linux·运维·服务器·数据库·bash
独钓寒江雨3 小时前
SRH介绍
运维·网络·srv6