0
点赞
收藏
分享

微信扫一扫

docker进阶一:Compose介绍


文章目录

  • ​​一、介绍:高效管理容器​​
  • ​​二、使用​​
  • ​​2安装​​
  • ​​3授权​​
  • ​​4查看版本​​
  • ​​5体验​​
  • ​​2.5.1第一步: 创建一个文件夹​​
  • ​​2.5.2第二步:创建Python文件夹并且书写代码​​
  • ​​2.5.3 第三步:在同一个目录下写一个txt​​
  • ​​2.5.4 第四步:在同一个目录下写一个DockerFile​​
  • ​​2.5.5 第五步:在同一个目录下写一个yml(用于部署)​​
  • ​​2.5.6第六步:在当前文件夹运行​​
  • ​​小结​​
  • ​​三.yml规则​​
  • ​​四、体验一键部署微博​​
  • ​​4.1进入文件夹 cd my_wordpress/​​
  • ​​4.2 Create a docker-compose.yml​​
  • ​​4.3启动docker-compose up -d​​

一、介绍:高效管理容器

docker进阶一:Compose介绍_docker


docker进阶一:Compose介绍_docker_02


docker进阶一:Compose介绍_redis_03

Compose 是Docker的开源项目,需要安装

docker进阶一:Compose介绍_flask_04


docker进阶一:Compose介绍_运维_05

二、使用

2安装

sudo curl -L "https://github.com/docker/compose/releases/download/1.26.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.5/docker-compose-'uname -s'-'uname-m' > /usr/local/bin/docker-compose

3授权

chmod +x /usr/local/bin/docker-compose

4查看版本

docker-compose version

docker进阶一:Compose介绍_redis_06

5体验

getting start体验
官方地址:https://docs.docker.com/compose/gettingstarted/
python应用,计数器,redis

2.5.1第一步: 创建一个文件夹

mkdir conposetest
cd conposetest

2.5.2第二步:创建Python文件夹并且书写代码

vim 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)

2.5.3 第三步:在同一个目录下写一个txt

vim requirements.txt

flask
redis

2.5.4 第四步:在同一个目录下写一个DockerFile

vim 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"]

2.5.5 第五步:在同一个目录下写一个yml(用于部署)

vim docker-compose.yml

version: "3.9"
services:
web:
build: .
ports:
- "5000:5000"
redis:
image: "redis:alpine"

2.5.6第六步:在当前文件夹运行

docker-compose up

docker进阶一:Compose介绍_运维_07


docker进阶一:Compose介绍_容器_08

小结

1、应用 app.py
2、Dockerfile 应用打包为镜像
3、Docker-compose yml 文件(定义整个服务需要的环境:web, redis)
4、启动compose项目(docker-compose up)

默认的服务名 文件名_服务名_num
多个服务器 集群 A B _num副本数量
服务redis服务 =》4个副本
集群状态,服务都不可能只有一个运行实例。弹性

网络规则:
项目中的内容都在同个网络下。可通过名称访问(需要在同一网络下),保证了高可用

停止:docker-compose down ctrl+c

以前都是单个docker run启动容器,docker-compose通过yml配置文件,可以通过compose一键启动所有服务、停止

三.yml规则

docker进阶一:Compose介绍_flask_09


docker进阶一:Compose介绍_容器_10


docker进阶一:Compose介绍_flask_11

四、体验一键部署微博

官方网址

https://docs.docker.com/samples/wordpress/

4.1进入文件夹 cd my_wordpress/

4.2 Create a docker-compose.yml

version: "3.9"

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: {}

4.3启动docker-compose up -d

docker-compose up -d 后台启动
docker-compose up 启动

docker进阶一:Compose介绍_运维_12

docker进阶一:Compose介绍_运维_13


举报

相关推荐

0 条评论