2016-02-12 18:02:16 +00:00
|
|
|
# go-dockerclient
|
|
|
|
|
2020-03-23 14:48:47 +00:00
|
|
|
[![Travis Build Status](https://travis-ci.org/fsouza/go-dockerclient.svg?branch=master)](https://travis-ci.org/fsouza/go-dockerclient)
|
|
|
|
[![AppVeyor Build Status](https://ci.appveyor.com/api/projects/status/4m374pti06ubg2l7?svg=true)](https://ci.appveyor.com/project/fsouza/go-dockerclient)
|
|
|
|
[![GoDoc](https://img.shields.io/badge/api-Godoc-blue.svg?style=flat-square)](https://godoc.org/github.com/fsouza/go-dockerclient)
|
2016-02-12 18:02:16 +00:00
|
|
|
|
|
|
|
This package presents a client for the Docker remote API. It also provides
|
2016-03-25 00:42:00 +00:00
|
|
|
support for the extensions in the [Swarm API](https://docs.docker.com/swarm/swarm-api/).
|
2016-02-12 18:02:16 +00:00
|
|
|
|
|
|
|
This package also provides support for docker's network API, which is a simple
|
2020-03-23 14:48:47 +00:00
|
|
|
passthrough to the libnetwork remote API. Note that docker's network API is
|
|
|
|
only available in docker 1.8 and above, and only enabled in docker if
|
|
|
|
DOCKER_EXPERIMENTAL is defined during the docker build process.
|
2016-02-12 18:02:16 +00:00
|
|
|
|
2017-02-15 01:34:05 +00:00
|
|
|
For more details, check the [remote API
|
2020-03-23 14:48:47 +00:00
|
|
|
documentation](http://docs.docker.com/engine/reference/api/docker_remote_api/).
|
2016-02-12 18:02:16 +00:00
|
|
|
|
|
|
|
## Example
|
|
|
|
|
|
|
|
```go
|
|
|
|
package main
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
|
|
|
|
2020-03-23 14:48:47 +00:00
|
|
|
"github.com/fsouza/go-dockerclient"
|
2016-02-12 18:02:16 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
func main() {
|
2020-03-23 14:48:47 +00:00
|
|
|
endpoint := "unix:///var/run/docker.sock"
|
|
|
|
client, err := docker.NewClient(endpoint)
|
2017-02-15 01:34:05 +00:00
|
|
|
if err != nil {
|
|
|
|
panic(err)
|
|
|
|
}
|
|
|
|
imgs, err := client.ListImages(docker.ListImagesOptions{All: false})
|
|
|
|
if err != nil {
|
|
|
|
panic(err)
|
|
|
|
}
|
2016-02-12 18:02:16 +00:00
|
|
|
for _, img := range imgs {
|
|
|
|
fmt.Println("ID: ", img.ID)
|
|
|
|
fmt.Println("RepoTags: ", img.RepoTags)
|
|
|
|
fmt.Println("Created: ", img.Created)
|
|
|
|
fmt.Println("Size: ", img.Size)
|
|
|
|
fmt.Println("VirtualSize: ", img.VirtualSize)
|
|
|
|
fmt.Println("ParentId: ", img.ParentID)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
```
|
|
|
|
|
|
|
|
## Using with TLS
|
|
|
|
|
2017-02-15 01:34:05 +00:00
|
|
|
In order to instantiate the client for a TLS-enabled daemon, you should use
|
|
|
|
NewTLSClient, passing the endpoint and path for key and certificates as
|
|
|
|
parameters.
|
2016-02-12 18:02:16 +00:00
|
|
|
|
|
|
|
```go
|
|
|
|
package main
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
|
|
|
|
2020-03-23 14:48:47 +00:00
|
|
|
"github.com/fsouza/go-dockerclient"
|
2016-02-12 18:02:16 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
func main() {
|
2020-03-23 14:48:47 +00:00
|
|
|
endpoint := "tcp://[ip]:[port]"
|
2016-02-12 18:02:16 +00:00
|
|
|
path := os.Getenv("DOCKER_CERT_PATH")
|
|
|
|
ca := fmt.Sprintf("%s/ca.pem", path)
|
|
|
|
cert := fmt.Sprintf("%s/cert.pem", path)
|
|
|
|
key := fmt.Sprintf("%s/key.pem", path)
|
|
|
|
client, _ := docker.NewTLSClient(endpoint, cert, key, ca)
|
|
|
|
// use client
|
|
|
|
}
|
|
|
|
```
|
|
|
|
|
2017-02-15 01:34:05 +00:00
|
|
|
If using [docker-machine](https://docs.docker.com/machine/), or another
|
|
|
|
application that exports environment variables `DOCKER_HOST`,
|
2020-03-23 14:48:47 +00:00
|
|
|
`DOCKER_TLS_VERIFY`, `DOCKER_CERT_PATH`, you can use NewClientFromEnv.
|
2016-02-12 18:02:16 +00:00
|
|
|
|
|
|
|
|
|
|
|
```go
|
|
|
|
package main
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
|
|
|
|
2020-03-23 14:48:47 +00:00
|
|
|
"github.com/fsouza/go-dockerclient"
|
2016-02-12 18:02:16 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
func main() {
|
2020-03-23 14:48:47 +00:00
|
|
|
client, _ := docker.NewClientFromEnv()
|
2016-02-12 18:02:16 +00:00
|
|
|
// use client
|
|
|
|
}
|
|
|
|
```
|
|
|
|
|
|
|
|
See the documentation for more details.
|
|
|
|
|
|
|
|
## Developing
|
|
|
|
|
|
|
|
All development commands can be seen in the [Makefile](Makefile).
|
|
|
|
|
|
|
|
Commited code must pass:
|
|
|
|
|
2020-03-23 14:48:47 +00:00
|
|
|
* [golint](https://github.com/golang/lint) (with some exceptions, see the Makefile).
|
|
|
|
* [go vet](https://golang.org/cmd/vet/)
|
|
|
|
* [gofmt](https://golang.org/cmd/gofmt)
|
2016-02-12 18:02:16 +00:00
|
|
|
* [go test](https://golang.org/cmd/go/#hdr-Test_packages)
|
|
|
|
|
2020-03-23 14:48:47 +00:00
|
|
|
Running `make test` will check all of these. If your editor does not
|
|
|
|
automatically call ``gofmt -s``, `make fmt` will format all go files in this
|
|
|
|
repository.
|
2017-08-10 16:19:19 +00:00
|
|
|
|
2020-03-23 14:48:47 +00:00
|
|
|
## Vendoring
|
2017-11-14 23:27:57 +00:00
|
|
|
|
2020-03-23 14:48:47 +00:00
|
|
|
go-dockerclient uses [dep](https://github.com/golang/dep/) for vendoring. If
|
|
|
|
you're using dep, you should be able to pick go-dockerclient releases and get
|
|
|
|
the proper dependencies.
|
2017-11-14 23:27:57 +00:00
|
|
|
|
2020-03-23 14:48:47 +00:00
|
|
|
With other vendoring tools, users might need to specify go-dockerclient's
|
2017-11-14 23:27:57 +00:00
|
|
|
dependencies manually.
|
|
|
|
|
2017-08-10 16:19:19 +00:00
|
|
|
## Using with Docker 1.9 and Go 1.4
|
|
|
|
|
|
|
|
There's a tag for using go-dockerclient with Docker 1.9 (which requires
|
|
|
|
compiling go-dockerclient with Go 1.4), the tag name is ``docker-1.9/go-1.4``.
|
|
|
|
|
|
|
|
The instructions below can be used to get a version of go-dockerclient that compiles with Go 1.4:
|
|
|
|
|
|
|
|
```
|
|
|
|
% git clone -b docker-1.9/go-1.4 https://github.com/fsouza/go-dockerclient.git $GOPATH/src/github.com/fsouza/go-dockerclient
|
|
|
|
% git clone -b v1.9.1 https://github.com/docker/docker.git $GOPATH/src/github.com/docker/docker
|
|
|
|
% go get github.com/fsouza/go-dockerclient
|
|
|
|
```
|