Linux6.14 Docker Compose容器编排

news/2024/11/28 6:41:41/

文章目录

  • 计算机系统
    • 5G云计算
      • 第四章 LINUX Docker Compose容器编排
        • 一、Compose概述
          • 1.Docker Compose 的概述
          • 2.Docker Compose 三大的概念
        • 二、部署过程
          • 1.Docker Compose 环境安装
          • 2.YAML 文件格式及编写注意事项
          • 3.Docker Compose配置常用字段
          • 4.Docker Compose 常用命令
          • 5.Docker Compose 文件结构
          • 6.配置
            • 1)准备依赖文件
            • 2)编写配置文件docker-compose.yml

计算机系统

5G云计算

第四章 LINUX Docker Compose容器编排

一、Compose概述

1.Docker Compose 的概述

Docker-Compose项目是基于Python开发的Docker官方开源项目,负责实现对Docker容器集群的快速编排。Docker-Compose项目由Python编写,调用Docker服务提供的API来对容器进行管理。因此,只要所操作的平台支持Docker API, 就可以在其上利用Compose来进行编排管理

Docker Compose 是一个用于定义和运行多容器Docker应用程序的工具。它允许用户使用YAML文件来定义应用程序的配置,包括容器的数量、容器之间的依效关系、环境变量、端口映射以及其他设置。然后,用户可以使用docker-compose命令来启动和管理这些容器

使用 Docker Compose 可以方便地管理多个容器,例如,可以同时启动一个Web服务器容器和一个数据库容器,并在它们之间建立网络连接。Docker Compose 还支持自定义网络,使得容器可以在不同的网络中进行通信

Docker Compose文件通常包含一个或多个服务,每个服务都由一个或多个容器组成。服务定义了容器应该执行的任务,以及容器之间的依赖关系。例如,一个Web服务器服务可以包含一个或多个web 服务器容器,而这些容器又依赖于一个数据库容器

2.Docker Compose 三大的概念

Docker-Compose 将所管理的容器分为三层,分别是项目(project)、服务(service)以及容器(container)

Docker-Compose 运行目录下的所有文件组成一个项目,若无特殊指定项目名即为当前目录名

一个工程当中可包含多个服务,每个服务都包含一个名称、镜像、端口映射、环境变量、挂载点等信息

Docker-Compose 的项目配置文件默认为 docker-compose.yml,可通过环境变量 COMPSE_FILE 或 -f 参数自定义配置文件,其定义了多个有依赖关系的服务及每个服务运行的容器

Compose 允许用户通过一个单独的 docker-compose.yml 模板文件(AM格式)来定义一组相关联的应用容器为一个项目(project)

二、部署过程

1.Docker Compose 环境安装

Docker Compose 是 Docker 的独立产品,因此需要安装 Docker 之后在单独安装 Docker Compose

###下载
curl -L https://github.com/docker/compose/releases/download/1.21.1/docker-compose-`uname -s`-`uname -m` -o /usr/local/bin/docker-compose
###安装
chmod +x /usr/local/bin/docker-compose
###查看版本
docker-compose --version

在这里插入图片描述

2.YAML 文件格式及编写注意事项

YAML 是一种标记语言,它可以很直观的展示数据序列化格式,可读性高。类似于 json 数据描述语言,语法比 json 简单的很多。YAML 数据结构通过缩进来表示,连续的项目通过减号来表示,键值对用冒号分隔,数组用中括号 [] 括起来, hash 用花括号 {} 括起来

使用 YAML 时需要注意下面事项

注意事项
大小写敏感
通过缩进表示层级关系
不支持制表符 tab 键缩进,只能使用空格缩进
缩进的空格数目不重要,只要相同层级左对齐,通常开头缩进2个空格
用 # 号注释
符号字符后缩进1个空格,如冒号 : 、逗号 , 、横杠 -
如果包含特殊字符用单引号(‘’)引起来会作为普通字符串处理,双引号(“”): 特殊字符作为本身想表示的意思
3.Docker Compose配置常用字段
字段描述
build指定 Dockerfile 文件名,要指定Dockerfile文件需要在build标签的子级标签中使用dockerfile标签指定
dockerfile构建镜像上下文路径
context可以是 dockerfile 的路径,或者是指向 git 仓库的 url 地址
image指定镜像
command执行命令,覆盖容器启动后默认执行的命令
container_name指定容器名称,由于容器名称是唯一的,如果指定自定义名称,则无法scale指定容器数量
deploy指定部署和运行服务相关配置,只能在 Swarm 模式使用
environment添加环境变量
networks加入网络,引用顶级networks下条目
network_mode设置容器的网络模式,如 host,bridge,…
ports暴露容器端口,与 -p 相同,但端口不能低于 60
volumes挂载一个宿主机目录或命令卷到容器,命名卷要在顶级 volumes 定义卷名称
volumes_from从另一个服务或容器挂载卷,可选参数 :ro 和 :rw,仅版本 ‘2’ 支持
hostname容器主机名
sysctls在容器内设置内核参数
links连接到另外一个容器,- 服务名称[:服务别名]
privileged用来给容器root权限,注意是不安全的,true | false
restart设置重启策略,no,always,no-failure,unless-stopped
depends_on在使用Compose时,最大的好处就是少打启动命令,但一般项目容器启动的顺序是有要求的,如果直接从上到下启动容器,可能会因为容器依赖问题而启动失败。例如在没启动数据库容器的时候启动应用容器,应用容器会因为找不到数据库而退出depends_on标签用于解决容器的依赖、启动先后的问题
php:
depends_on:
- apache
- mysql
4.Docker Compose 常用命令
字段描述
build重新构建服务
ps列出容器
up创建和启动容器
exec在容器里面执行命令
scale指定一个服务容器启动数量
top显示正在运行的容器进程
logs查看服务容器的输出
down删除容器、网络、数据卷和镜像
stop/start/restart停止/启动/重启服务
5.Docker Compose 文件结构
yum install -y tree
tree /opt/compose_nginx
/opt/compose_nginx/
├── docker-compose.yml				#创建模板脚本
├── nginx├── Dockerfile					#创建容器脚本├── nginx-1.24.0.tar.gz			#复制源码包└── html└── index.html			    #站点网页└── wordpress               #论坛目录
6.配置
1)准备依赖文件
###用上一篇LNMP的配置和目录及文件准备Docker Compose的二进制文件,上传后修改权限并移动到/usr/local/bin目录下
cd /opt
docker-compose
chmod +x docker-compose
mv docker-compose /usr/local/bin/

在这里插入图片描述

2)编写配置文件docker-compose.yml
vim /opt/mylnmp/docker-compose.yml
version: '3'
services:nginx:build:context: ./nginxdockerfile: Dockerfilecontainer_name: nginxports:- 80:80volumes :- ./nginx/html:/usr/local/nginx/htmlnetworks:lnmp :ipv4_address: 172.18.0.10mysql:#build:#  context: ./mysgl#  dockerfile: Dockerfileimage: mysql:lnmpcontainer_name: mysqlports:- 3306:3306volumes :- db-data:/usr/local/mysqlnetworks:lnmp :ipv4_address: 172.18.0.20privileged: truephp:#build:#  context: ./php#  dockerfile: Dockerfileimage: php:lnmpcontainer_name: phpports:- 9000:9000volumes :- db-data:/usr/local/mysql- ./nginx/html:/usr/local/nginx/htmlnetworks:lnmp :ipv4_address: 172.18.0.30depends_on:- nginx- mysqlnetworks:lnmp :driver: bridgeipam:config:- subnet: 172.18.0.0/16
volumes:db-data:#web-data:cd /opt/mylnmp/
docker-compose -f docker-compose.yml up -d
------------------------------------------------------------------
-f, --file FILE :使用特定的 compose 模板文件,默认为 docker-compose.yml
-p, --project-name NAME :指定项目名称,默认使用目录名称
-d :在后台运行
------------------------------------------------------------------docker ps -a
CONTAINER ID   IMAGE                 COMMAND     CREATED              STATUS              PORTS                                         NAMES
2c0faededb85   php:lnmp       "/usr/local/php/sbin…"   15 seconds ago   Up 14 seconds   0.0.0.0:9000->9000/tcp, :::9000->9000/tcp   php
02f64893988e   mylnmp_nginx   "/usr/local/nginx/sb…"   35 seconds ago   Up 33 seconds   0.0.0.0:80->80/tcp, :::80->80/tcp           nginx
6f19d97e3163   mysql:lnmp     "/usr/local/mysql/bi…"   35 seconds ago   Up 14 seconds   0.0.0.0:3306->3306/tcp, :::3306->3306/tcp   mysqlcd /opt/mylnmp/
docker-compose ps					#必须在docker-compose.yml所在目录执行此命令

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述


http://www.ppmy.cn/news/978081.html

相关文章

C语言学习笔记 第一个C语言项目-07

目录 1.新建一个文件夹 2.新建一个文件,后缀以.cpp结尾 3.编写代码 4.编译与执行代码 代码解析 总结 1.新建一个文件夹 2.新建一个文件,后缀以.cpp结尾 如下图所示,选择相应的文件夹,然后点击新建文件按钮,新建的文…

何优化 PHP 数据库查询性能?

当你想要优化 PHP 数据库查询性能时,以下是一些可以从新手角度出发的有趣且实用的技巧: 学会写 SQL 查询语句 SQL 查询语句是数据库操作的核心,学会写高效的 SQL 查询语句是优化数据库查询性能的关键。不要发送过多的数据到服务器&#xff0…

集成学习Boosting - AdaBoost

目录 1. Boosting方法的基本思想 1.1 Bagging VS Boosting 1.2 Boosting算法的基本元素与基本流程 1.3 sklearn中的Boosting算法 2. AdaBoost 3 AdaBoost的基本参数与损失函数 3.1 参数 base_estimator,属性base_estimator_与estimators_ 3.1. 参数 learnin…

微信小程序 内容评论-回复评论-回复回复的实现(纯前端)

wxml <!-- 评论-回复-回复评论显示区域 --> <view class"container"><!-- 总共评论数 --> <view class"total">共{{comment_list.length comment_list2.length}}条评论</view> <!-- END --><!-- 评论框 …

一文助你快速提高嵌入式软件的代码质量【下】

一文助你快速提高嵌入式软件的代码质量 文章目录 一文助你快速提高嵌入式软件的代码质量&#x1f468;‍&#x1f3eb;前言1️⃣写直观的代码2️⃣写无懈可击的代码3️⃣正确处理错误4️⃣正确处理null指针5️⃣防止过度工程&#x1f647;文末小结 &#x1f468;‍&#x1f3eb…

报表下载工具

1.需求说明 我有一堆文件的Url地址&#xff0c; 现在需要按照企业&#xff0c;项目和报表类型分类下载到对应的文件夹中 2.相关实体类 企业文件夹定义 package com.vz.utils.report;import lombok.Data; import java.util.ArrayList; import java.util.List; import java.uti…

MySQL主从复制、读写分离

一、前言二、主从复制原理2.1 MySQL复制类型2.2 MySQL主从复制工作过程2.3 MySQL的四种同步方式2.3.1 异步复制&#xff08;MySQL默认&#xff09;2.3.2 同步复制2.3.3 半同步复制&#xff08;企业常用&#xff09;2.3.4 增强半同步复制 2.4 MySQL主从复制延迟原因和优化方法2.…

Jvm参数优化

Jvm参数优化 背景1. 系统上线规划容量- 分析 2. 垃圾回收器选择吞吐量和响应时间垃圾回收器选择 3. 规划各个分区的比例大小4. 对象年龄对少移动到老年代合适5. 对象多大放到老年代6. 垃圾回收器CMS老年代参数优化7. 配置OOM时的内存dump文件和GC日志8. 通用JVM参数模板 背景 …