多种工具协同创建一个基于CentOS,包含最新版本sysstat的镜像

2024-02-21 03:59

本文主要是介绍多种工具协同创建一个基于CentOS,包含最新版本sysstat的镜像,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

服务器上部署了sysstat,通过sar可以保留系统监控记录,从服务器下载数据在别处分析时,不是很方便,因此考虑构建一个方便使用的Docker镜像辅助工作。

sysstat: https://github.com/sysstat/sysstat

1. Bing AI 创建 Dockerfile

直接让 AI 帮忙写 Dockerfile
在这里插入图片描述
内容复制如下:

# 基于CentOS7镜像
FROM centos:7# 安装git和编译工具
RUN yum install -y git gcc make# 通过git克隆sysstat仓库
RUN git clone https://github.com/sysstat/sysstat.git# 进入sysstat目录,编译并安装
WORKDIR /sysstat
RUN ./configure && make && make install# 清理缓存数据和源码
RUN yum clean all && rm -rf /sysstat

创建完成后在我本地构建过程中,git clone 下载不了,换一种方式构建。

2. GitHub Codespaces

2.1 打开 sysstat 的页面,创建一个运行环境

在这里插入图片描述

2.2 检查一下是否支持 docker 环境

@abel533 ➜ /workspaces/sysstat (master) $ docker ps
CONTAINER ID   IMAGE     COMMAND   CREATED   STATUS    PORTS     NAMES

2.3 创建 Dockerfile

没有问题,从左侧资源管理器创建 Dockerfile,输入上面的内容。
在这里插入图片描述

为了方便我本地使用,把CentOS镜像版本从7改成了具体的7.6.1810

2.4 执行命令构建

@abel533 ➜ /workspaces/sysstat (master) $ docker build -t sysstat:23-0323 .
[+] Building 79.1s (11/11) FINISHED                                                                                                                                                                                => [internal] load build definition from Dockerfile                                                                                                                                                          0.5s=> => transferring dockerfile: 398B                                                                                                                                                                          0.0s=> [internal] load .dockerignore                                                                                                                                                                             0.4s=> => transferring context: 2B                                                                                                                                                                               0.1s=> [internal] load metadata for docker.io/library/centos:7.6.1810                                                                                                                                            3.0s=> [auth] library/centos:pull token for registry-1.docker.io                                                                                                                                                 0.0s=> [1/6] FROM docker.io/library/centos:7.6.1810@sha256:62d9e1c2daa91166139b51577fe4f4f6b4cc41a3a2c7fc36bd895e2a17a3e4e6                                                                                      4.9s=> => resolve docker.io/library/centos:7.6.1810@sha256:62d9e1c2daa91166139b51577fe4f4f6b4cc41a3a2c7fc36bd895e2a17a3e4e6                                                                                      0.1s=> => sha256:62d9e1c2daa91166139b51577fe4f4f6b4cc41a3a2c7fc36bd895e2a17a3e4e6 534B / 534B                                                                                                                    0.0s=> => sha256:747b2de199b6197a26eb1a24d69740d25483995842b2d2f75824095e9d1d19eb 529B / 529B                                                                                                                    0.0s=> => sha256:f1cb7c7d58b73eac859c395882eec49d50651244e342cd6c68a5c7809785f427 2.18kB / 2.18kB                                                                                                                0.0s=> => sha256:ac9208207adaac3a48e54a4dc6b49c69e78c3072d2b3add7efdabf814db2133b 75.16MB / 75.16MB                                                                                                              0.9s=> => extracting sha256:ac9208207adaac3a48e54a4dc6b49c69e78c3072d2b3add7efdabf814db2133b                                                                                                                     3.0s=> [2/6] RUN yum install -y git gcc make                                                                                                                                                                    46.6s=> [3/6] RUN git clone https://github.com/sysstat/sysstat.git                                                                                                                                                3.7s=> [4/6] WORKDIR /sysstat                                                                                                                                                                                    0.3s => [5/6] RUN ./configure && make && make install                                                                                                                                                            13.0s => [6/6] RUN yum clean all && rm -rf /sysstat                                                                                                                                                                1.5s => exporting to image                                                                                                                                                                                        5.2s => => exporting layers                                                                                                                                                                                       5.2s => => writing image sha256:03d82c85a1f5df4f21558e8d43a9632a1119b6a4d52456ed3139bf76fb72c349                                                                                                                  0.0s => => naming to docker.io/library/sysstat:23-0323               

2.5 运行镜像验证一下功能

@abel533 ➜ /workspaces/sysstat (master) $ docker run -it --rm sysstat:23-0323 /bin/bash
[root@38451f6af593 sysstat]# sar 1 10
Linux 5.4.0-1104-azure (38451f6af593)   03/23/23        _x86_64_        (2 CPU)02:17:43        CPU     %user     %nice   %system   %iowait    %steal     %idle
02:17:44        all      3.54      0.00      5.05      0.00      0.00     91.41
02:17:45        all      0.51      0.00      1.02      0.00      0.00     98.47
02:17:46        all      1.51      0.00      4.02      0.50      0.00     93.97
02:17:47        all      7.69      0.00      6.67      0.00      0.00     85.64
02:17:48        all     16.24      0.00      6.09      0.00      0.00     77.66
02:17:49        all      3.54      0.00      2.02      0.00      0.00     94.44
02:17:50        all      2.02      0.00      3.03      0.00      0.00     94.95
02:17:51        all      1.02      0.00      1.02      0.00      0.00     97.97
02:17:52        all      2.54      0.00      3.55      0.00      0.00     93.91
02:17:53        all      2.01      0.00      2.51      0.00      0.00     95.48
Average:        all      4.05      0.00      3.50      0.05      0.00     92.40

2.6 推送镜像

在DockerHub创建一个公开的镜像,重新命名tag:

docker tag sysstat:23-0323 abel533/sysstat:23.03.23

登录Docker

docker login -u用户名 -p密码

推送镜像

@abel533 ➜ /workspaces/sysstat (master) $ docker push abel533/sysstat:23.03.23
The push refers to repository [docker.io/abel533/sysstat]
68867ac04a78: Pushed 
574e22f85afb: Pushed 
5f70bf18a086: Pushed 
b5e26a4e7785: Pushed 
6a7f717fb326: Pushed 
89169d87dbe2: Pushed 
23.03.23: digest: sha256:e5fdcb8c11f34a43e96e25ffef4572cc71113a47691980655f47871ef981346d size: 1581

至此完成了一个最新版本的 sysstat 镜像。

3. 镜像地址

如果有需要,你可以直接下载该镜像使用:

https://hub.docker.com/r/abel533/sysstat/tags

在这里插入图片描述

4. 特别注意

在Windows上使用时,如果挂载本地目录到容器使用时,WSL2 在容器和宿主机操作文件非常的慢(几乎没有反应),建议把文件拷到容器其他目录进行操作,输出到容器目录(速度特别快),然后在拷贝到挂载的本地目录中。

想要将sar导出为svg图表时,可以参考下面的命令使用:

# 设置起止时间
sadf -s 8:30:00 -e 17:30:00 -t -g sa27 -- -A > sa27.svg# 不设置时间
sadf -t -g sa27 -- -A > sa27.svg# 不同系统的时间不一样,如果使用 -t 起至时间不是0时,可以改成 -T 试试

产生的图表示例如下:
在这里插入图片描述
上面 -- -A 包含了所有的监控数据,上图有缩放,下图是一个没缩放的系统负载图:
在这里插入图片描述

这篇关于多种工具协同创建一个基于CentOS,包含最新版本sysstat的镜像的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/730503

相关文章

Spring IoC 容器的使用详解(最新整理)

《SpringIoC容器的使用详解(最新整理)》文章介绍了Spring框架中的应用分层思想与IoC容器原理,通过分层解耦业务逻辑、数据访问等模块,IoC容器利用@Component注解管理Bean... 目录1. 应用分层2. IoC 的介绍3. IoC 容器的使用3.1. bean 的存储3.2. 方法注

MySQL 删除数据详解(最新整理)

《MySQL删除数据详解(最新整理)》:本文主要介绍MySQL删除数据的相关知识,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录一、前言二、mysql 中的三种删除方式1.DELETE语句✅ 基本语法: 示例:2.TRUNCATE语句✅ 基本语

Linux中压缩、网络传输与系统监控工具的使用完整指南

《Linux中压缩、网络传输与系统监控工具的使用完整指南》在Linux系统管理中,压缩与传输工具是数据备份和远程协作的桥梁,而系统监控工具则是保障服务器稳定运行的眼睛,下面小编就来和大家详细介绍一下它... 目录引言一、压缩与解压:数据存储与传输的优化核心1. zip/unzip:通用压缩格式的便捷操作2.

Qt QCustomPlot库简介(最新推荐)

《QtQCustomPlot库简介(最新推荐)》QCustomPlot是一款基于Qt的高性能C++绘图库,专为二维数据可视化设计,它具有轻量级、实时处理百万级数据和多图层支持等特点,适用于科学计算、... 目录核心特性概览核心组件解析1.绘图核心 (QCustomPlot类)2.数据容器 (QCPDataC

深度解析Java DTO(最新推荐)

《深度解析JavaDTO(最新推荐)》DTO(DataTransferObject)是一种用于在不同层(如Controller层、Service层)之间传输数据的对象设计模式,其核心目的是封装数据,... 目录一、什么是DTO?DTO的核心特点:二、为什么需要DTO?(对比Entity)三、实际应用场景解析

java实现docker镜像上传到harbor仓库的方式

《java实现docker镜像上传到harbor仓库的方式》:本文主要介绍java实现docker镜像上传到harbor仓库的方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地... 目录1. 前 言2. 编写工具类2.1 引入依赖包2.2 使用当前服务器的docker环境推送镜像2.2

Go语言中nil判断的注意事项(最新推荐)

《Go语言中nil判断的注意事项(最新推荐)》本文给大家介绍Go语言中nil判断的注意事项,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录1.接口变量的特殊行为2.nil的合法类型3.nil值的实用行为4.自定义类型与nil5.反射判断nil6.函数返回的

sqlite3 命令行工具使用指南

《sqlite3命令行工具使用指南》本文系统介绍sqlite3CLI的启动、数据库操作、元数据查询、数据导入导出及输出格式化命令,涵盖文件管理、备份恢复、性能统计等实用功能,并说明命令分类、SQL语... 目录一、启动与退出二、数据库与文件操作三、元数据查询四、数据操作与导入导出五、查询输出格式化六、实用功

springboot项目打jar制作成镜像并指定配置文件位置方式

《springboot项目打jar制作成镜像并指定配置文件位置方式》:本文主要介绍springboot项目打jar制作成镜像并指定配置文件位置方式,具有很好的参考价值,希望对大家有所帮助,如有错误... 目录一、上传jar到服务器二、编写dockerfile三、新建对应配置文件所存放的数据卷目录四、将配置文

python如何创建等差数列

《python如何创建等差数列》:本文主要介绍python如何创建等差数列的问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录python创建等差数列例题运行代码回车输出结果总结python创建等差数列import numpy as np x=int(in