【云原生】docker-compose单机容器集群编排工具

目录

一、docker-compose容器编排的简介

二、docker-compose的使用

1、docker-compose的安装

2、docker-compose的配置模板文件yaml文件的编写

(1)布尔值类型

(2)字符串类型

(3)一个key有多个值

(4)对象object类型类型

(5)文本块

(6)锚点

3、docker-compose配置模板文件常用的字段 与docker run的选项和参数对比

4、docker-compose命令的选项和参数

三、基于上次实验结果,完成一个lnmp项目

步骤一:项目名称是docker,创建了一个/docker目录,先准备一个docker-compose.yaml文件

步骤二:编写docker-compose.yaml配置模板文件

​编辑 步骤三:完成容器集群的一次性启动,在docker-compose.yaml文件的目录中,使用docker-compose up -d 构建镜像并直接启动所有的容器以及相关的依赖环境

步骤四:进入mysql中完成wordpress的首先,并在浏览器中进行验证

 排错思路


一、docker-compose容器编排的简介

docker-compose 是一个可以实现在单机上对容器集群编排管理的工具。

它允许用户使用docker-compose.yml 配置模板文件来定义应用程序的配置,包括容器的数量、容器之间的依赖关系、环境变量、端口映射以及数据卷等设置。

然后,用户使用docker-compose命令根据指定配置模板文件的配置来启动和管理容器集群。

通过docker-compose的优势:

  1. 使用 Docker Compose命令可以方便地管理多个容器
  2. 可以解决容器之间的依赖关系,同时启动一个 Web 服务器容器和一个数据库容器,并在它们之间建立网络连接,再通过depends_on实现php依赖于nginx和mysql服务的启动顺序;
  3. Docker Compose 还支持自定义网络,使得容器可以在不同的网络中进行通信;

本质就是在yaml格式的docker-compose配置模板文件里定义多个服务容器的启动参数和依赖关系,并使用docker-compose命令根据指定配置模板文件的配置来启动和管理容器集群。

docker-compose的三大概念
项目project -> 包含一个或多个服务service -> 包含一个或多个容器container的镜像、端口映射、环境变量、依赖关系等启动参数

  1. 默认使用项目的目录名作为project的项目名,支持使用 -p 或 --project-name 来指定项目名称
  2. 项目目录里要包含一个 docker-compose 配置模板文件,默认为 docker-compose.yml,支持使用 -f 或 --file 来指定项目的配置模板文件
  3. 在配置模板文件docker-compose.yaml里要包含一个或多个服务容器的配置,每个服务要包含容器的名称、镜像、映射端口、挂载点、网络模式、依赖关系等容器启动的配置参数

二、docker-compose的使用

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

[root@localhost docker]#find / -name docker-compose
c/usr/libexec/docker/cli-plugins/docker-compose
[root@localhost docker]#cp /usr/libexec/docker/cli-plugins/docker-compose /usr/local/bin/
[root@localhost docker]#docker-compose -v
Docker Compose version v2.24.2

2、docker-compose的配置模板文件yaml文件的编写

YAML是一种标记语言,可以很直观的展示数据序列化格式,可读性很高。类似于json数据描述语言,语法比json简单很多,关于yaml数据格式:

  • YAML数据结构通过缩进来表示字段的层级
  • 连续的项目通过减号来表示,
  • 键值对用冒号分隔,
  • 数组用中括号 [] 括起来,
  • hash 用花括号 {} 括起来

关于yaml的注意事项:

  • 大小写敏感
  • 通过缩进表示层级关系
  • 不支持制表符 tab 键缩进,只能使用空格缩进
  • 缩进的空格数目不重要,只要相同层级左对齐,通常开头缩进2个空格
  • 用 # 号注释
  • 符号字符后缩进1个空格,如冒号 :  、逗号 ,  、横杠 - 
  • 如果包含特殊字符用单引号('')引起来会作为普通字符串处理,双引号(""): 特殊字符作为本身想表示的意思

(1)布尔值类型

debug: true
debug: false
privileged: true

(2)字符串类型

name: tom
name: 'tom'
name: "tom"

(3)一个key有多个值

animal: 
- 飞行动物
- 爬行动物
- 水生动物
- 两栖东西

横向格式
animal: ["飞行动物", "爬行动物", "水生动物", "两栖东西"]

(4)对象object类型类型

#yaml格式用 空格缩进 表示字段的层级关系,同一层字段要靠左对齐

一级字段:
    二级字段1:                    
    二级字段2:
	    三级字段: 

human:
  name:
    姓: "王"
	ming: 
	- 文宇
	- 思聪
  age: 24
  sex: 男
  height: 180

(5)文本块

value:              ->  value: "helloworld"
       hello 
       world

 
value: |            -> value: "hello\nworld"              #key: |  表示保留文本块里的换行符
       hello 
       world

value: |-           -> value: 相当于 echo -n "helloworld"
       hello        
       world
	   
value: |+           -> value: "hello\nworld\n"
       hello    
       world 

(6)锚点

name: &a yaml       #锚点,相当于 a="yaml"                    
book: *a            #引用,相当于 echo $a     book: yaml   

关于json格式:

 json文件格式:文件名格式通常是以 .json 为后缀,用 大括号{} 表示字段的层级关系,每层字段除了最后一个字段都要用逗号,结尾,特性:易于api接口解析

human:
  name:
    姓: "王"
	ming: 
	- 文宇
	- 思聪
  age: 24
  sex: 男
  height: 180
  
  
{
  "human": {                      #json格式用 大括号{} 表示字段的层级关系,每层字段除了最后一个字段都要用逗号,结尾
     "name": {
	    "姓": ["王"],
		"名":["文宇", "思聪"]
	 },
	 "age": ["24"],
	 "sex": ["男"],
     "height": ["180"]
  
  }
}

3、docker-compose配置模板文件常用的字段 与docker run的选项和参数对比

image               使用本地镜像或从仓库拉取镜像创建容器
build:              使用dockerfile现场构建镜像创建容器
  context:指定dockerfile文件所在的目录
  dockerfile:指定dockerfile的文件名称
command             指定容器启动命令,会覆盖镜像中的CMD指令
container_name      相当于指定容器的名称  --name 
environment        相当于指定容器的环境变量 -e  --env
network_mode        相当于指定容器的网络 --network
networks          指定加入的网络和IP    --IP以及自定义网络模式
ports               指定端口映射 -p
volumes            指定数据卷   -v 或者自定义顶级卷(版本3)
volumes_from        --volumes-from ,版本3不支持
hostname            指定容器的主机名  -h  --hostname
sysctls             指定容器的内核参数  --sysctl
links               指定容器的名称以及连接别名,可以通过容器名称通信 --link
privileged          让容器拥有真正的root权限 不建议使用  不安全 --privileged
restart             

指定重启策略  --restart

设置重启策略,no,always,no-failure,unless-stopped
no,默认策略,在容器退出时不重启容器。
on-failure,在容器非正常退出时(退出状态非0),才会重启容器。
on-failure:3,在容器非正常退出时重启容器,最多重启3次。
always,在容器退出时总是重启容器。
unless-stopped,在容器退出时总是重启容器,但是不考虑在 Docker 守护进程启动时就已经停止了的容器。

depends_on          

指定有依赖关系的容器

在使用Compose时,最大的好处就是少打启动命令,但一般项目容器启动的顺序是有要求的,如果直接从上到下启动容器,可能会因为容器依赖问题而启动失败。例如在没启动数据库容器的时候启动应用容器,应用容器会因为找不到数据库而退出。depends_on标签用于解决容器的依赖、启动先后的问题。
php:
  depends_on:
    - apache
    - mysql

4、docker-compose命令的选项和参数

字段                    描述
build                   重新构建服务
ps                      列出容器
up                      创建和启动容器
exec                    在容器里面执行命令
scale                   指定一个服务容器启动数量
top                     显示容器进程
logs                    查看容器输出
down                    删除容器、网络、数据卷和镜像
stop/start/restart      停止/启动/重启服务

三、基于上次实验结果,完成一个lnmp项目

步骤一:项目名称是docker,创建了一个/docker目录,先准备一个docker-compose.yaml文件

ps:为了实验环境,将自定义网络,以及容器全部清空,并删除了nginx:lnmp镜像。

计划:nginx镜像通过dockerfile文件现场构建(准备好nginx构建镜像的目录),mysql和php的镜像使用本地镜像

步骤二:编写docker-compose.yaml配置模板文件

#指定compose的版本为3
version: "3"
#定义服务
services:
  #第一个服务为nginx
  nginx:
    #可以直接指定现有的镜像,或者通过build去现场构建,context指明dockerfile的文件目录,以及dockerfile指定dockerfile的文件名称
    #image:
    build:
      context: ./nginx
      dockerfile: Dockerfile
    #定义容器的服务名称
    container_name: nginx
    #暴露端口号
    ports:
    - 80:80
    #数据卷挂载
    volumes:
    - ./nginx/html:/usr/local/nginx/html
    #指定网络,compose_lnmp为自定义网络
    networks:
      compose_lnmp:
        ipv4_address: 172.18.0.2
    #指定服务的重启策略
    restart: always

  #第二个服务是mysql
  mysql:
    image: mysql:lnmp
    #定义容器的服务名称
    container_name: mysql
    #通过顶级卷创建数据卷
    volumes:
    - db_data:/usr/local/mysql
    #设置容器有真正的root权限
    privileged: true
    #给容器自定义ip
    networks:
      compose_lnmp:
        ipv4_address: 172.18.0.4
    restart: always

  #第三个服务是php
  php:
    image: php:lnmp
    container_name: php
    ports:
    - 9000:9000
    volumes:
    - db_data:/usr/local/mysql
    - ./nginx/html:/usr/local/nginx/html
    networks:
      compose_lnmp:
        ipv4_address: 172.18.0.3
    restart: always
    #设置依赖环境,php的启动需要在nginx和mysql之后
    depends_on:
    - nginx
    - mysql

#自定义网络
networks:
  #自定义网络的名称
  compose_lnmp:
    #自定义网络的驱动
    driver: bridge
    ipam:
      config:
        #自定义的网段
      - subnet: 172.18.0.0/16

#创建一个顶级卷,因为在版本3不支持volumes_from,需要通过顶级卷来实现容器之间的数据共享
volumes:
  db_data:

 步骤三:完成容器集群的一次性启动,在docker-compose.yaml文件的目录中,使用docker-compose up -d 构建镜像并直接启动所有的容器以及相关的依赖环境

[root@localhost docker]#vim docker-compose.yaml 
[root@localhost docker]#docker-compose up -d

步骤四:进入mysql中完成wordpress的首先,并在浏览器中进行验证

[root@localhost docker]#docker exec -it mysql bash
##进入mysql容器完成账号的授权

[root@localhost docker]#docker-compose down

 排错思路

1、查看提示,粗心错误,自定义网段错误

2、配置模板文件漏了字段

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mfbz.cn/a/357056.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

成都直播产业园解析直播供应链金融服务,天府锋巢直播产业基地打造“金融+产业+生态”新型模式

天府锋巢直播产业基地如何打造“金融产业生态”新型模式? 本文将为您全面解析基地提供的成都直播产业园供应链金融服务 锋巢资讯~每周准时报道~~ 赶紧下拉,阅读全文 Q:企业入驻园区能获得哪些直播供应链金融服务&…

【gcc】RtpTransportControllerSend学习笔记 5:OnTransportPacketsFeedback及测试程序

【gcc】RtpTransportControllerSend学习笔记 4:码率分配 中阅读了大神的文章,依旧云雾中,因此,反复阅读大神的文章,结合代码,继续。本次是 基于m98的代码。src\modules\congestion_controller\goog_cc\goog_cc_network_control.cc GoogCcNetworkController 是核心类,其处…

基于UDP的套接字通信(附通信代码)

基于UDP的套接字通信 udp是一个面向无连接的,不安全的,报式传输层协议,udp的通信过程默认也是阻塞的。 不需要建立连接 UDP通信过程中,每次都需要指定数据接收端的IP和端口 UDP不对收到的数据进行排序,在UDP报文的…

【vue】defineModel在vue3.4中的最新用法和详解

在2023年12月28日,尤大发布了vue3.4版本,这个版本主要对一些实验性特性的改进(比如defineModel),大量重写了模板编译器并重构了响应式系统,可以说是大大提升了运行速度和效率。 之前在vue3.3中defineModel…

erp读书笔记20240129

ERP 计划中的时间概念,包括计划期、时段、时区与时界,以及五种作业时间。 计划期的定义是为了实现对产品全流程的控制,提高计划的预见性,实现供需链计划。时段的划分是为了区别优先级,满足滚动计划的需求。 时区与时界…

信创联盟--朗思科技加入证券基金行业信息技术应用创新联盟,共促金融信创发展

近期,证券基金行业信息技术应用创新联盟(以下简称:信创联盟)新一批成员单位名单公布,朗思科技LanSive凭借产品创新以及实践案例成功入选,正式成为信创联盟成员单位。 信创联盟由上交所联合行业券商倡议发起…

STM32控制DHT11温湿度传感器模块获取温湿度数据

时间记录:2024/1/29 一、DHT11引脚介绍 (1)VCC:电源引脚,3.3-5.5V (2)DATA:数据输入输出引脚 (3)NC:保留引脚,悬空即可 (…

MicrosoftEdge浏览器打开网页出现“此网站被人举报不安全”问题时解决办法

1:有时候不知怎么回事用电脑自带的微软浏览器进行搜索会出现以下的问题 这可能是由于我们的浏览器安全审查过于严格引起的 Windows10正式版系统下,使用Edge浏览器浏览网页时候,发现整个页面突然变成了红色,显示“已有人举报此网站…

springboot3+vue支付宝在线支付案例-解决跨域请求的问题

springboot3vue支付宝在线支付案例-解决跨域请求的问题!为了使用外网地址,跨域请求业务接口。我们需要设置一个类。配置一下。 我们采用的方案是。借助于 WebMvcConfigurer package com.example.demo.config;import org.springframework.context.annot…

el-upload子组件上传多张图片(上传为files或base64url)

场景: 在表单页,有图片需要上传,表单的操作行按钮中有上传按钮,点击上传按钮。 弹出el-dialog进行图片的上传,可以上传多张图片。 由于多个表单页都有上传多张图片的操作,因此将上传多图的el-upload定义…

温酒读Qt:QObject中篇2 ——欲遮还羞的 QObjectPrivate

《妙法莲华经》曰:“佛道长远,久受勤苦,乃可得成。” 世事修炼,莫不如是,日拱一卒无有尽,功不唐捐终入海。 传送门: 《温酒读Qt:QObject 序篇》 《温酒读Qt:QObject中篇1—— Q_OBJ…

大型电商系统商城源码_架构_订单系统_OctShop

中国的电商差不多发展到今天已经有20多年的历史啦,特别是过去的10年里其发展速度与竞争是相当的激烈,发展出了各种各样的模式如:B2B、B2C、B2B2C、O2O、社交电商等等。对于广大的企业或商家来说,电商是一个不可或缺的销售渠道&…

IndexedDB查询

Indexeddb 创建、增删改查_indexdb 删除表-CSDN博客本地数据库IndexedDB - 学员管理系统之条件筛选&#xff08;四&#xff09;_indexdb条件查询-CSDN博客 <div align"center"><input type"text" id"input_search"> <button id&q…

linux -- 内存管理 -- SLAB分配器

SLAB分配器&#xff08;slab allocator&#xff09; SLAB分配器用于小内存空间管理&#xff0c;基本思想是&#xff1a;先利用页面分配器分配出单个或多个连续的物理页面&#xff0c;然后再此基础上将整块页面分割为多个相等的小内存单元&#xff0c;来满足小内存空间分配的需…

费一凡:土木博士的自我救赎之道 | 提升之路系列(五)

导读 为了发挥清华大学多学科优势&#xff0c;搭建跨学科交叉融合平台&#xff0c;创新跨学科交叉培养模式&#xff0c;培养具有大数据思维和应用创新的“π”型人才&#xff0c;由清华大学研究生院、清华大学大数据研究中心及相关院系共同设计组织的“清华大学大数据能力提升项…

【动态规划】【图论】【C++算法】1575统计所有可行路径

作者推荐 【动态规划】【字符串】【行程码】1531. 压缩字符串 本文涉及知识点 动态规划汇总 图论 LeetCode1575统计所有可行路径 给你一个 互不相同 的整数数组&#xff0c;其中 locations[i] 表示第 i 个城市的位置。同时给你 start&#xff0c;finish 和 fuel 分别表示出…

如何使用YOLOv8训练自己的模型

本文介绍如何用YOLO8训练自己的模型&#xff0c;我们开门见山&#xff0c;直接步入正题。 前言&#xff1a;用yolo8在自己的数据集上训练模型首先需要配置好YOLO8的环境&#xff0c;如果不会配置YOLO8环境可以参考本人主页的另一篇文章 提醒&#xff1a;使用GPU训练会大幅度加…

实习日志7

1.试试pdf发票识别 1.1.添加文件类型判断 //判断文件类型 if (getFileType(imgCodeCell.getValue()) "jpg"||getFileType(imgCodeCell.getValue()) "png"||getFileType(imgCodeCell.getValue()) "jpeg"||getFileType(imgCodeCell.getValue(…

Python爬虫解析库安装

解析库的安装 抓取网页代码之后&#xff0c;下一步就是从网页中提取信息。提取信息的方式有多种多样&#xff0c;可以使用正则来提取&#xff0c;但是写起来相对比较烦琐。这里还有许多强大的解析库&#xff0c;如 lxml、Beautiful Soup、pyquery 等。此外&#xff0c;还提供了…

R语言(数据导入,清洗,可视化,特征工程,建模)

记录一下痛失的超级轻松的数据分析实习&#xff08;线上&#xff09;&#xff0c;hr问我有没有相关经历&#xff0c;我说我会用jupyter book进行数据导入&#xff0c;清洗&#xff0c;可视化&#xff0c;特征工程&#xff0c;建模&#xff0c;python学和用的比较多&#xff0c;…