上一篇讲述了docker部署gunicorn+flask+nginx+vue,对于打包好的镜像,我们还是喜欢如果数据库什么的一起进行一键部署,这是最好不过的了
基于上一篇:
#已有的基础镜像:
--python:3.6
--nginx
--mongo
--redis
# 已经制作完成的项目镜像
--web:1 # 打包好的项目镜像
--vue_index:1 # 打包好的前端镜像
我们现在要做耳朵就是怎么把这些个镜像做成一个docker-compose.yml文件
version: '3'
services:
mongo-db:
image: mongo:latest
container_name: mongo-db
restart: always
ports:
- 27017:27017
environment:
TZ: Asia/Shanghai
MONGO_INITDB_ROOT_USERNAME: admin
MONGO_INITDB_ROOT_PASSWORD: 123456
networks:
- "net1"
volumes:
- /data/mongo:/data/db
my_redis:
image: redis
container_name: my_redis
restart: always
command: redis-server --requirepass 123456
ports:
- "6379:6379"
networks:
- "net1"
volumes:
- /data/redis:/data
web:
image: web:1
container_name: web
restart: always
ports:
- 8000:8000
networks:
- "net1"
volumes:
- /data/web/logs:/web/logs
environment:
TZ: Asia/Shanghai
user_index:
image: vue_index
container_name: user_index
ports:
- 8001:80
networks:
- "net1"
networks:
net1:
driver: bridge
至于yml文件输入格式。可以自行学习。
1、执行顺序
当我们使用docker-compose的时候,配置的文件就是我们执行docker run时候后边执行的命令,就近原则的话,无论我们dockerfile中如何配置镜像的基础文件,docker-compose.yml重写的部分,都会覆盖原来的配置。
2、容器通信
我们在部署的时候,会发现单个容器是有自己的ip的,如果我们的容器想要访问本机的数据库,只能用ip写死。如果我们不用docker-compose启动的话,单个启动查看
首先启动数据库redis
docker run -v $PWD/data:/data -p 6379:6379 --name redis1 -d redis-server
docker ps
查看镜像
root@iZ2zecsx6bxpn51xbj6unsZ:~# docker ps
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
c9c25c9fc29d redis "docker-entrypoint.s…" 2 months ago Up 2 months 0.0.0.0:6379->6379/tcp redis1
docker inspect redis1
拉倒最下边看NetWorks
"Networks": { #无用的不展示
"Gateway": "172.18.0.1",
"IPAddress": "172.18.0.2",
我们会发现,容器已经创建的有虚拟ip"IPAddress": "172.18.0.2",
,其实这个时候我们可以修改web中的配置,把它指定道这个地址也是没问题的redis://:123456@172.18.0.2:6379/0
。但是这样的通信容器每次分配的地址还是不确定的,这不又是需要手动指定嘛。
对于容器的通信有多中通信方式。
在这里docker-compose.yml中使用net_works,在上边docker-compose启动后。
执行:docker network ls
查看各容器的网络状态,查看都注册到bridge上
[centos@ip-172-31-46-235 ~]$ docker network ls
NETWORK ID NAME DRIVER SCOPE
df2a510ce631 bridge bridge local
208d8a925cb3 centos_default bridge local
b4f8d38387bd web_default bridge local
ecd130baa1f5 web_net1 bridge local
c3610f8abebd host host local
12ef161dfbda none null local
549e1ed0e753 test_net1 bridge local
在我们的docker-compose中是已经配置好的,这样如果我们向访问数据库的话我们可以配置redis://:123456@my_redis:6379/0
这里我们就不用配置固定的ip,现在的话就用我们在docker-compose中配置的redis镜像名字进行配置。在容器中会自动解析这个my_redis
为我们容器的ip
重点
1、restart: always
保证容器内的cmd执行的一致执行,自动重启