1
0
mirror of https://github.com/shirou/gopsutil.git synced 2025-04-26 13:48:59 +08:00
shirou_gopsutil/README.rst

294 lines
7.8 KiB
ReStructuredText
Raw Normal View History

2014-04-18 16:34:47 +09:00
gopsutil: psutil for golang
==============================
2016-02-12 22:53:22 +09:00
.. image:: https://circleci.com/gh/shirou/gopsutil.svg?&style=shield
:target: https://circleci.com/gh/shirou/gopsutil
2014-04-25 14:38:26 +09:00
2015-12-11 12:31:08 -07:00
.. image:: https://coveralls.io/repos/shirou/gopsutil/badge.svg?branch=master
2014-05-11 17:06:53 +09:00
:target: https://coveralls.io/r/shirou/gopsutil?branch=master
2015-12-11 12:31:08 -07:00
.. image:: https://godoc.org/github.com/shirou/gopsutil?status.svg
:target: http://godoc.org/github.com/shirou/gopsutil
2014-05-11 17:06:53 +09:00
This is a port of psutil (http://pythonhosted.org/psutil/). The challenge is porting all
psutil functions on some architectures...
2014-04-22 12:38:12 +09:00
2016-04-07 15:34:49 +09:00
.. highlights:: Breaking Changes!
2016-04-07 15:34:49 +09:00
Breaking changes is introduced at v2. See `issue 174 <https://github.com/shirou/gopsutil/issues/174>`_ .
Migrating to v2
-------------------------
On gopsutil itself, `v2migration.sh <https://github.com/shirou/gopsutil/blob/v2/v2migration.sh>`_ is used for migration. It can not be commly used, but it may help to your migration.
Available Architectures
2014-04-22 12:31:36 +09:00
------------------------------------
2014-04-18 16:34:47 +09:00
2015-02-09 11:30:38 +09:00
- FreeBSD i386/amd64
- Linux i386/amd64/arm(raspberry pi)
2014-04-23 10:37:21 +09:00
- Windows/amd64
2014-12-30 22:09:05 +09:00
- Darwin/amd64
2014-04-23 12:53:27 +09:00
All works are implemented without cgo by porting c struct to golang struct.
2014-04-25 14:38:26 +09:00
Usage
2014-04-22 12:31:36 +09:00
---------
2016-04-07 15:34:49 +09:00
Note: gopsutil v2 breaks compatibility. If you want to stay with compatibility, please use v1 branch and vendoring.
2015-01-12 11:55:59 -05:00
.. code:: go
2014-04-22 12:31:36 +09:00
2016-04-07 15:34:49 +09:00
package main
2014-04-30 23:17:33 +09:00
import (
2016-04-07 15:34:49 +09:00
"fmt"
2014-04-30 23:17:33 +09:00
2016-04-07 15:34:49 +09:00
"github.com/shirou/gopsutil/mem"
2014-04-30 23:17:33 +09:00
)
func main() {
2016-04-07 15:34:49 +09:00
v, _ := mem.VirtualMemory()
2014-04-30 23:17:33 +09:00
2016-04-07 15:34:49 +09:00
// almost every return value is a struct
fmt.Printf("Total: %v, Free:%v, UsedPercent:%f%%\n", v.Total, v.Free, v.UsedPercent)
2014-04-30 23:17:33 +09:00
2016-04-07 15:34:49 +09:00
// convert to JSON. String() is also implemented
fmt.Println(v)
2014-04-30 23:17:33 +09:00
}
2014-04-22 12:31:36 +09:00
The output is below.
::
Total: 3179569152, Free:284233728, UsedPercent:84.508194%
2016-04-07 15:34:49 +09:00
{"total":3179569152,"available":492572672,"used":2895335424,"usedPercent":84.50819439828305, (snip...)}
2014-04-22 12:31:36 +09:00
You can set an alternative location to /proc by setting the HOST_PROC environment variable.
You can set an alternative location to /sys by setting the HOST_SYS environment variable.
You can set an alternative location to /etc by setting the HOST_ETC environment variable.
2014-04-22 12:31:36 +09:00
Documentation
------------------------
2014-04-22 12:31:36 +09:00
see http://godoc.org/github.com/shirou/gopsutil
More Info
2014-05-16 16:42:16 +09:00
--------------------
2015-01-01 00:47:24 +09:00
Several methods have been added which are not present in psutil, but will provide useful information.
2015-01-01 00:47:24 +09:00
- host/HostInfo() (linux)
- Hostname
- Uptime
- Procs
- OS (ex: "linux")
- Platform (ex: "ubuntu", "arch")
- PlatformFamily (ex: "debian")
- PlatformVersion (ex: "Ubuntu 13.10")
- VirtualizationSystem (ex: "LXC")
- VirtualizationRole (ex: "guest"/"host")
2015-01-01 00:47:24 +09:00
- cpu/CPUInfo() (linux, freebsd)
- CPU (ex: 0, 1, ...)
- VendorID (ex: "GenuineIntel")
- Family
- Model
- Stepping
- PhysicalID
- CoreID
- Cores (ex: 2)
- ModelName (ex: "Intel(R) Core(TM) i7-2640M CPU @ 2.80GHz")
2014-05-16 18:12:18 +09:00
- Mhz
- CacheSize
- Flags (ex: "fpu vme de pse tsc msr pae mce cx8 ...")
2014-05-16 18:12:18 +09:00
2015-01-01 00:47:24 +09:00
- load/LoadAvg() (linux, freebsd)
2014-05-16 19:03:15 +09:00
- Load1
- Load5
- Load15
2015-01-01 00:47:24 +09:00
- docker/GetDockerIDList() (linux only)
2014-06-10 14:38:01 +09:00
- container id list ([]string)
2015-01-01 00:47:24 +09:00
- docker/CgroupCPU() (linux only)
2014-06-10 14:38:01 +09:00
- user
- system
2015-01-01 00:47:24 +09:00
- docker/CgroupMem() (linux only)
2014-06-10 14:38:01 +09:00
- various status
2015-11-19 14:19:43 -07:00
- net_protocols (linux only)
- system wide stats on network protocols (i.e IP, TCP, UDP, etc.)
- sourced from /proc/net/snmp
- iptables nf_conntrack (linux only)
- system wide stats on netfilter conntrack module
- sourced from /proc/sys/net/netfilter/nf_conntrack_count
2014-06-24 14:50:52 +09:00
Some codes are ported from Ohai. many thanks.
2014-05-16 16:42:16 +09:00
2014-04-22 12:38:12 +09:00
Current Status
------------------
- x: work
- b: almost work but something broken
2015-02-09 11:30:38 +09:00
================= ====== ======= ====== =======
name Linux FreeBSD MacOSX Windows
2015-09-16 17:20:43 +09:00
cpu_times x x x x
2015-02-09 11:30:38 +09:00
cpu_count x x x x
2015-09-16 17:20:43 +09:00
cpu_percent x x x x
cpu_times_percent x x x x
2015-02-09 11:30:38 +09:00
virtual_memory x x x x
swap_memory x x x
disk_partitions x x x x
disk_io_counters x x
2015-02-09 11:30:38 +09:00
disk_usage x x x x
net_io_counters x x b x
boot_time x x x x
2015-02-09 11:30:38 +09:00
users x x x x
pids x x x x
pid_exists x x x x
2015-09-16 17:20:43 +09:00
net_connections x x
2015-11-19 14:19:43 -07:00
net_protocols x
2015-09-16 17:20:43 +09:00
net_if_addrs
net_if_stats
netfilter_conntrack x
2015-02-09 11:30:38 +09:00
================= ====== ======= ====== =======
Process class
^^^^^^^^^^^^^^^
2015-02-09 11:30:38 +09:00
================ ===== ======= ====== =======
name Linux FreeBSD MacOSX Windows
pid x x x x
ppid x x x x
name x x x x
cmdline x x x
2015-02-09 11:30:38 +09:00
create_time x
status x x x
2015-02-09 11:30:38 +09:00
cwd x
exe x x x
uids x x x
gids x x x
terminal x x x
io_counters x x
nice x x x x
2015-02-09 11:30:38 +09:00
num_fds x
num_ctx_switches x
num_threads x x x x
2015-02-09 11:30:38 +09:00
cpu_times x
memory_info x x x
2015-02-09 11:30:38 +09:00
memory_info_ex x
memory_maps x
open_files x
send_signal x x x
suspend x x x
resume x x x
terminate x x x
kill x x x
username x
ionice
rlimit
num_handlres
threads
2015-10-17 00:35:12 +09:00
cpu_percent x x
cpu_affinity
memory_percent
parent x x
children x x x
connections x x
is_running
2015-02-09 11:30:38 +09:00
================ ===== ======= ====== =======
Original Metrics
^^^^^^^^^^^^^^^^^^^
2015-02-09 11:30:38 +09:00
================== ===== ======= ====== =======
item Linux FreeBSD MacOSX Windows
**HostInfo**
2015-02-09 11:30:38 +09:00
hostname x x x x
uptime x x x
proces x x
os x x x x
platform x x x
platformfamiliy x x x
virtualization x
**CPU**
VendorID x x x x
Family x x x x
Model x x x x
Stepping x x x x
2015-02-09 11:30:38 +09:00
PhysicalID x
CoreID x
Cores x x
ModelName x x x x
**LoadAvg**
2015-02-09 11:30:38 +09:00
Load1 x x x
Load5 x x x
Load15 x x x
**GetDockerID**
2015-02-09 11:30:38 +09:00
container id x no no no
**CgroupsCPU**
2015-02-09 11:30:38 +09:00
user x no no no
system x no no no
**CgroupsMem**
2015-02-09 11:30:38 +09:00
various x no no no
================== ===== ======= ====== =======
2014-04-25 14:38:26 +09:00
- future work
2014-04-22 12:38:12 +09:00
- process_iter
- wait_procs
2014-04-25 14:38:26 +09:00
- Process class
2014-04-25 14:38:26 +09:00
- as_dict
- wait
2014-04-22 12:38:12 +09:00
2014-04-22 12:31:36 +09:00
License
------------
New BSD License (same as psutil)
Related Works
2014-04-22 12:31:36 +09:00
-----------------------
I have been influenced by the following great works:
2014-04-18 16:34:47 +09:00
- psutil: http://pythonhosted.org/psutil/
- dstat: https://github.com/dagwieers/dstat
2015-07-09 16:16:35 +03:00
- gosigar: https://github.com/cloudfoundry/gosigar/
2014-04-18 16:34:47 +09:00
- goprocinfo: https://github.com/c9s/goprocinfo
- go-ps: https://github.com/mitchellh/go-ps
2014-05-16 16:42:16 +09:00
- ohai: https://github.com/opscode/ohai/
2015-01-01 21:29:25 +09:00
- bosun: https://github.com/bosun-monitor/bosun/tree/master/cmd/scollector/collectors
- mackerel: https://github.com/mackerelio/mackerel-agent/tree/master/metrics
2014-04-29 15:34:48 +09:00
How to Contribute
2014-04-29 15:34:48 +09:00
---------------------------
1. Fork it
2. Create your feature branch (git checkout -b my-new-feature)
3. Commit your changes (git commit -am 'Add some feature')
4. Push to the branch (git push origin my-new-feature)
5. Create new Pull Request
My English is terrible, so documentation or correcting comments are also
2014-04-29 15:34:48 +09:00
welcome.