【Golang】探索进程资源监控的精妙细节:利用Gopsutil/Process实现高级进程性能和资源信息监控

【Golang】探索进程资源监控的精妙细节:利用Gopsutil/Process实现高级进程性能和资源信息监控

大家好 我是寸铁👊
总结了一篇【Golang】探索进程资源监控的精妙细节:利用Gopsutil/Process实现高级进程性能和资源信息监控的文章✨
喜欢的小伙伴可以点点关注 💝


前言🎏

在当今信息技术的浪潮中,对系统性能和资源利用的监控变得至关重要。特别是对于运行在服务器或云环境中的应用程序,了解和优化进程的资源消耗是提高系统效率和可靠性的关键。而使用 Go 语言的 Gopsutil 库,特别是其中的Process模块,为我们提供了强大的工具,能够深入监控和管理进程的各种资源。本文将探索如何利用 Gopsutil/Process 实现进程资源监控,并介绍一些常用的技术和方法。


Memory📟

MemoryInfo

newProcess, _ := process.NewProcess(18024) //参数:想监控的进程号pidinfo, _ := newProcess.MemoryInfo()fmt.Println("返回平台独立内存信息", info)

返回如下信息:
rSS:实际使用物理内存
vmS:虚拟使用内存
hwm: 表示进程所占用物理内存的峰值
data: 表示进程数据段的大小
stack: 表示进程堆栈段的大小
locked: 表示被锁定的内存大小
swap:交换分区


MemoryInfoEx

ex, _ := newProcess.MemoryInfoEx()
fmt.Println("MemoryInfoEx()返回与平台相关的内存信息: ", ex)

MemoryMaps

maps, _ := newProcess.MemoryMaps(true)
fmt.Println("MemoryMaps 从 /proc/(pid)/smaps 获取内存映射: ", maps)

MemoryPercent

memorypercent, _ := newProcess.MemoryPercent()
fmt.Println("MemoryPercent 返回此进程使用的总 RAM 的百分比: ", memorypercent)

RAM :是与CPU直接交换数据的内部存储器,也叫主存(内存)


CPU📀

主要是CPUPercent获取进程CPU使用率

cpupercent, _ := newProcess.CPUPercent()
fmt.Println("CPU_Percent返回此进程使用的 CPU 时间的百分比: ", cpupercent)times, _ := newProcess.Times()
fmt.Println("Times 返回进程的 CPU 时间: ", times)

cpu.Percent(time.Second, false)

这个函数的目的是返回一个包含每个逻辑CPU使用率百分比的切片。
其中的参数和返回值:

  • interval 参数表示获取 CPU 使用率的时间间隔。它是一个 time.Duration 类型的值,通常会传入一个时间段,比如 time.Second 表示每秒获取一次 CPU 使用率。
  • percpu 参数是一个布尔值,表示是否获取每个逻辑 CPU 的使用率。如果设置为 true,返回的切片将包含每个逻辑 CPU 的使用率百分比;如果设置为 false,返回的切片将只包含总的 CPU 使用率百分比。
  • 返回值是一个 []float64 类型的切片,其中包含了每个逻辑 CPU 或总 CPU 的使用率百分比。每个元素的取值范围是 0 到 100,表示对应 CPU 的使用率百分比。

关于CPUPercent的补充
在这里插入图片描述

查看官方文档源代码的注释,发现指的是进程的CPU的使用率
监控的是子进程其实返回的是子进程所在的父进程的CPU的使用率
子进程直接调用该函数,没有参数可以调整

Disk 💾

这里要注意Process没有提供与Disk直接相关的API
这里需要追溯到原来Python的gopsutil库结合输出结果
知道IOCounters返回进程的磁盘信息

counters, _ := newProcess.IOCounters()fmt.Println("IOCounters() 返回进程的磁盘信息:", counters)
    返回信息:readCount:磁盘读入的总数writeCount:写入磁盘的总数readBytes:磁盘读入的字节数writeBytes:写入磁盘的字节数

网络 💻

Process的网络信息由 netIOcounters监管
在这里插入图片描述

根据输入的参数(true/false)返回不同的信息,根据自己需求来。

netIOcounters, _ := newProcess.NetIOCounters(true)
fmt.Println("NetIOCounters 返回进程的网络信息: ", netIOcounters)

demo

package mainimport ("fmt""github.com/shirou/gopsutil/process"
)func main() {//获取到所有进程的详细信息p1, _ := process.Pids() //获取当前所有进程的pidfmt.Println("p1:", p1)//根据PID获得进程newProcess, _ := process.NewProcess(18024) //参数:想监控的进程号pid 从p1中选择测试info, _ := newProcess.MemoryInfo()fmt.Println("返回平台独立内存信息", info)/*返回如下信息://rSS:实际使用物理内存//vmS:虚拟使用内存//hwm: 表示进程所占用物理内存的峰值//data: 表示进程数据段的大小//stack: 表示进程堆栈段的大小//locked: 表示被锁定的内存大小//swap:交换分区*/ex, _ := newProcess.MemoryInfoEx()fmt.Println("MemoryInfoEx()返回与平台相关的内存信息: ", ex)maps, _ := newProcess.MemoryMaps(true)fmt.Println("MemoryMaps 从 /proc/(pid)/smaps 获取内存映射: ", maps)memorypercent, _ := newProcess.MemoryPercent()fmt.Println("MemoryPercent 返回此进程使用的总 RAM 的百分比: ", memorypercent)//RAM :是与CPU直接交换数据的内部存储器,也叫主存(内存)cpupercent, _ := newProcess.CPUPercent()fmt.Println("CPU_Percent返回此进程使用的 CPU 时间的百分比: ", cpupercent)times, _ := newProcess.Times()fmt.Println("Times 返回进程的 CPU 时间: ", times)counters, _ := newProcess.IOCounters()fmt.Println("IOCounters() 返回进程的磁盘信息:", counters)/*//readCount:磁盘读入的总数//writeCount:写入磁盘的总数//readBytes:磁盘读入的字节数//writeBytes:写入磁盘的字节数*///返回信息样例{"readCount":6689,"writeCount":8516,"readBytes":4778776,"writeBytes":20146627}netIOcounters, _ := newProcess.NetIOCounters(true)fmt.Println("NetIOCounters 返回进程的网络信息: ", netIOcounters)}

结果如下:
在这里插入图片描述

这里的nil(空)实际上是go调用函数API返回的第二个结果:error
一般情况下为nil 开发中最好还是写一个判断nil的语句(处理错误)
返回的第一个结果就是我们想看到的数据和信息


结语 🎏

通过本文的学习,您已经了解了如何利用 Gopsutil/Process 库在 Go 语言中实现了进程资源监控。从获取进程信息到监测 CPU内存磁盘网络等资源的使用情况,您现在拥有了一套强大的工具来监控和优化您的应用程序。不断探索和应用这些技术,将有助于提高系统的性能和稳定性,为用户提供更好的体验。愿您在编程的旅程中不断前行,创造出更加优秀的作品!


看到这里的小伙伴,恭喜你又掌握了一个技能👊
希望大家能取得胜利,坚持就是胜利💪
我是寸铁!我们下期再见💕


往期好文💕

保姆级教程

【保姆级教程】Windows11下go-zero的etcd安装与初步使用

【保姆级教程】Windows11安装go-zero代码生成工具goctl、protoc、go-zero

【Go-Zero】手把手带你在goland中创建api文件并设置高亮


报错解决

【Go-Zero】Error: user.api 27:9 syntax error: expected ‘:‘ | ‘IDENT‘ | ‘INT‘, got ‘(‘ 报错解决方案及api路由注意事项

【Go-Zero】Error: only one service expected goctl一键转换生成rpc服务错误解决方案

【Go-Zero】【error】 failed to initialize database, got error Error 1045 (28000):报错解决方案

【Go-Zero】Error 1045 (28000): Access denied for user ‘root‘@‘localhost‘ (using password: YES)报错解决方案

【Go-Zero】type mismatch for field “Auth.AccessSecret“, expect “string“, actual “number“报错解决方案

【Go-Zero】Error: user.api 30:2 syntax error: expected ‘)‘ | ‘KEY‘, got ‘IDENT‘报错解决方案

【Go-Zero】Windows启动rpc服务报错panic:context deadline exceeded解决方案


Go面试向

【Go面试向】defer与time.sleep初探

【Go面试向】defer与return的执行顺序初探

【Go面试向】Go程序的执行顺序

【Go面试向】rune和byte类型的认识与使用

【Go面试向】实现map稳定的有序遍历的方式

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

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

3-1RT-Thread时钟管理

这里写自定义目录标题 时钟节拍是RT thread操作系统的最小时间单位。 第一个功能,rt tick值自动加1,在RT thread当中通过RT_USING_SMP定义了多核和单核的场景。第二个功能,检查当前线程的时间片,首先获取当前线程,将当…

Flowable项目启动报错#java.time.LocalDateTime cannot be cast to java.lang.String

Flowable 项目启动后报错 flow项目第一次启动创建表成功,但是第二次启动时报错信息如下: 1、Error creating bean with name ‘appRepositoryServiceBean’ defined in class 2、Error creating bean with name ‘flowableAppEngine’: FactoryBean t…

React实战(一)初始化项目、配置router、redux、axios

(一)初始化项目 1.安装项目 npx create-react-app 项目名 编译报错: 解决办法:安装最新的babel-preset-react-app npm install babel-preset-react-applatest 2.配置项目 (1)配置文件目录 (2)使用craco配置webpack.config npm install craco/crac…

传统工科硕士想转嵌入式,时间够吗?

在开始前刚好我有一些资料,是我根据网友给的问题精心整理了一份「嵌入式的资料从专业入门到高级教程」, 点个关注在评论区回复“888”之后私信回复“888”,全部无偿共享给大家!!! 零基础开始学&#xff0…

每天五分钟深度学习pytorch:pytorch中的广播机制是什么?

本文重点 在pytorch中经常有张量和张量之间的运算,那么有一点需要注意,那就是维度要匹配,如果维度不匹配就有可能出现问题。如果维度不一致,此时也可以同时进行操作,此时就需要使用pytorch中的广播机制,本节课程就讲解pytorch中的广播机制。 广播机制示意图 如上就是py…

Prism 入门06,发布订阅(入门完结)

本章节介绍使用 Prism 框架的消息聚合器 IEventAggregator ,实现如何进行消息发布,订阅,取消订阅的功能 继续使用上一章节使用的 Prism WPF 空模板项目 BlankApp1 1.首先,在使用 Prism 框架当中,进行事件消息的发布和订阅之前,需要定义发布事件的事件消息模型。如下所示:…

[图解]建模相关的基础知识-05

1 00:00:01,510 --> 00:00:03,900 练习,我们就出这一道就行了 2 00:00:04,230 --> 00:00:07,210 这些都是像数理逻辑 3 00:00:08,140 --> 00:00:10,570 包括信息专业的 4 00:00:11,350 --> 00:00:12,900 包括文科的 5 00:00:12,910 --> 00:00:14…

反激肖特基整流二级管及输出滤波电容的设计

反激肖特基整流二级管的设计 1 耐压:Vdr > Vor*1.2(1.2为裕量) 其中Vor (Vo Vf)*(Np/Ns) 2 电流计算: Id > 4Io,Id为峰值电流 肖特基上面的吸收电路的计算 直接调试更加快捷,首先确定吸收电容的容量&…

linux内存缓存占用过高分析和优化

1、什么是buffer/cache ? buffer/cache其实是作为服务器系统的文件数据缓存使用的,尤其是针对进程对文件存在read/write操作的时候,所以当你的服务进程在对文件进行读写的时候,Linux内核为了提高服务的读写速度,则将会…

【前端基础】CSS介绍|CSS选择器|常用CSS

目录 一、CSS介绍 1.1 什么是CSS 1.2 基本语法规范 1.3 引⼊⽅式 1.4 规范 💡二、CSS选择器 1. 标签选择器 2. class选择器 3. id选择器 4. 复合选择器 5. 通配符选择器 三、常用CSS 3.1 color 3.2 font-size 3.3 border 3.4 width/height 3.5 padd…

单片机原理及技术(三)—— AT89S51单片机(二)(C51编程)

一、AT89S51单片机的并行I/O端口 1.1 P0口 AT89S51的P0口是一个通用的I/O口,可以用于输入和输出。每个引脚都可以通过软件控制为输入或输出模式。 1.1.1 P0口的工作原理 P0口的工作原理是通过对P0寄存器的读写操作来控制P0口的引脚。 输出模式:当P0口…

【进程调度的基本过程】初步认识进程和线程的区别与联系:计算机是如何工作的

​ 🔥个人主页: 中草药 🔥专栏:【Java】登神长阶 史诗般的Java成神之路 🐺一.冯诺依曼体系结构 认识计算机的祖师爷 -- 冯诺依曼 冯诺依曼(John von Neumann,1903年12⽉28⽇-1957年2⽉8⽇&…

docker实战命令大全

文章目录 1 环境准备1.1 移除旧版本Docker1.2安装工具包1.3配置docker yum源 2 安装最新docker2.1 设置开机自启docker2.2配置加速器 3 实操-镜像3.1搜索镜像3.2下载镜像3.3查看镜像3.4 删除镜像 4 实操-容器4.1运行nginx容器4.2 查看容器4.3启动容器4.5关闭容器4.6查看容器日志…

软件测试--Linux快速入门

文章目录 软件测试-需要掌握的Linux指令Linux命令操作技巧Linx命令的基本组成常用命令 软件测试-需要掌握的Linux指令 Linux命令操作技巧 使用Tab键自动补全上下键进行翻找之前输入的命令命令执行后无法停止使用CtrC,结束屏幕输出 Linx命令的基本组成 命令 [-选项] [参数] …

nginx c++模块编译

不论是c还是c,nginx的第三方模块编写没什么太区别,但是提供给nginx调用的,必须是纯c的接口。 先说下为什么不能使用c编译nginx,nginx是纯c写的,而且c是兼容c的,但是用c(g)编译nginx的框架,就会出…

深度网络学习笔记(二)——Transformer架构详解(包括多头自注意力机制)

Transformer架构详解 前言Transformer的整体架构多头注意力机制(Multi-Head Attention)具体步骤1. 步骤12. 步骤23. 步骤34. 步骤4 Self-Attention应用与比较Self-Attention用于图像处理Self-Attention vs. CNNSelf-Attention vs. RNN Transformer架构详…

【嵌入式】智能系统优化:【C++】驱动的【机器学习】与【数据挖掘】技术

目录 一、嵌入式系统简介 二、C在嵌入式系统中的优势 三、机器学习在嵌入式系统中的挑战 四、C实现机器学习模型的基本步骤 五、实例分析:使用C在嵌入式系统中实现手写数字识别 1. 数据准备 2. 模型训练与压缩 3. 模型部署 六、优化与分析 1. 模型优化 模…

生成式人工智能如何运作?

一、简述 生成式人工智能是一种可用于创建内容(包括对话、故事、图像、视频和音乐)的人工智能。人工智能技术试图在图像识别、自然语言处理(NLP)和翻译等非传统计算任务中模仿人类智能。生成式人工智能是人工智能的发展方向。您可…

使用python绘制桑基图

使用python绘制桑基图 桑基图效果代码 桑基图 桑基图(Sankey Diagram)是一种用来表示流动(如能源、资金、材料等)在不同实体之间转移的图表。 每个流的宽度与流量成正比,通常用于显示能量或成本流动的分布情况。 桑基…

RocketMQ教程(三):RocketMQ的核心组件

四个核心组件 RocketMQ 的架构采用了典型的分布式系统设计理念,以确保高性能、高可用和可扩展性。RocketMQ 主要由四个核心组件构成:NameServer、Broker、Producer 和 Consumer。下面是对这些组件以及它们在 RocketMQ 中的角色和功能的概述: 1. NameServer 角色和功能:Name…