1
0
mirror of https://github.com/shirou/gopsutil.git synced 2025-04-26 13:48:59 +08:00
2014-05-01 12:01:30 +09:00
2014-04-18 16:34:47 +09:00
2014-04-30 16:16:07 +09:00
2014-04-30 16:22:54 +09:00
2014-04-30 16:19:39 +09:00
2014-04-30 16:16:07 +09:00
2014-04-30 15:32:05 +09:00
2014-04-30 16:16:07 +09:00
2014-04-30 16:16:07 +09:00
2014-04-30 16:19:39 +09:00
2014-04-30 16:22:54 +09:00
2014-04-30 15:32:05 +09:00
2014-04-30 16:16:07 +09:00
2014-04-30 16:16:07 +09:00
2014-04-30 15:32:05 +09:00
2014-04-30 16:16:07 +09:00
2014-04-30 16:19:39 +09:00
2014-04-30 16:16:07 +09:00
2014-04-30 15:32:05 +09:00
2014-04-30 17:15:28 +09:00
2014-04-22 17:38:47 +09:00
2014-04-22 12:31:36 +09:00
2014-04-30 16:16:07 +09:00
2014-04-22 21:39:18 +09:00
2014-04-30 15:32:05 +09:00
2014-04-30 15:32:05 +09:00
2014-04-30 16:16:07 +09:00
2014-04-30 16:19:39 +09:00
2014-04-30 16:16:07 +09:00
2014-04-30 16:22:54 +09:00
2014-04-30 16:16:07 +09:00
2014-04-30 16:16:07 +09:00
2014-04-30 16:40:54 +09:00
2014-04-30 16:16:07 +09:00
2014-04-30 23:17:33 +09:00

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

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

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
- Windows/amd64

(I do not have a darwin machine)


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


Usage
---------

::

   import (
   	"encoding/json"
   	"fmt"

   	"github.com/shirou/gopsutil"
   )

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

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

   	// convert to JSON
   	d, _ := json.Marshal(v)
   	fmt.Printf("%s\n", d)
   }

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


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

- done

  - cpu_times (linux, freebsd)
  - cpu_count (linux, freebsd, windows)
  - virtual_memory (linux, windows)
  - swap_memory (linux)
  - disk_partitions (linux, freebsd, windows)
  - disk_io_counters (linux)
  - disk_usage (linux, freebsd, windows)
  - net_io_counters (linux)
  - 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, windows)
    - name (linux)
    - cmdline (linux)
    - create_time (linux)
    - status (linux)
    - nwd (linux)
    - exe (linux, freebsd, windows)
    - uids (linux)
    - gids (linux)
    - terminal (linux)
    - nice (linux)
    - num_fds (linux)
    - num_threads (linux, windows)
    - cpu_times (linux)
    - memory_info (linux)
    - 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
    - io_counters
    - num_ctx_switches
    - 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

I have referenced 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.
Description
No description provided
Readme BSD-3-Clause 5 MiB
Languages
Go 99.2%
Makefile 0.4%
C 0.3%