You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
Go to file
KenjiTakahashi 13e0d3433f CPUPercent 11 years ago
.gitignore
LICENSE
README.rst
common.go readLinesOffsetN helper for reading only specific part of the file 11 years ago
common_darwin.go
common_freebsd.go
common_windows.go
cpu.go CPUPercent 11 years ago
cpu_darwin.go CPUTimes percpu for Darwin 11 years ago
cpu_freebsd.go CPUTimes percpu for FreeBSD 11 years ago
cpu_linux.go CPUTimes percpu for Linux 11 years ago
cpu_test.go CPUPercent 11 years ago
cpu_windows.go TODO: CPUTimes percpu for Windows 11 years ago
disk.go add SerialNumber to DiskIOCounterStat. 11 years ago
disk_darwin.go
disk_freebsd.go fill DiskPartitionStat.Device on freebsd 11 years ago
disk_freebsd_amd64.go Rename idents to gofmt-specs 11 years ago
disk_linux.go sorry, I committed an old file. 11 years ago
disk_test.go add SerialNumber to DiskIOCounterStat. 11 years ago
disk_unix.go unix disk usage in bytes 11 years ago
disk_windows.go disk inodes usage 11 years ago
docker_linux.go Rename idents to gofmt-specs 11 years ago
docker_linux_test.go GoFmt fixes 11 years ago
host.go
host_darwin.go remove "mustParse" function on darwin. 11 years ago
host_freebsd.go remove mustParse on frebsd. 11 years ago
host_freebsd_amd64.go Rename idents to gofmt-specs 11 years ago
host_linux.go Small gofmt fixes 11 years ago
host_linux_amd64.go
host_linux_arm.go
host_linux_test.go
host_test.go
host_windows.go
load.go
load_darwin.go
load_freebsd.go
load_linux.go
load_test.go
load_windows.go fix LoadAvg definition error on Windows. 11 years ago
mem.go
mem_darwin.go fix getPagesize parse error. 11 years ago
mem_freebsd.go remove mustParse on frebsd. 11 years ago
mem_linux.go [linux] fill SwapMemoryStat.Sin/Sout from /proc/vmstat 11 years ago
mem_test.go remove mustParse on frebsd. 11 years ago
mem_windows.go
net.go
net_darwin.go remove "mustParse" function on darwin. 11 years ago
net_freebsd.go remove mustParse on frebsd. 11 years ago
net_linux.go error handling in linux is now unsuppressed. 11 years ago
net_test.go
net_windows.go Rename idents to gofmt-specs 11 years ago
process.go * fix IOCountersStat 11 years ago
process_darwin.go Process.Username method for posix-compliant OS 11 years ago
process_darwin_amd64.go Rename idents to gofmt-specs 11 years ago
process_freebsd.go Process.Username method for posix-compliant OS 11 years ago
process_freebsd_amd64.go Rename idents to gofmt-specs 11 years ago
process_linux.go * fix IOCountersStat 11 years ago
process_linux_amd64.go Rename idents to gofmt-specs 11 years ago
process_linux_arm.go Rename idents to gofmt-specs 11 years ago
process_posix.go error handling in linux is now unsuppressed. 11 years ago
process_posix_test.go
process_test.go Rename idents to gofmt-specs 11 years ago
process_windows.go Rename idents to gofmt-specs 11 years ago
windows_memo.rst

README.rst

gopsutil: psutil for golang
==============================

.. image:: https://drone.io/github.com/shirou/gopsutil/status.png
        :target: https://drone.io/github.com/shirou/gopsutil

.. image:: https://coveralls.io/repos/shirou/gopsutil/badge.png?branch=master
        :target: https://coveralls.io/r/shirou/gopsutil?branch=master


This is a port of psutil(http://pythonhosted.org/psutil/). This
challenges porting all psutil functions on some architectures.

Available archtectures
------------------------------------

- FreeBSD/amd64
- Linux/amd64
- Linux/arm (raspberry pi)
- Windows/amd64

(I do not have a darwin machine)


All works are implemented without cgo by porting c struct to golang struct.


Usage
---------

::

   import (
   	"fmt"

   	"github.com/shirou/gopsutil"
   )

   func main() {
   	v, _ := gopsutil.VirtualMemory()

   	// almost every return value is struct
   	fmt.Printf("Total: %v, Free:%v, UsedPercent:%f%%\n", v.Total, v.Free, v.UsedPercent)

   	// convert to JSON. String() is also implemented
   	fmt.Println(v)
   }

The output is below.

::

  Total: 3179569152, Free:284233728, UsedPercent:84.508194%
  {"total":3179569152,"available":492572672,"used":2895335424,"usedPercent":84.50819439828305, (snip)}


Document
----------

see http://godoc.org/github.com/shirou/gopsutil


More info
--------------------

To becomes more useful, I have some methods which produces more information.

- Hostinfo()  (linux)

  - OS
  - Platform (ex: ubuntu, arch)
  - Platform family (ex: debian)
  - Platform Version (ex: Ubuntu 13.10)
  - VirtualizationSystem (ex: LXC)
  - VirtualizationRole (ex: guest/host)

- CPUInfoStat()  (linux, freebsd)

  - Processer
  - Vendor ID
  - Model name
  - cores
  - Mhz
  - etc...

- LoadAvg()  (linux, freebsd)

  - Load1
  - Load5
  - Load15

- GetDockerIDList() (linux)

  - container id list ([]string)

- CgroupCPU() (linux)

  - user
  - system

- CgroupMem() (linux)

  - various status

Some codes are ported from Ohai. many thanks.


Current Status
------------------

- done

  - cpu_times (linux, freebsd)
  - cpu_count (linux, freebsd, windows)
  - virtual_memory (linux, freebsd, windows)
  - swap_memory (linux, freebsd)
  - disk_partitions (linux, freebsd, windows)
  - disk_io_counters (linux)
  - disk_usage (linux, freebsd, windows)
  - net_io_counters (linux, freebsd, windows)
  - boot_time (linux, freebsd, windows(but little broken))
  - users (linux, freebsd)
  - pids (linux, freebsd)
  - pid_exists (linux, freebsd)
  - Process class

    - pid (linux, freebsd, windows)
    - ppid (linux, freebsd, windows)
    - name (linux)
    - cmdline (linux)
    - create_time (linux)
    - status (linux)
    - cwd (linux)
    - exe (linux, freebsd, windows)
    - uids (linux, freebsd)
    - gids (linux, freebsd)
    - terminal (linux, freebsd)
    - io_counters (linux)
    - nice (linux)
    - num_fds (linux)
    - num_ctx_switches (linux)
    - num_threads (linux, freebsd, windows)
    - cpu_times (linux)
    - memory_info (linux, freebsd)
    - memory_info_ex (linux)
    - memory_maps() (linux)
    - open_files (linux)
    - send_signal (linux, freebsd)
    - suspend (linux, freebsd)
    - resume (linux, freebsd)
    - terminate (linux, freebsd)
    - kill (linux, freebsd)

- not yet

  - cpu_percent
  - cpu_times_percent
  - net_connections
  - Process class

    - username
    - ionice
    - rlimit
    - num_handlers
    - threads
    - cpu_percent
    - cpu_affinity
    - memory_percent
    - children
    - connections
    - is_running


- future work

  - process_iter
  - wait_procs
  - Process class

    - parent (use ppid instead)
    - as_dict
    - wait


License
------------

New BSD License (same as psutil)


Related works
-----------------------

- psutil: http://pythonhosted.org/psutil/
- dstat: https://github.com/dagwieers/dstat
- gosiger: https://github.com/cloudfoundry/gosigar/
- goprocinfo: https://github.com/c9s/goprocinfo
- go-ps: https://github.com/mitchellh/go-ps
- ohai: https://github.com/opscode/ohai/

I have influenced from these great works.

How to Contributing
---------------------------

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 engilsh is terrible, documentation or correcting comments are also
welcome.