35 lines
		
	
	
		
			1.1 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
			
		
		
	
	
			35 lines
		
	
	
		
			1.1 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
| # Process List Library for Go [](https://godoc.org/github.com/mitchellh/go-ps)
 | |
| 
 | |
| go-ps is a library for Go that implements OS-specific APIs to list and
 | |
| manipulate processes in a platform-safe way. The library can find and
 | |
| list processes on Linux, Mac OS X, Solaris, and Windows.
 | |
| 
 | |
| If you're new to Go, this library has a good amount of advanced Go educational
 | |
| value as well. It uses some advanced features of Go: build tags, accessing
 | |
| DLL methods for Windows, cgo for Darwin, etc.
 | |
| 
 | |
| How it works:
 | |
| 
 | |
|   * **Darwin** uses the `sysctl` syscall to retrieve the process table.
 | |
|   * **Unix** uses the procfs at `/proc` to inspect the process tree.
 | |
|   * **Windows** uses the Windows API, and methods such as
 | |
|     `CreateToolhelp32Snapshot` to get a point-in-time snapshot of
 | |
|     the process table.
 | |
| 
 | |
| ## Installation
 | |
| 
 | |
| Install using standard `go get`:
 | |
| 
 | |
| ```
 | |
| $ go get github.com/mitchellh/go-ps
 | |
| ...
 | |
| ```
 | |
| 
 | |
| ## TODO
 | |
| 
 | |
| Want to contribute? Here is a short TODO list of things that aren't
 | |
| implemented for this library that would be nice:
 | |
| 
 | |
|   * FreeBSD support
 | |
|   * Plan9 support
 | 
