summaryrefslogtreecommitdiff
path: root/docs/sources/installation/windows.md
blob: b5a148417af586b030e709ce91118d1634332090 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
page_title: Installation on Windows
page_description: Docker installation on Microsoft Windows
page_keywords: Docker, Docker documentation, Windows, requirements, virtualbox, boot2docker

# Windows
> **Note:**
> Docker has been tested on Windows 7.1 and 8; it may also run on older versions.
> Your processor needs to support hardware virtualization.

The Docker Engine uses Linux-specific kernel features, so to run it on Windows
we need to use a lightweight virtual machine (VM).  You use the **Windows Docker
Client** to control the virtualized Docker Engine to build, run, and manage
Docker containers.

To make this process easier, we've designed a helper application called
[Boot2Docker](https://github.com/boot2docker/boot2docker) creates a Linux virtual
machine on Windows to run Docker on a Linux operating system.

Although you will be using Windows Docker client, the docker engine hosting the
containers will still be running on Linux. Until the Docker engine for Windows
is developed, you can launch only Linux containers from your Windows machine.

![Windows Architecture Diagram](/installation/images/win_docker_host.svg)

## Demonstration

<iframe width="640" height="480" src="//www.youtube.com/embed/TjMU3bDX4vo?rel=0" frameborder="0" allowfullscreen></iframe>

## Installation

1. Download the latest release of the
   [Docker for Windows Installer](https://github.com/boot2docker/windows-installer/releases/latest).
2. Run the installer, which will install Docker Client for Windows, VirtualBox,
   Git for Windows (MSYS-git), the boot2docker Linux ISO, and the Boot2Docker
   management tool.
   ![](/installation/images/windows-installer.png)
3. Run the **Boot2Docker Start** shortcut from your Desktop or “Program Files →
   Boot2Docker for Windows”.
   The Start script will ask you to enter an ssh key passphrase - the simplest
   (but least secure) is to just hit [Enter].

4. The **Boot2Docker Start** will start a unix shell already configured to manage
   Docker running inside the virtual machine. Run `docker version` to see
   if it is working correctly:

![](/installation/images/windows-boot2docker-start.png)

## Running Docker

{{ include "no-remote-sudo.md" }}

**Boot2Docker Start** will automatically start a shell with environment variables
correctly set so you can start using Docker right away:

Let's try the `hello-world` example image. Run

    $ docker run hello-world

This should download the very small `hello-world` image and print a
`Hello from Docker.` message.

## Using Docker from Windows Command Line Prompt (cmd.exe)

Launch a Windows Command Line Prompt (cmd.exe).

Boot2Docker command requires `ssh.exe` to be in the PATH, therefore we need to
include `bin` folder of the Git installation (which has ssh.exe) to the `%PATH%`
environment variable by running:

    set PATH=%PATH%;"c:\Program Files (x86)\Git\bin"

and then we can run the `boot2docker start` command to start the Boot2Docker VM.
(Run `boot2docker init` command if you get an error saying machine does not
exist.) Then copy the instructions for cmd.exe to set the environment variables
to your console window and you are ready to run docker commands such as
`docker ps`:

![](/installation/images/windows-boot2docker-cmd.png)

## Using Docker from PowerShell

Launch a PowerShell window, then you need to add `ssh.exe` to your PATH:

    $Env:Path = "${Env:Path};c:\Program Files (x86)\Git\bin"

and after running `boot2docker start` command it will print PowerShell commands
to set the environment variables to connect Docker running inside VM. Run these
commands and you are ready to run docker commands such as `docker ps`:

![](/installation/images/windows-boot2docker-powershell.png)

> NOTE: You can alternatively run `boot2docker shellinit | Invoke-Expression`
> command to set the environment variables instead of copying and pasting on
> PowerShell.

# Further Details

The Boot2Docker management tool provides several commands:

    $ boot2docker
    Usage: boot2docker.exe [<options>] {help|init|up|ssh|save|down|poweroff|reset|restart|config|status|info|ip|shellinit|delete|download|upgrade|version} [<args>]

## Upgrading

1. Download the latest release of the [Docker for Windows Installer](
   https://github.com/boot2docker/windows-installer/releases/latest)

2. Run the installer, which will update the Boot2Docker management tool.

3. To upgrade your existing virtual machine, open a terminal and run:

        boot2docker stop
        boot2docker download
        boot2docker start

## Container port redirection

If you are curious, the username for the boot2docker default user is `docker`
and the password is `tcuser`.

The latest version of `boot2docker` sets up a host only network adaptor which
provides access to the container's ports.

If you run a container with an exposed port:

    docker run --rm -i -t -p 80:80 nginx

Then you should be able to access that nginx server using the IP address reported
to you using:

    boot2docker ip

Typically, it is 192.168.59.103, but it could get changed by Virtualbox's DHCP
implementation.

For further information or to report issues, please see the [Boot2Docker site](http://boot2docker.io)

## Login with PUTTY instead of using the CMD

Boot2Docker generates and uses the public/private key pair in your `%USERPROFILE%\.ssh`
directory so to log in you need to use the private key from this same directory.

The private key needs to be converted into the format PuTTY uses.

You can do this with
[puttygen](http://www.chiark.greenend.org.uk/~sgtatham/putty/download.html):

- Open `puttygen.exe` and load ("File"->"Load" menu) the private key from
  `%USERPROFILE%\.ssh\id_boot2docker`
- then click: "Save Private Key".
- Then use the saved file to login with PuTTY using `docker@127.0.0.1:2022`.

## Uninstallation

You can uninstall Boot2Docker using Window's standard process for removing programs.
This process does not remove the `docker-install.exe` file. You must delete that file
yourself.

## References

If you have Docker hosts running and if you don't wish to do a 
Boot2Docker installation, you can install the docker.exe using
unofficial Windows package manager Chocolately. For information
on how to do this, see [Docker package on Chocolatey](http://chocolatey.org/packages/docker).