111 lines
3.7 KiB
Markdown
111 lines
3.7 KiB
Markdown
[![Build Status](https://travis-ci.org/vmware/govmomi.png?branch=master)](https://travis-ci.org/vmware/govmomi)
|
|
[![Go Report Card](https://goreportcard.com/badge/github.com/vmware/govmomi)](https://goreportcard.com/report/github.com/vmware/govmomi)
|
|
|
|
# govmomi
|
|
|
|
A Go library for interacting with VMware vSphere APIs (ESXi and/or vCenter).
|
|
|
|
In addition to the vSphere API client, this repository includes:
|
|
|
|
* [govc](./govc) - vSphere CLI
|
|
|
|
* [vcsim](./vcsim) - vSphere API mock framework
|
|
|
|
* [toolbox](./toolbox) - VM guest tools framework
|
|
|
|
## Compatibility
|
|
|
|
This library is built for and tested against ESXi and vCenter 6.5, 6.7 and 7.0.
|
|
|
|
It may work with versions 5.1, 5.5 and 6.0, but neither are officially supported.
|
|
|
|
## Documentation
|
|
|
|
The APIs exposed by this library very closely follow the API described in the [VMware vSphere API Reference Documentation][apiref].
|
|
Refer to this document to become familiar with the upstream API.
|
|
|
|
The code in the `govmomi` package is a wrapper for the code that is generated from the vSphere API description.
|
|
It primarily provides convenience functions for working with the vSphere API.
|
|
See [godoc.org][godoc] for documentation.
|
|
|
|
[apiref]:https://code.vmware.com/apis/968/vsphere
|
|
[godoc]:http://godoc.org/github.com/vmware/govmomi
|
|
|
|
## Installation
|
|
|
|
```sh
|
|
go get -u github.com/vmware/govmomi
|
|
```
|
|
|
|
## Discussion
|
|
|
|
Contributors and users are encouraged to collaborate using GitHub issues and/or
|
|
[Slack](https://vmwarecode.slack.com/messages/govmomi).
|
|
Access to Slack requires a [VMware {code} membership](https://code.vmware.com/join/).
|
|
|
|
## Status
|
|
|
|
Changes to the API are subject to [semantic versioning](http://semver.org).
|
|
|
|
Refer to the [CHANGELOG](CHANGELOG.md) for version to version changes.
|
|
|
|
## Projects using govmomi
|
|
|
|
* [Docker Machine](https://github.com/docker/machine/tree/master/drivers/vmwarevsphere)
|
|
|
|
* [Docker InfraKit](https://github.com/docker/infrakit/tree/master/pkg/provider/vsphere)
|
|
|
|
* [Docker LinuxKit](https://github.com/linuxkit/linuxkit/tree/master/src/cmd/linuxkit)
|
|
|
|
* [Kubernetes](https://github.com/kubernetes/kubernetes/tree/master/pkg/cloudprovider/providers/vsphere)
|
|
|
|
* [Kubernetes Cloud Provider](https://github.com/kubernetes/cloud-provider-vsphere)
|
|
|
|
* [Kubernetes Cluster API](https://github.com/kubernetes-sigs/cluster-api-provider-vsphere)
|
|
|
|
* [Kubernetes kops](https://github.com/kubernetes/kops/tree/master/upup/pkg/fi/cloudup/vsphere)
|
|
|
|
* [Terraform](https://github.com/terraform-providers/terraform-provider-vsphere)
|
|
|
|
* [Packer](https://github.com/jetbrains-infra/packer-builder-vsphere)
|
|
|
|
* [VMware VIC Engine](https://github.com/vmware/vic)
|
|
|
|
* [Travis CI](https://github.com/travis-ci/jupiter-brain)
|
|
|
|
* [collectd-vsphere](https://github.com/travis-ci/collectd-vsphere)
|
|
|
|
* [Gru](https://github.com/dnaeon/gru)
|
|
|
|
* [Libretto](https://github.com/apcera/libretto/tree/master/virtualmachine/vsphere)
|
|
|
|
* [Telegraf](https://github.com/influxdata/telegraf/tree/master/plugins/inputs/vsphere)
|
|
|
|
* [Open Storage](https://github.com/libopenstorage/openstorage/tree/master/pkg/storageops/vsphere)
|
|
|
|
* [Juju](https://github.com/juju/juju)
|
|
|
|
* [vSphere 7.0](https://docs.vmware.com/en/VMware-vSphere/7.0/rn/vsphere-esxi-vcenter-server-7-vsphere-with-kubernetes-release-notes.html)
|
|
|
|
* [OPS](https://github.com/nanovms/ops)
|
|
|
|
* [VMware Event Broker Appliance](https://github.com/vmware-samples/vcenter-event-broker-appliance/tree/development/vmware-event-router)
|
|
|
|
## Related projects
|
|
|
|
* [rbvmomi](https://github.com/vmware/rbvmomi)
|
|
|
|
* [pyvmomi](https://github.com/vmware/pyvmomi)
|
|
|
|
* [go-vmware-nsxt](https://github.com/vmware/go-vmware-nsxt)
|
|
|
|
## License
|
|
|
|
govmomi is available under the [Apache 2 license](LICENSE.txt).
|
|
|
|
## Name
|
|
|
|
Pronounced "go-v-mom-ie"
|
|
|
|
Follows pyvmomi and rbvmomi: language prefix + the vSphere acronym "VM Object Management Infrastructure".
|