2014-05-01 01:43:01 +00:00
---
2016-01-19 18:08:53 +00:00
layout: "docs"
2014-05-01 01:43:01 +00:00
page_title: "Basic Usage - Docker Provider"
2016-01-19 18:08:53 +00:00
sidebar_current: "providers-docker-basics"
description: |-
The Docker provider in Vagrant behaves just like any other provider.
If you are familiar with Vagrant already, then using the Docker provider
should be intuitive and simple.
2014-05-01 01:43:01 +00:00
---
# Docker Basic Usage
2014-05-04 21:14:26 +00:00
The Docker provider in Vagrant behaves just like any other provider.
2016-01-19 18:08:53 +00:00
If you are familiar with Vagrant already, then using the Docker provider
2014-05-01 01:43:01 +00:00
should be intuitive and simple.
The Docker provider _does not_ require a `config.vm.box` setting. Since
the "base image" for a Docker container is pulled from the
2014-08-09 00:32:42 +00:00
Docker Index or
2016-01-19 18:08:53 +00:00
built from a Dockerfile, the box does not
2014-05-01 01:43:01 +00:00
add much value, and is optional for this provider.
## Docker Images
The first method that Vagrant can use to source a Docker container
is via an image. This image can be from any Docker registry. An
example is shown below:
2016-01-19 18:08:53 +00:00
```ruby
2014-05-01 01:43:01 +00:00
Vagrant.configure("2") do |config|
config.vm.provider "docker" do |d|
d.image = "foo/bar"
end
end
2016-01-19 18:08:53 +00:00
```
2014-05-01 01:43:01 +00:00
When `vagrant up --provider=docker` is run, this will bring up the
image `foo/bar` .
This is useful for extra components of your application that it might
depend on: databases, queues, etc. Typically, the primary application
2016-01-19 18:08:53 +00:00
you are working on is built with a Dockerfile, or via a container with
2014-05-01 01:43:01 +00:00
SSH.
## Dockerfiles
Vagrant can also automatically build and run images based on a local
Dockerfile. This is useful for iterating on an application locally
that is built into an image later. An example is shown below:
2016-01-19 18:08:53 +00:00
```ruby
2014-05-01 01:43:01 +00:00
Vagrant.configure("2") do |config|
config.vm.provider "docker" do |d|
d.build_dir = "."
end
end
2016-01-19 18:08:53 +00:00
```
2014-05-01 01:43:01 +00:00
The above configuration will look for a `Dockerfile` in the same
2014-07-24 16:02:46 +00:00
directory as the Vagrantfile. When `vagrant up --provider=docker` is run, Vagrant
2014-05-01 01:43:01 +00:00
automatically builds that Dockerfile and starts a container
based on that Dockerfile.
The Dockerfile is rebuilt when `vagrant reload` is called.
2014-08-06 22:58:26 +00:00
## Synced Folders and Networking
When using Docker, Vagrant automatically converts synced folders
and networking options into Docker volumes and forwarded ports.
2016-01-19 18:08:53 +00:00
You do not have to use the Docker-specific configurations to do this.
2014-08-06 22:58:26 +00:00
This helps keep your Vagrantfile similar to how it has always looked.
2015-11-24 01:40:28 +00:00
The Docker provider does not support specifying options for `owner` or `group`
on folders synced with a docker container.
2018-05-09 04:10:54 +00:00
### Volume Consistency
2018-07-27 22:11:45 +00:00
Docker's [volume consistency ](https://docs.docker.com/v17.09/engine/admin/volumes/bind-mounts/ ) setting can be specified using the `docker_consistency` option when defining a synced folder. This can
2018-05-09 04:10:54 +00:00
[greatly improve performance on macOS ](https://docs.docker.com/docker-for-mac/osxfs-caching ). An example is shown using the `cached` and `delegated` settings:
2018-07-27 22:11:45 +00:00
```ruby
2018-05-09 04:10:54 +00:00
config.vm.synced_folder "/host/dir1", "/guest/dir1", docker_consistency: "cached"
config.vm.synced_folder "/host/dir2", "/guest/dir2", docker_consistency: "delegated"
```
2014-05-01 01:43:01 +00:00
## Host VM
2017-11-30 00:15:37 +00:00
If the system cannot run Linux containers natively, Vagrant automatically spins
up a "host VM" to run Docker. This allows your Docker-based Vagrant environments
to remain portable, without inconsistencies depending on the platform they are
running on.
2014-05-01 01:43:01 +00:00
Vagrant will spin up a single instance of a host VM and run multiple
containers on this one VM. This means that with the Docker provider,
you only have the overhead of one virtual machine, and only if it is
absolutely necessary.
By default, the host VM Vagrant spins up is
2018-03-07 22:10:30 +00:00
[backed by boot2docker ](https://github.com/hashicorp/vagrant/blob/master/plugins/providers/docker/hostmachine/Vagrantfile ),
2014-05-01 01:43:01 +00:00
because it launches quickly and uses little resources. But the host VM
can be customized to point to _any_ Vagrantfile. This allows the host VM
to more closely match production by running a VM running Ubuntu, RHEL,
etc. It can run any operating system supported by Vagrant.
2014-05-22 17:26:12 +00:00
< div class = "alert alert-info" >
2016-01-19 19:54:13 +00:00
< strong > Synced folder note:< / strong > Vagrant will attempt to use the
"best" synced folder implementation it can. For boot2docker, this is
often rsync. In this case, make sure you have rsync installed on your
host machine. Vagrant will give you a human-friendly error message if
it is not.
2014-05-22 17:26:12 +00:00
< / div >
2014-05-01 01:43:01 +00:00
An example of changing the host VM is shown below. Remember that this
2016-01-19 18:08:53 +00:00
is optional, and Vagrant will spin up a default host VM if it is not
2014-05-01 01:43:01 +00:00
specified:
2016-01-19 18:08:53 +00:00
```ruby
2014-05-01 01:43:01 +00:00
Vagrant.configure("2") do |config|
config.vm.provider "docker" do |d|
d.vagrant_vagrantfile = "../path/to/Vagrantfile"
end
end
2016-01-19 18:08:53 +00:00
```
2014-05-01 01:43:01 +00:00
The host VM will be spun up at the first `vagrant up` where the provider
is Docker. To control this host VM, use the
2016-01-19 18:08:53 +00:00
[global-status command ](/docs/cli/global-status.html )
2014-05-01 01:43:01 +00:00
along with global control.