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
shirou 0f9f812472 Merge pull request #26 from logavanc/master
Update README.rst
11 years ago
.gitignore
LICENSE
README.rst Update README.rst 11 years ago
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 value check to avoid zero division error. 11 years ago
cpu_darwin.go add a import. 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 use 10microsend duration for CPUPercent test. 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
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/). The challenge is porting all 
psutil functions on some architectures...

Available Architectures
------------------------------------

- 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 a 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)}


Documentation
------------------------

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


More Info
--------------------

Several methods have been added which are not present in psutil, but which provide useful information.

- 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")

- 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")
  - Mhz
  - CacheSize
  - Flags        (ex: "fpu vme de pse tsc msr pae mce cx8 ...")

- 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
-----------------------

I have been influenced by the following great 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/


How to Contribute
---------------------------

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