docker-compose 一键部署flask+vue+gunicorn+nginx+redis+mongo

上一篇讲述了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://:[email protected]: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执行的一致执行,自动重启

你可能感兴趣的:(docker-compose 一键部署flask+vue+gunicorn+nginx+redis+mongo)