compose容器编排工具

1、什么是compose

compose是一个容器编排工具;Compose 是用于定义和运行多容器 Docker 应用程序的工具。通过 Compose,您可以使用 YML 文件来配置应用程序需要的所有服务。然后,使用一个命令,就可以从 YML 文件配置中创建并启动所有服务。

2、安装docker-compose

[root@docker_server ~]# DOCKER_CONFIG=${DOCKER_CONFIG:-$HOME/.docker}
[root@docker_server ~]# mkdir -p $DOCKER_CONFIG/cli-plugins
[root@docker_server ~]# echo $DOCKER_CONFIG
/root/.docker

[root@docker_server ~]# curl -SL https://github.com/docker/compose/releases/download/v2.7.0/docker-compose-linux-x86_64 -o $DOCKER_CONFIG/cli-plugins/docker-compose
(github下载太慢,先下载到本地在用xftp或者rzsz传输上来)
[root@docker_server cli-plugins]# rz -E
rz waiting to receive.
[root@docker_server cli-plugins]# ls
docker-compose
[root@docker_server cli-plugins]# chmod +x docker-compose 
[root@docker_server cli-plugins]# ls
docker-compose
[root@docker_server cli-plugins]# docker compose version
Docker Compose version v2.7.0

3、使用docker-compose

1、定义应用程序依赖项

[root@docker_server cli-plugins]# mkdir /composetest
[root@docker_server cli-plugins]# cd /composetest/
[root@docker_server composetest]# ls
[root@docker_server composetest]# vim app.py
[root@docker_server composetest]# cat 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)

[root@docker_server composetest]# vim requirements.txt
[root@docker_server composetest]# cat requirements.txt 
flask
redis
[root@docker_server composetest]# ls
app.py  requirements.txt

2、创建Dockerfile文件

[root@docker_server composetest]# vim Dockerfile
[root@docker_server composetest]# cat Dockerfile 
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、创建docker-compose.yml定义服务

[root@docker_server composetest]# vim docker-compose.yml
[root@docker_server composetest]# cat docker-compose.yml 
version: "3.9"
services:
  web:
    build: .
    ports:
      - "8000:5000"
  redis:
    image: "redis:alpine"

4、执行docker-compose

只能在有docker-compose.yml或docker-compose.yaml的目录下运行

[root@docker_server composetest]# ls
app.py  docker-compose.yml  Dockerfile  requirements.txt
[root@docker_server composetest]# docker compose up
[+] Building 243.5s (11/11) FINISHED                                                                                                                    
 => [internal] load build definition from Dockerfile                                                                                               0.0s
 => => transferring dockerfile: 348B                                                                                                               0.0s
 => [internal] load .dockerignore                                                                                                                  0.0s
 => => transferring context: 2B                                                                                                                    0.0s
 => [internal] load metadata for docker.io/library/python:3.7-alpine                                                                               4.5s
 => [1/6] FROM docker.io/library/python:3.7-alpine@sha256:94c0a807604a8da09cf6597f11080ad8cdb62f9b4dc1e8cb8134e487f33aa15f                         0.0s
 => [internal] load build context                                                                                                                  0.0s
 => => transferring context: 358B                                                                                                                  0.0s
 => CACHED [2/6] WORKDIR /code                                                                                                                     0.0s
 => CACHED [3/6] RUN apk add --no-cache gcc musl-dev linux-headers                                                                                 0.0s
 => CACHED [4/6] COPY requirements.txt requirements.txt                                                                                            0.0s
 => [5/6] RUN pip install -r requirements.txt                                                                                                    238.2s
 => [6/6] COPY . .                                                                                                                                 0.0s
 => exporting to image                                                                                                                             0.6s 
 => => exporting layers                                                                                                                            0.6s 
 => => writing image sha256:106621b2aead02aecaceeb7948d35ff0b9de044d25507007248692b0295081a9                                                       0.0s 
 => => naming to docker.io/library/composetest_web                                                                                                 0.0s 
[+] Running 3/1                                                                                                                                         
 ⠿ Network composetest_default    Created                                                                                                          0.0s
 ⠿ Container composetest-redis-1  Created                                                                                                          0.0s
 ⠿ Container composetest-web-1    Created                                                                                                          0.0s
Attaching to composetest-redis-1, composetest-web-1
composetest-redis-1  | 1:C 04 Jul 2023 08:41:56.116 # oO0OoO0OoO0Oo Redis is starting oO0OoO0OoO0Oo
composetest-redis-1  | 1:C 04 Jul 2023 08:41:56.116 # Redis version=7.0.11, bits=64, commit=00000000, modified=0, pid=1, just started
composetest-redis-1  | 1:C 04 Jul 2023 08:41:56.116 # Warning: no config file specified, using the default config. In order to specify a config file use redis-server /path/to/redis.conf
composetest-redis-1  | 1:M 04 Jul 2023 08:41:56.116 * monotonic clock: POSIX clock_gettime
composetest-redis-1  | 1:M 04 Jul 2023 08:41:56.117 * Running mode=standalone, port=6379.
composetest-redis-1  | 1:M 04 Jul 2023 08:41:56.117 # WARNING: The TCP backlog setting of 511 cannot be enforced because /proc/sys/net/core/somaxconn is set to the lower value of 128.
composetest-redis-1  | 1:M 04 Jul 2023 08:41:56.117 # Server initialized
composetest-redis-1  | 1:M 04 Jul 2023 08:41:56.117 # WARNING Memory overcommit must be enabled! Without it, a background save or replication may fail under low memory condition. Being disabled, it can can also cause failures without low memory condition, see https://github.com/jemalloc/jemalloc/issues/1328. To fix this issue add 'vm.overcommit_memory = 1' to /etc/sysctl.conf and then reboot or run the command 'sysctl vm.overcommit_memory=1' for this to take effect.
composetest-redis-1  | 1:M 04 Jul 2023 08:41:56.118 * Ready to accept connections
composetest-web-1    |  * Serving Flask app 'app.py'
composetest-web-1    |  * Debug mode: off
composetest-web-1    | WARNING: This is a development server. Do not use it in a production deployment. Use a production WSGI server instead.
composetest-web-1    |  * Running on all addresses (0.0.0.0)
composetest-web-1    |  * Running on http://127.0.0.1:5000
composetest-web-1    |  * Running on http://172.18.0.2:5000
composetest-web-1    | Press CTRL+C to quit
^CGracefully stopping... (press Ctrl+C again to force)
[+] Running 2/2
 ⠿ Container composetest-web-1    Stopped                                                                                                         10.3s
 ⠿ Container composetest-redis-1  Stopped                                                                                                          0.4s
canceled

访问8000端口就可以看到页面内容

4、Wordpress案例

[root@docker_server my_wordpress]# mkdir /my_wordpress
[root@docker_server my_wordpress]# cd /my_wordpress/
[root@docker_server my_wordpress]# ls
docker-compose.yml
[root@docker_server my_wordpress]# vim docker-compose.yml 
[root@docker_server my_wordpress]# cat docker-compose.yml 
services:
  db:
    # We use a mariadb image which supports both amd64 & arm64 architecture
    image: mariadb:10.6.4-focal
    # If you really want to use MySQL, uncomment the following line
    #image: mysql:8.0.27
    command: '--default-authentication-plugin=mysql_native_password'
    volumes:
      - db_data:/var/lib/mysql
    restart: always
    environment:
      - MYSQL_ROOT_PASSWORD=somewordpress
      - MYSQL_DATABASE=wordpress
      - MYSQL_USER=wordpress
      - MYSQL_PASSWORD=wordpress
    expose:
      - 3306
      - 33060
  wordpress:
    image: wordpress:latest
    volumes:
      - wp_data:/var/www/html
    ports:
      - 80:80
    restart: always
    environment:
      - WORDPRESS_DB_HOST=db
      - WORDPRESS_DB_USER=wordpress
      - WORDPRESS_DB_PASSWORD=wordpress
      - WORDPRESS_DB_NAME=wordpress
volumes:
  db_data:
  wp_data:
[root@docker_server my_wordpress]# docker-compose up
[+] Running 2/0

访问80端口就可以看到效果

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值