Docker-compose容器编排与容器监控

news2024/12/25 9:01:42

一、Docker-compose

1、概念:

Docker-Compose 是 Docker 官方的开源项目,负责实现对Docker容器集群的快速编排。

2、作用:

Docker-Compose可以管理多个Docker容器组成一个应用。需要定义一个yaml格式的配置文件 docker-compose.yml,配置好多个容器之间的调用关系,然后只需要一个命令就能同时启动/关闭这些容器。

3、compose核心概念:

① 一文件:docker-compose.yml

② 两要素:

项目 (project):由一组关联的容器组成的一个完整业务单元;

服务 (service):一个项目中的某一个容器实例 。

4、compose 使用步骤:

① 编写 Dockerfile 定义各个应用容器,构建出对应的镜像文件;

② 使用 docker-compose.yml,定义一个完整的业务单元,安排好整体应用中的各个容器服务;

③ 执行 docker-compose up 命令,创建并运行整个应用程序,完成一键部署上线。

5、compose示例:

compose模版:https://docker_practice.gitee.io/compose/compose_file.html

(1) 创建一个项目:

mkdir /root/ems/ (以ems目录作为项目名)

(2) 在ems目录里创建一个docker-compose.yml文件:

① version:

每个模版文件需要写上version版本号,代表所使用的docker-compose的项目版本。

● 版本号的选择与docker引擎有关:

官方提供的compose版本号与docker引擎的对应关系:

② services:

在模版文件里定义需要启动的容器:

● 启动 tomcat:

若要启动另一个tomcat,则要再写一组服务:

● 启动 redis:

● 启动 mysql:

(3) 启动docker-compose服务:

docker compose up

这个命令必须在docker-compose.yml配置文件目录下执行

● 查看服务:

tomcat:

redis:

mysql:

● 停止服务:

附:完整docker-compose.yml

#代表使用的docker-compose项目版本号
version: "3.8"

services:
  tomcat1:            #tomcat服务名(名称唯一)
   image: tomcat:8.0   #所使用的镜像
   ports:              #宿主机8080端口映射容器8080端口
    - 8080:8080

  tomcat2:
   image: tomcat:8.0
   ports:
    - 8081:8080

  redis1:
   image: redis:6.0.8
   ports:
    - 6379:6379

  mysql:
   image: mysql:5.7
   ports:
    - 3306:3306
   environment:  #给当前容器启动指定环境 类似docker run -e MYSQL_ROOT_PASSWORD=123456
    - "MYSQL_ROOT_PASSWORD=123456" 
   volumes:   #给当前容器指定数据卷 类似docker run -v
    - /root/mysqldata1:/var/lib/mysql

(4) 在IDEA上创建docker-compose.yml:

远程连接docker服务器,创建一个docker-compose.yml

编写docker-compose.yml,可根据提示信息自动补齐,编写完成后点击红框所示图标,即可完成上传

宿主机上启动docker-compose服务:

6、docker-compose 常用命令:

(1) up:

docker compose up [options] [SERVICE...]

该命令会尝试自动完成包括构建镜像,创建服务,启动服务,并关联服务相关容器的一系列操作。

docker compose up:启动的容器都在前台,控制台将会同时打印所有容器的输出信息,可以很方便进行调试。

docker compose up -d:在后台启动并运行所有的容器。

(2) down:

docker compose down:关闭up命令所启动的服务容器,并移除网络。

(3) exec:

docker compose exec 服务id:进入某个服务容器。

(4) restart:

docker compose restart [options] [SERVICE...]:重启项目中的服务

-t, --timeout TIMEOUT 指定重启前停止容器的超时(默认为 10 秒)。

(5) rm:

docker compose rm [options] [SERVICE...]

删除所有停止状态的服务容器,先执行 docker compose stop 命令停止容器。

-f 强制直接删除,包括非停止状态的容器。

-v 删除容器所挂载的数据卷。

(6) top:

docker compose top

查看项目中所有服务容器运行进程,或某个指定id服务容器的进程。

(7) logs:

docker compose logs [options] [SERVICE...]

查看整个项目或某个id服务容器的日志。

7、docker-compose 模版文件常用指令:

https://vuepress.mirror.docker-practice.com/compose/compose_file/#

二、可视化工具Portainer

1、简介:

Portainer是一款轻量级的应用,提供图形化界面,用于管理Docker环境。

官网:Portainer: Container Management Software for Kubernetes and Docker

2、安装:

(1) docker 命令安装:

docker run -d -p 8000:8000 -p 9000:9000 --name portainer --restart=always -v /var/run/docker.sock:/var/run/docker.sock -v portainer_data:/data portainer/portainer-ce:2.13.0-alpine

(2) 登录:

① 访问地址:服务器ip:9000;

② 设置 admin 密码;

类似 docker system df:

3、Portainer创建容器:

三、容器监控CIG

1、简介:

CAdvisor (监控收集) + InfluxDB (存储数据) + Granfana (展示图表),合称CIG

(1) CAdvisor:

CAdvisor是一个容器资源监控工具,包括容器的内存、CPU、网络IO、磁盘IO等监控,提供了一个Web页面用于查看容器的实时运行状态。

CAdvisor默认存储2分钟的数据,而且只针对单物理机。不过CAdvisor提供了很多数据集成接口,支持 InfluxDB、Redis、Kafka、Elasticsearch等集成,可以加上对应配置将监控数据发往这些数据库存储起来。

(2) InfluxDB:

为了持久化存储数据和统一收集展示监控数据,需要将数据存储到InfluxDB中。InfluxDB是一个时序数据库,专门用于存储时序相关数据,很适合存储 CAdvisor 的数据。

(3) Granfana:

Grafana是一个开源的数据监控分析可视化平台,支持多种数据源配置和丰富的插件及模板功能,支持图表权限控制和报警。

2、docker-compose 部署 CIG:

(1) 新建docker-compose.yml:

① 新建目录:mkdir /mydocker/cig -p

② 编写docker-compose.yml:

services:
  influxdb:
    image: tutum/influxdb:0.9
    restart: always
    environment:
      - PRE_CREATE_DB=cadvisor
    ports:
      - "8083:8083"        
      - "8086:8086"            
    volumes:
      - ./data/influxdb:/data

  cadvisor:
    image: google/cadvisor:v0.32.0
    links:
      - influxdb:influxsrv
    command:
      - -storage_driver=influxdb
      - -storage_driver_db=cadvisor
      - -storage_driver_host=influxsrv:8086
    restart: always
    ports:
      - "8080:8080"
    volumes:
      - /:/rootfs:ro
      - /var/run:/var/run:rw
      - /sys:/sys:ro
      - /var/lib/docker/:/var/lib/docker:ro

  grafana:
    image: grafana/grafana:8.5.2
    user: '104'
    restart: always
    links:
      - influxdb:influxsrv
    ports:
      - "3000:3000"
    volumes:
      - grafana_data:/var/lib/grafana
    environment:
      - HTTP_USER=admin
      - HTTP_PASS=admin
      - INFLUXDB_HOST=influxsrv
      - INFLUXDB_PORT=8086

docker compose config -q:检查.yml文件语法

(2) 启动docker-compose文件,并检查服务是否启动:

3、测试:

(1) 浏览CAdvisor收集服务:

(2) 浏览 influxdb 存储服务:

(3) 浏览 grafana 展现服务:

初始用户名:admin ;密码:admin

● grafana 配置:

① 配置数据源:

② 配置面板panel:

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

2023-12-06 LeetCode每日一题(最小化旅行的价格总和)

2023-12-06每日一题 一、题目编号 2646. 最小化旅行的价格总和二、题目链接 点击跳转到题目位置 三、题目描述 现有一棵无向、无根的树,树中有 n 个节点,按从 0 到 n - 1 编号。给你一个整数 n 和一个长度为 n - 1 的二维整数数组 edges &#xff0…

maven-assembly-plugin 自定义打包

我想把input文件夹给打包进去 pom文件 <build><plugins><plugin><groupId>org.apache.maven.plugins</groupId><artifactId>maven-assembly-plugin</artifactId><executions><execution><!-- 配置执行器 --><i…

Dockerfile介绍

1. DockerFile介绍 dockerfile是用来构建docker镜像的文件&#xff01;命令参数脚本&#xff01; 构建步骤&#xff1a; 1、编写一个dockerfile文件 2、docker build 构建成为一个镜像 3、docker run运行镜像 4、docker push发布镜像&#xff08;DockerHub、阿里云镜像仓库…

『亚马逊云科技产品测评』活动征文|AWS云服务器EC2实例实现ByConity快速部署

授权声明&#xff1a;本篇文章授权活动官方亚马逊云科技文章转发、改写权&#xff0c;包括不限于在 Developer Centre, 知乎&#xff0c;自媒体平台&#xff0c;第三方开发者媒体等亚马逊云科技官方渠道 前言 亚马逊是全球最大的在线零售商和云计算服务提供商。AWS云服务器在…

5G入门到精通 - 5G的十大关键技术

文章目录 一、网络切片二、自组织网络三、D2D技术四、低时延技术五、MIMO技术六、毫米波七、内容分发网络八、M2M技术九、频谱共享十、信息中心网络 一、网络切片 5G中的网络切片是一项关键技术&#xff0c;它允许将整个5G网络分割成多个独立的虚拟网络&#xff0c;每个虚拟网络…

一维相位解包裹

一维相位解包裹 本文首先介绍最简单的一维的位相解包裹算法。设W是包裹运算符&#xff0c;中是解包裹位相&#xff0c;是包裹的位相。则一维位相解包裹可表示为&#xff1a; 解包裹就是要选取正确的k,满足&#xff1a; 两个相邻像素位相的差值如下&#xff1a; 由式(2-1)和式(2…

从零开始学习 JS APL(六):完整指南和实例解析

学习目标&#xff1a; 1. 能够利用正则表达式校验输入信息的合法性 2. 具备利用正则表达式验证小兔鲜注册页面表单的能力 学习内容&#xff1a; 正则表达式 综合案例 阶段案例 学习时间&#xff1a; 周一至周五晚上 7 点—晚上9点周六上午 9 点-上午 11 点周日下午 3 点-下…

PCIe 数据链路层

PCIe 总线的数据链路层处于事务层和物理层之间&#xff0c;主要功能是保证来自事务层的TLP在PCle链路中的正确传递&#xff0c;为此数据链路层定义了一系列数据链路层报文&#xff0c;即DLLP。数据链路层使用了容错和重传机制保证数据传送的完整性与一致性&#xff0c;此外数据…

frp内网穿透部署,轻松实现内网服务对外访问

FRP&#xff08;Fast Reverse Proxy&#xff09;是一种轻量级、高性能的反向代理工具&#xff0c;利用反向代理技术将公网请求转发至内网服务器上&#xff0c;并将内网服务器的响应再次转发至公网请求者。在实现内网穿透时&#xff0c;FRP能够将公网与内网之间的隔离突破&#…

每日一题:Leetcode1926.迷宫中离入口最近的出口

给你一个 m x n 的迷宫矩阵 maze &#xff08;下标从 0 开始&#xff09;&#xff0c;矩阵中有空格子&#xff08;用 . 表示&#xff09;和墙&#xff08;用 表示&#xff09;。同时给你迷宫的入口 entrance &#xff0c;用 entrance [entrancerow, entrancecol] 表示你一开始…

MYSQL练题笔记-聚合函数-游戏玩法分析

仍需成长啊&#xff0c;干自己认为的想干的事情的时候都有很大的挫败&#xff0c;那做别人分配给你的你自然会更难受些&#xff0c;尤其是你不懂的时候&#xff0c;所以加油&#xff0c;好好看待挫折和未成长的路啊&#xff01;&#xff01; 一、题目相关内容 1&#xff09;相…

N26:构建无缝体验的平台工程之路-Part 1

在 N26&#xff0c;在生产环境中仅需一小时即可完成启动一个新的服务&#xff0c;包括所有必要的基础设施依赖项、功能&#xff0c;以及专用的数据库集群&#xff0c;并且其 API 可以用于通过身份验证的请求。在激烈竞争的金融市场中&#xff0c;迅速推出新产品和服务对于吸引和…

接口测试:身份认证(Auth认证的接口)+查询发布会

上一篇&#xff1a;接口测试case&#xff1a;查询发布会-CSDN博客&#xff08;无身份认证版&#xff09; 1、前置基础 一般测试工具都会提供一个User Auth/Authorization的选项&#xff0c;要求输入username/password字段。 系统登录功能时的username/password&#xff0c;是…

ke13--10章-1数据库JDBC介绍

注册数据库(两种方式),获取连接,通过Connection对象获取Statement对象,使用Statement执行SQL语句。操作ResultSet结果集 ,回收数据库资源. 需要语句: 1Class.forName("DriverName");2Connection conn DriverManager.getConnection(String url, String user, String…

机器学习 类别特征编码:Category Encoders 库的使用

✅作者简介&#xff1a;人工智能专业本科在读&#xff0c;喜欢计算机与编程&#xff0c;写博客记录自己的学习历程。 &#x1f34e;个人主页&#xff1a;小嗷犬的个人主页 &#x1f34a;个人网站&#xff1a;小嗷犬的技术小站 &#x1f96d;个人信条&#xff1a;为天地立心&…

java设计模式学习之【组合模式】

文章目录 引言组合模式简介定义与用途&#xff1a;实现方式UML 使用场景优势与劣势组合模式在Spring中的应用员工结构示例代码地址 引言 设想您正在组织一个大型派对&#xff0c;需要将各种食品和饮料按类型整理。您可能有单独的物品&#xff0c;如一瓶苏打水&#xff0c;也可…

您知道计算机是怎么分类的嘛

地表最强计算机 第 61 版全球最强大的超级计算机已经发布。名为 Top500&#xff0c;顾名思义&#xff0c;该列表列出了全球 500 台最强大的超级计算机。榜单显示&#xff0c;美国的AMD、英特尔和IBM处理器是超级计算系统的首选。在 TOP10 中&#xff0c;有四个系统使用 AMD 处理…

JWT安全及WebGoat靶场

JWT 安全 cookie(放在浏览器) cookie 是一个非常具体的东西&#xff0c;指的就是浏览器里面能永久存储的一种数据&#xff0c;仅仅是浏览器实现的一种数据存储功能。 cookie 由服务器生成&#xff0c;发送给浏览器&#xff0c;浏览器把 cookie 以 kv 形式保存到某个目录下的…

1+x网络系统建设与运维(中级)-练习题4

一.设备命名 LSW1 <Huawei>sys [Huawei]sysn LSW1 [LSW1]un in en 同理可得&#xff0c;给所有设备如以上命令一样配置 二.VLAN LSW1 [LSW1]vlan ba 1 10 20 100 [LSW1]int g0/0/1 [LSW1-GigabitEthernet0/0/1]port link-type trunk [LSW1-GigabitEthernet0/0/1]port tru…

axios调接口传参特殊字符丢失的问题(encodeURI 和 encodeURIComponent)

1、axios调接口特殊字符丢失的问题 项目开发过程中遇到一个接口传参&#xff0c;参数带特殊字符&#xff0c;axios调接口特殊字符丢失的问题 例如接口&#xff1a; get/user/detail/{name} name是个参数直接调接口的时候拼到接口上&#xff0c;get/user/detail/test123#$%&am…