1.1 docker-compose理论
https://www.cnblogs.com/xiaonq/p/10256414.html
1.什么是docker-compose(what)
- Compose是一个定义和管理多容器的工具,使用Python语言编写。
- 使用Compose配置文件描述多个容器应用的架构,比如使用什么镜像、数据卷、网络、映射端口等;
- 然后一条命令管理所有服务,比如启动、停止、重启等。
2.docker compose作用(where)
- 现在我们要部署django项目,需要 django+mysql+redis+nginx等
- 我们需要开启四个docker容器进行部署每一个组件,如果每个容器单独管理太过于复杂,而且可能是给客户部署项目
- 每一个容器启动都是有说法的,比如celery会使用redis,如果redis没有启动先启动celery服务起不来
- 我们的django项目会使用 mysql、还会使用redis,如果这两个没有启动而先启动django项目,也会报错
- docker compose就是一个可以同时管理一个项目中的多个docker容器的工具,一键部署启动
- 一条命令
- docker-compose -f xxx.yml
3.docker compose安装
[root@linux-node4 ~]# curl -L https://github.com/docker/compose/releases/download/1.15.0/docker-compose-`uname -s`-`uname -m` -o /usr/local/bin/docker-compose
[root@linux-node4 ~]# chmod +x /usr/local/bin/docker-compose
4.docker读写层
[root@linux-node1 84c0e08a8cc81e85b2e6a2508bd7a92920129471ec1f5ad1dfe4187c7571e72d]# ll
total 8
drwxr-xr-x 5 root root 39 Mar 4 20:54 diff # docker容器自己的读写层(只有我们改动的文件在这里)
-rw-r--r-- 1 root root 26 Mar 4 20:54 link
-rw-r--r-- 1 root root 347 Mar 4 20:54 lower
drwxr-xr-x 1 root root 39 Mar 4 20:54 merged # docker真正的工作区
drwx------ 3 root root 18 Mar 4 20:54 work # 项目工作路径
举个例子:我现在安排了十个问题让全班同学去做
- 现在zhanghuisheng做了前六题,huisheng把这个作为模板(就好像我们的docker进行):读层,模板
- 天博要做十个题目:
- 应用zhanghuisheng的前六个题目(merged)
- 天博还要做后面四个题目,他需要把后面四个题目单独放到一个地方区分(diff)
- 天博发现zhanghuisheng有错误要改了,他会zhanghuisheng前六题的文件拷贝到diff(真实文件,不是引用),自己修改
1.2 docker-compose在企业中应用
1.拉取线上代码
$ git clone https://gitee.com/edushiyanlou/django-docker.git
$ docker-compose up -d # 启动所有容器
$ docker-compose logs celery # 查看celery运行日志
$ docker-compose down # 关闭所有容器
启动后访问:http://192.168.56.11
2.部署django程序一般使用那些
- django
- mysql
- celery
- redis
- nginx
1.3 docker-compose配置文件解析
version: '3' # cocker compose版本号
services: # 顶级配置文件(名称自己写)
mysql: # 服务名: 容器建通信、管理容器(mysql这个容器取的名字,也是自己写的)
image: mysql:5.7 # 引入官方mysql镜像(可以大家自己的hub仓库,中大型公司都会自己搭建docker hub仓库)
volumes:
- ./mysql:/var/lib/mysql # 把当前文件夹下的 ./mysql文件夹挂载到docker容器 /var/lib/mysql 路径下
expose:
- "3306" # 将当前容器的端口3306端口暴露给link到本容器的容器
restart: always # 宿主机重启自动拉起这个docker容器
environment:
- MYSQL_ROOT_PASSWORD=root # mysql服务器root密码root
- MYSQL_DATABASE=djangodocker # 创建数据库 djangodocker
- MYSQL_USER=django # 创建一个用户 django
- MYSQL_PASSWORD=django # 用户密码为django
- 单独部署一个nginx
- 安装nginx服务
- 配置nginx.conf
- 配置 /etc/nginx/conf.d/*.conf
- 访问端口
nginx:
image: nginx:alpine
volumes:
- ./nginx/nginx.conf:/etc/nginx/nginx.conf
- ./nginx/conf:/etc/nginx/conf.d
- ./web/staticfiles:/django_static
ports:
- "80:80" # 绑定容器的80端口到主机的80端口
depends_on:
- web # 必须先启动web容器然才能启动nginx容器
redis:
image: redis:alpine
expose:
- "6379"
restart: always
web:
build: .
# command: python manage.py runserver 0:8000
# ports:
# - "8000:8000"
command: uwsgi --ini uwsgi.ini # 启动uwsgi命令
working_dir: /code/web # 项目工作路径
volumes:
- .:/code # 将当前文件夹下所有文件挂载到容器的 /code 文件夹
expose:
- "8000"
depends_on: # 必须mysql和reids容器启动后才能启动web容器
- mysql
- redis
celery:
build: .
command: celery -A web worker -l info
working_dir: /code/web
volumes:
- .:/code
depends_on:
- mysql
- redis