博客
关于我
Go语言获取系统性能数据gopsutil库
阅读量:447 次
发布时间:2019-03-06

本文共 2419 字,大约阅读时间需要 8 分钟。

目录

go 从入门到放弃完整教程目录(更有python、go、pytorch、tensorflow、爬虫、人工智能教学等着你):

更新、更全的《Go从入门到放弃》的更新网站,更有python、go、人工智能教学等着你:
psutil是一个跨平台进程和系统监控的Python库,而gopsutil是其Go语言版本的实现。本文介绍了它的基本使用。

Go语言部署简单、性能好的特点非常适合做一些诸如采集系统信息和监控的服务,本文介绍的gopsutil库是知名Python库:psutil的一个Go语言版本的实现。

一、安装

go get github.com/shirou/gopsutil

二、使用

2.1 CPU

采集CPU相关信息。

import "github.com/shirou/gopsutil/cpu"// cpu infofunc getCpuInfo() {	cpuInfos, err := cpu.Info()	if err != nil {		fmt.Printf("get cpu info failed, err:%v", err)	}	for _, ci := range cpuInfos {		fmt.Println(ci)	}	// CPU使用率	for {		percent, _ := cpu.Percent(time.Second, false)		fmt.Printf("cpu percent:%v\n", percent)	}}

获取CPU负载信息:

import "github.com/shirou/gopsutil/load"func getCpuLoad() {	info, _ := load.Avg()	fmt.Printf("%v\n", info)}

2.2 Memory

import "github.com/shirou/gopsutil/mem"// mem infofunc getMemInfo() {	memInfo, _ := mem.VirtualMemory()	fmt.Printf("mem info:%v\n", memInfo)}

2.3 Host

import "github.com/shirou/gopsutil/host"// host infofunc getHostInfo() {	hInfo, _ := host.Info()	fmt.Printf("host info:%v uptime:%v boottime:%v\n", hInfo, hInfo.Uptime, hInfo.BootTime)}

2.4 Disk

import "github.com/shirou/gopsutil/disk"// disk infofunc getDiskInfo() {	parts, err := disk.Partitions(true)	if err != nil {		fmt.Printf("get Partitions failed, err:%v\n", err)		return	}	for _, part := range parts {		fmt.Printf("part:%v\n", part.String())		diskInfo, _ := disk.Usage(part.Mountpoint)		fmt.Printf("disk info:used:%v free:%v\n", diskInfo.UsedPercent, diskInfo.Free)	}	ioStat, _ := disk.IOCounters()	for k, v := range ioStat {		fmt.Printf("%v:%v\n", k, v)	}}

2.5 net IO

import "github.com/shirou/gopsutil/net"func getNetInfo() {	info, _ := net.IOCounters(true)	for index, v := range info {		fmt.Printf("%v:%v send:%v recv:%v\n", index, v, v.BytesSent, v.BytesRecv)	}}

三、net

3.1 获取本机IP的两种方式

func GetLocalIP() (ip string, err error) {	addrs, err := net.InterfaceAddrs()	if err != nil {		return	}	for _, addr := range addrs {		ipAddr, ok := addr.(*net.IPNet)		if !ok {			continue		}		if ipAddr.IP.IsLoopback() {			continue		}		if !ipAddr.IP.IsGlobalUnicast() {			continue		}		return ipAddr.IP.String(), nil	}	return}

或:

// Get preferred outbound ip of this machinefunc GetOutboundIP() string {	conn, err := net.Dial("udp", "8.8.8.8:80")	if err != nil {		log.Fatal(err)	}	defer conn.Close()	localAddr := conn.LocalAddr().(*net.UDPAddr)	fmt.Println(localAddr.String())	return localAddr.IP.String()}

转载地址:http://kxgyz.baihongyu.com/

你可能感兴趣的文章
mysql 查看锁_阿里/美团/字节面试官必问的Mysql锁机制,你真的明白吗
查看>>
MySql 查询以逗号分隔的字符串的方法(正则)
查看>>
MySQL 查询优化:提速查询效率的13大秘籍(避免使用SELECT 、分页查询的优化、合理使用连接、子查询的优化)(上)
查看>>
mysql 查询,正数降序排序,负数升序排序
查看>>
MySQL 树形结构 根据指定节点 获取其下属的所有子节点(包含路径上的枝干节点和叶子节点)...
查看>>
mysql 死锁 Deadlock found when trying to get lock; try restarting transaction
查看>>
mysql 死锁(先delete 后insert)日志分析
查看>>
MySQL 死锁了,怎么办?
查看>>
MySQL 深度分页性能急剧下降,该如何优化?
查看>>
MySQL 深度分页性能急剧下降,该如何优化?
查看>>
MySQL 添加列,修改列,删除列
查看>>
mysql 添加索引
查看>>
MySQL 添加索引,删除索引及其用法
查看>>
MySQL 用 limit 为什么会影响性能?
查看>>
MySQL 用 limit 为什么会影响性能?有什么优化方案?
查看>>
MySQL 用户权限管理:授权、撤销、密码更新和用户删除(图文解析)
查看>>
mysql 用户管理和权限设置
查看>>
MySQL 的 varchar 水真的太深了!
查看>>
mysql 的GROUP_CONCAT函数的使用(group_by 如何显示分组之前的数据)
查看>>
MySQL 的instr函数
查看>>