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

相关文章

Java枚举类实现Key-Value映射的多种实现方式

《Java枚举类实现Key-Value映射的多种实现方式》在Java开发中,枚举(Enum)是一种特殊的类,本文将详细介绍Java枚举类实现key-value映射的多种方式,有需要的小伙伴可以根据需要... 目录前言一、基础实现方式1.1 为枚举添加属性和构造方法二、http://www.cppcns.co

Python基于wxPython和FFmpeg开发一个视频标签工具

《Python基于wxPython和FFmpeg开发一个视频标签工具》在当今数字媒体时代,视频内容的管理和标记变得越来越重要,无论是研究人员需要对实验视频进行时间点标记,还是个人用户希望对家庭视频进行... 目录引言1. 应用概述2. 技术栈分析2.1 核心库和模块2.2 wxpython作为GUI选择的优

Linux卸载自带jdk并安装新jdk版本的图文教程

《Linux卸载自带jdk并安装新jdk版本的图文教程》在Linux系统中,有时需要卸载预装的OpenJDK并安装特定版本的JDK,例如JDK1.8,所以本文给大家详细介绍了Linux卸载自带jdk并... 目录Ⅰ、卸载自带jdkⅡ、安装新版jdkⅠ、卸载自带jdk1、输入命令查看旧jdkrpm -qa

Tomcat版本与Java版本的关系及说明

《Tomcat版本与Java版本的关系及说明》:本文主要介绍Tomcat版本与Java版本的关系及说明,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Tomcat版本与Java版本的关系Tomcat历史版本对应的Java版本Tomcat支持哪些版本的pythonJ

Python+PyQt5实现多屏幕协同播放功能

《Python+PyQt5实现多屏幕协同播放功能》在现代会议展示、数字广告、展览展示等场景中,多屏幕协同播放已成为刚需,下面我们就来看看如何利用Python和PyQt5开发一套功能强大的跨屏播控系统吧... 目录一、项目概述:突破传统播放限制二、核心技术解析2.1 多屏管理机制2.2 播放引擎设计2.3 专

idea中创建新类时自动添加注释的实现

《idea中创建新类时自动添加注释的实现》在每次使用idea创建一个新类时,过了一段时间发现看不懂这个类是用来干嘛的,为了解决这个问题,我们可以设置在创建一个新类时自动添加注释,帮助我们理解这个类的用... 目录前言:详细操作:步骤一:点击上方的 文件(File),点击&nbmyHIgsp;设置(Setti

Docker镜像pull失败两种解决办法小结

《Docker镜像pull失败两种解决办法小结》有时候我们在拉取Docker镜像的过程中会遇到一些问题,:本文主要介绍Docker镜像pull失败两种解决办法的相关资料,文中通过代码介绍的非常详细... 目录docker 镜像 pull 失败解决办法1DrQwWCocker 镜像 pull 失败解决方法2总

使用Java实现通用树形结构构建工具类

《使用Java实现通用树形结构构建工具类》这篇文章主要为大家详细介绍了如何使用Java实现通用树形结构构建工具类,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录完整代码一、设计思想与核心功能二、核心实现原理1. 数据结构准备阶段2. 循环依赖检测算法3. 树形结构构建4. 搜索子

利用Python开发Markdown表格结构转换为Excel工具

《利用Python开发Markdown表格结构转换为Excel工具》在数据管理和文档编写过程中,我们经常使用Markdown来记录表格数据,但它没有Excel使用方便,所以本文将使用Python编写一... 目录1.完整代码2. 项目概述3. 代码解析3.1 依赖库3.2 GUI 设计3.3 解析 Mark

Java 中实现异步的多种方式

《Java中实现异步的多种方式》文章介绍了Java中实现异步处理的几种常见方式,每种方式都有其特点和适用场景,通过选择合适的异步处理方式,可以提高程序的性能和可维护性,感兴趣的朋友一起看看吧... 目录1. 线程池(ExecutorService)2. CompletableFuture3. ForkJoi