vagrant/website/source/docs/docker/configuration.html.md

124 lines
5.1 KiB
Markdown

---
layout: "docs"
page_title: "Configuration- Docker Provider"
sidebar_current: "providers-docker-configuration"
description: |-
The Docker provider has some provider-specific configuration options
you may set. A complete reference is shown on this page.
---
# Docker Configuration
The Docker provider has some provider-specific configuration options
you may set. A complete reference is shown below.
### Required
One of the following settings is required when using the Docker provider:
* `build_dir` (string) - The path to a directory containing a Dockerfile.
* `image` (string) - The image to launch, specified by the image ID or a name
such as `ubuntu:12.04`.
* `git_repo` (string) - The URL of a git repository to build the image from.
Supports pulling specific tags, branches and revision, consult the
[docker documentation](https://docs.docker.com/engine/reference/commandline/build/#/git-repositories)
for more information.
### Optional
General settings:
* `build_args` (array of strings) - Extra arguments to pass to
`docker build` when `build_dir` is in use.
* `cmd` (array of strings) - Custom command to run on the container.
Example: `["ls", "/app"]`.
* `compose` (boolean) - If true, Vagrant will use `docker-compose` to
manage the lifecycle and configuration of containers. This defaults
to false.
* `compose_configuration` (Hash) - Configuration values used for populating
the `docker-compose.yml` file. The value of this Hash is directly merged
and written to the `docker-compose.yml` file allowing customization of
non-services items like networks and volumes.
* `create_args` (array of strings) - Additional arguments to pass to
`docker run` when the container is started. This can be used to set
parameters that are not exposed via the Vagrantfile.
* `dockerfile` (string) - Name of the Dockerfile in the build directory.
This defaults to "Dockerfile"
* `env` (hash) - Environmental variables to expose into the container.
* `expose` (array of integers) - Ports to expose from the container
but not to the host machine. Useful for links.
* `link` (method, string argument) - Link this container to another
by name. The argument should be in the format of `(name:alias)`.
Example: `docker.link("db:db")`. Note, if you are linking to
another container in the same Vagrantfile, make sure you call
`vagrant up` with the `--no-parallel` flag.
* `force_host_vm` (boolean) - If true, then a host VM will be spun up
even if the computer running Vagrant supports Linux containers. This
is useful to enforce a consistent environment to run Docker. This value
defaults to "false" on Linux, Mac, and Windows hosts and defaults to "true"
on other hosts. Users on other hosts who choose to use a different Docker
provider or opt-in to the native Docker builds can explicitly set this
value to false to disable the behavior.
* `has_ssh` (boolean) - If true, then Vagrant will support SSH with
the container. This allows `vagrant ssh` to work, provisioners, etc.
This defaults to false.
* `host_vm_build_dir_options` (hash) - Synced folder options for the
`build_dir`, since the build directory is synced using a synced folder
if a host VM is in use.
* `name` (string) - Name of the container. Note that this has to be unique
across all containers on the host VM. By default Vagrant will generate
some random name.
* `pull` (bool) - If true, the image will be pulled on every `up` and
`reload`. Defaults to false.
* `ports` (array of strings) - Ports to expose from the container to the
host. These should be in the format of `host:container`.
* `remains_running` (boolean) - If true, Vagrant expects this container
to remain running and will make sure that it does for a certain amount
of time. If false, then Vagrant expects that this container will
automatically stop at some point, and will not error if it sees it do that.
* `stop_timeout` (integer) - The amount of time to wait when stopping
a container before sending a SIGTERM to the process.
* `vagrant_machine` (string) - The name of the Vagrant machine in the
`vagrant_vagrantfile` to use as the host machine. This defaults to
"default".
* `vagrant_vagrantfile` (string) - Path to a Vagrantfile that contains
the `vagrant_machine` to use as the host VM if needed.
* `volumes` (array of strings) - List of directories to mount as
volumes into the container. These directories must exist in the
host where Docker is running. If you want to sync folders from the
host Vagrant is running, just use synced folders.
Below, we have settings related to auth. If these are set, then Vagrant
will `docker login` prior to starting containers, allowing you to pull
images from private repositories.
* `email` (string) - Email address for logging in.
* `username` (string) - Username for logging in.
* `password` (string) - Password for logging in.
* `auth_server` (string) - The server to use for authentication. If not
set, the Docker Hub will be used.