Terraform Provider - Docker
Find a file
Manuel Vogel 33b29dcc43
docs: update readme with logos and subsections (#235)
* docs(readme): add tf, xw and docker logo
* docs: new logo alignment
2021-06-23 17:33:00 +02:00
.github fix(deps): update module github.com/docker/docker to v20.10.7 (#218) 2021-06-21 09:55:55 +02:00
assets docs: update readme with logos and subsections (#235) 2021-06-23 17:33:00 +02:00
docs chore: prepare release v2.13.0 2021-06-22 17:32:10 +02:00
examples chore: prepare release v2.13.0 2021-06-22 17:32:10 +02:00
internal/provider fix/service delete deadline (#227) 2021-06-22 22:11:32 +09:00
scripts fix(deps): update module github.com/docker/docker to v20.10.7 (#218) 2021-06-21 09:55:55 +02:00
templates fix/service image name (#212) 2021-06-21 09:24:02 +02:00
testdata chore(deps): update nginx:1.21.0 docker digest to d1b8ff2 (#232) 2021-06-23 08:54:06 +02:00
tools fix(deps): update module github.com/golangci/golangci-lint to v1.41.1 (#226) 2021-06-21 09:28:25 +02:00
.gitignore chore/refactor tests (#201) 2021-05-31 16:11:49 +09:00
.go-version feat: support darwin arm builds and golang 1.16 (#140) 2021-03-18 23:21:49 +09:00
.golangci.yml feat: migrate to terraform-sdk v2 (#102) 2021-03-18 08:30:54 +01:00
.goreleaser.yml fix(deps): update module github.com/golangci/golangci-lint to v1.39.0 (#166) 2021-04-09 11:56:56 +02:00
.markdownlinkcheck.json feat/doc generation (#193) 2021-05-21 21:30:56 +09:00
.markdownlint.yml feat/doc generation (#193) 2021-05-21 21:30:56 +09:00
CHANGELOG.md chore: prepare release v2.13.0 2021-06-22 17:32:10 +02:00
CODE_OF_CONDUCT.md docs: adds coc and contributing 2020-12-24 16:27:35 +01:00
CONTRIBUTING.md docs: update readme with logos and subsections (#235) 2021-06-23 17:33:00 +02:00
GNUmakefile fix/service image name (#212) 2021-06-21 09:24:02 +02:00
go.mod fix/service delete deadline (#227) 2021-06-22 22:11:32 +09:00
go.sum fix/service delete deadline (#227) 2021-06-22 22:11:32 +09:00
LICENSE initial commit 2017-06-05 20:59:08 +00:00
main.go feat/doc generation (#193) 2021-05-21 21:30:56 +09:00
README.md docs: update readme with logos and subsections (#235) 2021-06-23 17:33:00 +02:00
renovate.json5 chore(renovate): configure Renovate (#162) 2021-04-07 10:53:58 +02:00

Docker logo Terraform logo Kreuzwerker logo

Terraform Provider for Docker

Requirements

  • Terraform >=0.12.x
  • Go 1.16.x (to build the provider plugin)

Building The Provider

$ git clone git@github.com:kreuzwerker/terraform-provider-docker
$ make build

Example usage

Take a look at the examples in the documentation of the registry or use the following example:

# Set the required provider and versions
terraform {
  required_providers {
    # We recommend pinning to the specific version of the Docker Provider you're using
    # since new versions are released frequently
    docker = {
      source  = "kreuzwerker/docker"
      version = "2.13.0"
    }
  }
}

# Configure the docker provider
provider "docker" {
}

# Create a docker image resource
# -> docker pull nginx:latest
resource "docker_image" "nginx" {
  name         = "nginx:latest"
  keep_locally = true
}

# Create a docker container resource
# -> same as 'docker run --name nginx -p8080:80 -d nginx:latest'
resource "docker_container" "nginx" {
  name    = "nginx"
  image   = docker_image.nginx.latest

  ports {
    external = 8080
    internal = 80
  }
}

# Or create a service resource
# -> same as 'docker service create -d -p 8081:80 --name nginx-service --replicas 2 nginx:latest'
resource "docker_service" "nginx_service" {
  name = "nginx-service"
  task_spec {
    container_spec {
      image = docker_image.nginx.repo_digest
    }
  }

  mode {
    replicated {
      replicas = 2
    }
  }

  endpoint_spec {
    ports {
      published_port = 8081
      target_port    = 80
    }
  }
}

Contributing

The Terraform Docker Provider is the work of many of contributors. We appreciate your help!

To contribute, please read the contribution guidelines: Contributing to Terraform - Docker Provider

License

The Terraform Provider Docker is available to everyone under the terms of the Mozilla Public License Version 2.0. Take a look the LICENSE file.