一.知识回顾
之前的内容都帮你整理好了,在这里哟!
【0.Docker相关目录文章整理,可自行查看,包含多节内容】
【1.Docker详细安装部署&阿里镜像地址配置】
【2.Docker架构&&架构角色概念&&角色作用】
【3.Docker命令详细讲解&实操演示】
【4.Docker镜像文件&加载原理&生产中重新制作并提交镜像文件&案例演示】
【5.Docker数据卷&数据卷容器&DockerFile执行流程】
【6.DockerFile构建自定义镜像实操&出现问题解决方案Failed to download metadata for repo ‘appstream‘: IPv4 forwarding disabled…】
【7.详细学习Docker部署搭建高可用的MySQL集群环境】
【8.基于haproxy实现负载均衡之~~~应用Docker部署搭建高可用的MySQL集群环境】
二.Docker安装部署DockerCompose
2.1 DockerCompose相关概念学习
Compose 是用于定义和运行多容器 Docker 应用程序的工具。通过 Compose,您可以使用 YML 文件来配置应用程序需要的所有服务。然后,使用一个命令,就可以从 YML 文件配置中创建并启动所有服务。
DockerCompose的使用步骤:
- 创建容器对应的DockerFile文件
- 创建yml文件,在yml文件中编排我们的服务
- 通过
docker-compose up
命令 一键运行我们的容器
2.2 DockerCompose安装
2.2.1 使用命令下载docker-compose
sudo curl -L "https://github.com/docker/compose/releases/download/1.29.2/docker-compose-$(uname -s)-$(uname -m)" -o /usr/local/bin/docker-compose
如果下载速度过慢使用下面的地址:
curl -L https://get.daocloud.io/docker/compose/releases/download/1.25.0/docker-compose-`uname -s`-`uname -m` > /usr/local/bin/docker-compose
2.2.2 修改文件夹权限
chmod +x /usr/local/bin/docker-compose
2.2.3 建立软连接
ln -s /usr/local/bin/docker-compose /usr/bin/docker-compose
2.2.4 校验是否安装成功
docker-compose --version
三、DockerCompose体验~官网部署案例
3. 1创建对应的目录
mkdir composetest
cd composetest
3.2 创建Python文件 app.py
import time
import redis
from flask import Flask
app = Flask(__name__)
cache = redis.Redis(host='redis', port=6379)
def get_hit_count():
retries = 5
while True:
try:
return cache.incr('hits')
except redis.exceptions.ConnectionError as exc:
if retries == 0:
raise exc
retries -= 1
time.sleep(0.5)
@app.route('/')
def hello():
count = get_hit_count()
return 'Hello World! I have been seen {} times.\n'.format(count)
3.3 在同级目录下创建requirements.txt
文件
flask
redis
3.4 然后创建对应的Dockerfile文件
# syntax=docker/dockerfile:1
FROM python:3.7-alpine
WORKDIR /code
ENV FLASK_APP=app.py
ENV FLASK_RUN_HOST=0.0.0.0
RUN apk add --no-cache gcc musl-dev linux-headers
COPY requirements.txt requirements.txt
RUN pip install -r requirements.txt
EXPOSE 5000
COPY . .
CMD ["flask", "run"]
3.5 然后创建核心的 yml文件docker-compose.yml
version: "3.9"
services:
web:
build: .
ports:
- "5000:5000"
redis:
image: "redis:alpine"
3.6 最终通过docker-compose up
命令来启动容器
docker-compose up
3.7 启动时间比较久,耐心等待即可,启动成功后测试访问:宿主机ip+端口进行访问
3.8 如果要退出服务
Ctrl+c
或者 docker-compose down
四、DockerCompose配置文件
4.1 docker-compse.yml核心配置官网查看手册
version: '' # 版本
servers: # 服务
服务1: web
# 服务的配置
build # 构建我们的dockerfile文件
network # 服务网络地址
images # 服务镜像
服务2: redis
...
# 其他配置 网络,全局的规则 数据卷
volumes:
configs:
networks:
4.2 常见的dockercompose命令
4.2.1 查看版本
docker-compose version
4.2.2 根据yml创建service
# 一键启动命令
docker-compose up
#指定yaml:
docker-compose up -f xxx.yaml
#后台运行:
docker-compose up -d
4.2.3 查看启动成功的service
# 和docker ps同理
docker-compose ps
4.2.4 查看images
docker-compose images
4.2.5 停止/启动service
docker-compose stop/start
4.2.6 删除service[同时会删除掉network和volume]
docker-compose down
4.2.7 进入到某个service
docker-compose exec redis sh
五、DockerCompose部署实战
5.1 DockerCompose部署实战官方案例
5.2 一键部署WP博客
5.2.1 创建my_wordpress目录
mkdir my_wordpress
5.2.2 创建docker-compose.yml
version: "3.1"
services:
db:
image: mysql:5.7
volumes:
- db_data:/var/lib/mysql
restart: always
environment:
MYSQL_ROOT_PASSWORD: somewordpress
MYSQL_DATABASE: wordpress
MYSQL_USER: wordpress
MYSQL_PASSWORD: wordpress
wordpress:
depends_on:
- db
image: wordpress:latest
volumes:
- wordpress_data:/var/www/html
ports:
- "8000:80"
restart: always
environment:
WORDPRESS_DB_HOST: db:3306
WORDPRESS_DB_USER: wordpress
WORDPRESS_DB_PASSWORD: wordpress
WORDPRESS_DB_NAME: wordpress
volumes:
db_data: {}
wordpress_data: {}
5.2.3 通过up命令启动
docker-compose up -d
注意:如果启动过程中出现如下的错误,需要去docker的官方网站上查看docker-compose.yml文件版本信息
解决:这个地方我从3.9改为了3.1版本,重新启动,成功部署。
5.2.4 浏览器访问部署的项目宿主机ip地址+端口
好了,到这里【Docker安装部署DockerCompose&案例演示&配置文件&命令实操学习】就结束了,持续更新中,持续学习中,持续创作中!加油。