Go to file
Nikolay Sivko e8c96ea07d fix DiskIOCountersStat.iotime on linux 2014-09-16 14:08:52 +04:00
.gitignore initial import. 2014-04-18 16:34:47 +09:00
LICENSE update README and add LICENSE file. 2014-04-22 12:31:36 +09:00
README.rst fix some bad english on README.rst 2014-06-24 14:50:52 +09:00
common.go GoFmt fixes 2014-08-15 19:18:30 +02:00
common_darwin.go add darwin placeholder. Not working yet. 2014-08-08 23:09:28 +09:00
common_freebsd.go golint on Linux 2014-04-30 16:16:07 +09:00
common_windows.go implement net_io_counters on Windows. 2014-05-16 11:33:35 +09:00
cpu.go implements CPUInfoStat on FreeBSD. 2014-05-16 18:39:17 +09:00
cpu_darwin.go Rename idents to gofmt-specs 2014-08-15 20:05:26 +02:00
cpu_freebsd.go Rename idents to gofmt-specs 2014-08-15 20:05:26 +02:00
cpu_linux.go rename parseFoo to mustParseFoo because these funcs are just a util func. 2014-05-18 22:43:12 +09:00
cpu_test.go Fixed missing error handling, error msg 2014-08-15 19:09:43 +02:00
cpu_windows.go add CPUInfo placeholder on Windows. 2014-05-16 18:42:37 +09:00
disk.go DiskIOCountersStat.IoTime on linux 2014-08-26 17:33:57 +04:00
disk_darwin.go add darwin placeholder. Not working yet. 2014-08-08 23:09:28 +09:00
disk_freebsd.go fill DiskPartitionStat.Device on freebsd 2014-08-26 17:32:38 +04:00
disk_freebsd_amd64.go Rename idents to gofmt-specs 2014-08-15 20:05:26 +02:00
disk_linux.go fix DiskIOCountersStat.iotime on linux 2014-09-16 14:08:52 +04:00
disk_test.go DiskIOCountersStat.IoTime on linux 2014-08-26 17:33:57 +04:00
disk_unix.go add Inode test and go fmt 2014-08-26 22:17:35 +09:00
disk_windows.go disk inodes usage 2014-08-26 12:38:52 +04:00
docker_linux.go Rename idents to gofmt-specs 2014-08-15 20:05:26 +02:00
docker_linux_test.go GoFmt fixes 2014-08-15 19:18:30 +02:00
host.go add detecting virtualization system on Linux. 2014-05-20 19:36:19 +09:00
host_darwin.go Rename idents to gofmt-specs 2014-08-15 20:05:26 +02:00
host_freebsd.go add detecting virtualization system on Linux. 2014-05-20 19:36:19 +09:00
host_freebsd_amd64.go Rename idents to gofmt-specs 2014-08-15 20:05:26 +02:00
host_linux.go Small gofmt fixes 2014-08-15 20:09:34 +02:00
host_linux_amd64.go golint on Linux 2014-04-30 16:16:07 +09:00
host_linux_arm.go now support linux/arm (raspberry pi) 2014-05-14 00:12:17 +09:00
host_linux_test.go implement redhatishVersion and platform on Linux. 2014-05-27 22:37:23 +09:00
host_test.go could not get coverage from test subdirectory. move back to top. 2014-05-23 10:31:47 +09:00
host_windows.go fix the type declaration on Windows 2014-05-18 23:48:29 +09:00
load.go implements String() which return as JSON to every structs. 2014-05-01 18:43:11 +09:00
load_darwin.go add darwin placeholder. Not working yet. 2014-08-08 23:09:28 +09:00
load_freebsd.go fix return type. 2014-05-20 19:29:41 +09:00
load_linux.go change various func return type to pointer. 2014-05-01 12:01:30 +09:00
load_test.go could not get coverage from test subdirectory. move back to top. 2014-05-23 10:31:47 +09:00
load_windows.go fix LoadAvg definition error on Windows. 2014-08-26 23:56:38 +09:00
mem.go implements String() which return as JSON to every structs. 2014-05-01 18:43:11 +09:00
mem_darwin.go add darwin placeholder. Not working yet. 2014-08-08 23:09:28 +09:00
mem_freebsd.go rename parseFoo to mustParseFoo because these funcs are just a util func. 2014-05-18 22:43:12 +09:00
mem_linux.go Bug fixed division 0 in SwapMemory() 2014-09-10 01:23:12 +07:00
mem_test.go could not get coverage from test subdirectory. move back to top. 2014-05-23 10:31:47 +09:00
mem_windows.go change various func return type to pointer. 2014-05-01 12:01:30 +09:00
net.go change net hardware adress to string. 2014-06-03 00:39:47 +09:00
net_darwin.go add darwin placeholder. Not working yet. 2014-08-08 23:09:28 +09:00
net_freebsd.go implements NetIOCounters() on FreeBSD. 2014-05-18 23:23:47 +09:00
net_linux.go fix NetIOCounters on linux 2014-08-18 11:14:26 +04:00
net_test.go change net hardware adress to string. 2014-06-03 00:39:47 +09:00
net_windows.go Rename idents to gofmt-specs 2014-08-15 20:05:26 +02:00
process.go change NumCtxSwitchesStat fields to int64 2014-09-13 00:29:54 +04:00
process_darwin.go Process.Username method for posix-compliant OS 2014-08-29 16:38:01 +04:00
process_darwin_amd64.go Rename idents to gofmt-specs 2014-08-15 20:05:26 +02:00
process_freebsd.go Process.Username method for posix-compliant OS 2014-08-29 16:38:01 +04:00
process_freebsd_amd64.go Rename idents to gofmt-specs 2014-08-15 20:05:26 +02:00
process_linux.go change NumCtxSwitchesStat fields to int64 2014-09-13 00:29:54 +04:00
process_linux_amd64.go Rename idents to gofmt-specs 2014-08-15 20:05:26 +02:00
process_linux_arm.go Rename idents to gofmt-specs 2014-08-15 20:05:26 +02:00
process_posix.go Process.Username method for posix-compliant OS 2014-08-29 16:38:01 +04:00
process_posix_test.go could not get coverage from test subdirectory. move back to top. 2014-05-23 10:31:47 +09:00
process_test.go Rename idents to gofmt-specs 2014-08-15 20:05:26 +02:00
process_windows.go Rename idents to gofmt-specs 2014-08-15 20:05:26 +02:00
windows_memo.rst add windows implementation memo. 2014-04-25 23:45:36 +09:00

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.