多种工具协同创建一个基于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

相关文章

Linux线程之线程的创建、属性、回收、退出、取消方式

《Linux线程之线程的创建、属性、回收、退出、取消方式》文章总结了线程管理核心知识:线程号唯一、创建方式、属性设置(如分离状态与栈大小)、回收机制(join/detach)、退出方法(返回/pthr... 目录1. 线程号2. 线程的创建3. 线程属性4. 线程的回收5. 线程的退出6. 线程的取消7.

MySQL 多列 IN 查询之语法、性能与实战技巧(最新整理)

《MySQL多列IN查询之语法、性能与实战技巧(最新整理)》本文详解MySQL多列IN查询,对比传统OR写法,强调其简洁高效,适合批量匹配复合键,通过联合索引、分批次优化提升性能,兼容多种数据库... 目录一、基础语法:多列 IN 的两种写法1. 直接值列表2. 子查询二、对比传统 OR 的写法三、性能分析

Spring Boot spring-boot-maven-plugin 参数配置详解(最新推荐)

《SpringBootspring-boot-maven-plugin参数配置详解(最新推荐)》文章介绍了SpringBootMaven插件的5个核心目标(repackage、run、start... 目录一 spring-boot-maven-plugin 插件的5个Goals二 应用场景1 重新打包应用

创建Java keystore文件的完整指南及详细步骤

《创建Javakeystore文件的完整指南及详细步骤》本文详解Java中keystore的创建与配置,涵盖私钥管理、自签名与CA证书生成、SSL/TLS应用,强调安全存储及验证机制,确保通信加密和... 目录1. 秘密键(私钥)的理解与管理私钥的定义与重要性私钥的管理策略私钥的生成与存储2. 证书的创建与

Python办公自动化实战之打造智能邮件发送工具

《Python办公自动化实战之打造智能邮件发送工具》在数字化办公场景中,邮件自动化是提升工作效率的关键技能,本文将演示如何使用Python的smtplib和email库构建一个支持图文混排,多附件,多... 目录前言一、基础配置:搭建邮件发送框架1.1 邮箱服务准备1.2 核心库导入1.3 基础发送函数二、

Javaee多线程之进程和线程之间的区别和联系(最新整理)

《Javaee多线程之进程和线程之间的区别和联系(最新整理)》进程是资源分配单位,线程是调度执行单位,共享资源更高效,创建线程五种方式:继承Thread、Runnable接口、匿名类、lambda,r... 目录进程和线程进程线程进程和线程的区别创建线程的五种写法继承Thread,重写run实现Runnab

基于Python实现一个图片拆分工具

《基于Python实现一个图片拆分工具》这篇文章主要为大家详细介绍了如何基于Python实现一个图片拆分工具,可以根据需要的行数和列数进行拆分,感兴趣的小伙伴可以跟随小编一起学习一下... 简单介绍先自己选择输入的图片,默认是输出到项目文件夹中,可以自己选择其他的文件夹,选择需要拆分的行数和列数,可以通过

Python中将嵌套列表扁平化的多种实现方法

《Python中将嵌套列表扁平化的多种实现方法》在Python编程中,我们常常会遇到需要将嵌套列表(即列表中包含列表)转换为一个一维的扁平列表的需求,本文将给大家介绍了多种实现这一目标的方法,需要的朋... 目录python中将嵌套列表扁平化的方法技术背景实现步骤1. 使用嵌套列表推导式2. 使用itert

C#读写文本文件的多种方式详解

《C#读写文本文件的多种方式详解》这篇文章主要为大家详细介绍了C#中各种常用的文件读写方式,包括文本文件,二进制文件、CSV文件、JSON文件等,有需要的小伙伴可以参考一下... 目录一、文本文件读写1. 使用 File 类的静态方法2. 使用 StreamReader 和 StreamWriter二、二进

Python使用pip工具实现包自动更新的多种方法

《Python使用pip工具实现包自动更新的多种方法》本文深入探讨了使用Python的pip工具实现包自动更新的各种方法和技术,我们将从基础概念开始,逐步介绍手动更新方法、自动化脚本编写、结合CI/C... 目录1. 背景介绍1.1 目的和范围1.2 预期读者1.3 文档结构概述1.4 术语表1.4.1 核