- Подсистема Docker в Windows Docker Engine on Windows
- Установка Docker Install Docker
- Настройка Docker с помощью файла конфигурации Configure Docker with a configuration file
- Настройка Docker в службе Docker Configure Docker on the Docker service
- Распространенные конфигурации Common configuration
- Создание сети по умолчанию Default network creation
- Задание группы безопасности для Docker Set Docker security group
- Конфигурация прокси-сервера Proxy configuration
- Удаление Docker How to uninstall Docker
- Подготовка системы к удалению Docker Prepare your system for Docker’s removal
- Удаление Docker Uninstall Docker
- Очистка данных и системных компонентов Docker Clean up Docker data and system components
- Перезагрузка системы Reboot your system
- Dockerfile on Windows
- Basic Syntax
- Instructions
- Considerations for using RUN with Windows
- Examples of using RUN with Windows
- Considerations for using COPY with Windows
- Examples of using COPY with Windows
- Considerations for running ADD with Windows
- Examples of using ADD with Windows
- WORKDIR
- Considerations for using WORKDIR with Windows
- Considerations for using CMD with Windows
- Escape character
- PowerShell in Dockerfile
- PowerShell cmdlets
- REST calls
- PowerShell scripts
- Docker build
Подсистема Docker в Windows Docker Engine on Windows
Подсистема и клиент Docker не входят в состав Windows, потому их нужно устанавливать и настраивать отдельно. The Docker Engine and client aren’t included with Windows and need to be installed and configured individually. Кроме того, подсистема Docker может принимать множество пользовательских конфигураций. Furthermore, the Docker Engine can accept many custom configurations. Например, можно настроить то, как управляющая программа принимает входящие запросы, сетевые параметры по умолчанию и параметры ведения журнала и отладки. Some examples include configuring how the daemon accepts incoming requests, default networking options, and debug/log settings. В ОС Windows эти конфигурации можно указать в файле конфигурации или с помощью диспетчера служб Windows. On Windows, these configurations can be specified in a configuration file or by using Windows Service control manager. В этом документе объясняется установка и настройка подсистемы Docker; также представлены примеры некоторых часто используемых конфигураций. This document details how to install and configure the Docker Engine, and also provides some examples of commonly used configurations.
Установка Docker Install Docker
Для работы с контейнерами Windows требуется Docker. You need Docker in order to work with Windows Containers. Docker состоит из подсистемы Docker (dockerd.exe) и клиента Docker (docker.exe). Docker consists of the Docker Engine (dockerd.exe), and the Docker client (docker.exe). Самый простой способ установить все необходимые компоненты изложен в кратком руководстве, которое поможет настроить и запустить первый контейнер. The easiest way to get everything installed is in the quickstart guide, which will help you get everything set up and run your first container.
Сведения об установке с помощью сценария см. в разделе Использование сценария для установки Docker EE. For scripted installations, see Use a script to install Docker EE.
Прежде чем использовать Docker, необходимо установить образы контейнеров. Before you can use Docker, you’ll need to install the container images. Дополнительные сведения см. в документации по образам контейнеров. For more information, see docs for our container base images.
Настройка Docker с помощью файла конфигурации Configure Docker with a configuration file
Предпочтительным способом настройки подсистемы Docker в Windows является использование файла конфигурации. The preferred method for configuring the Docker Engine on Windows is using a configuration file. Путь к файлу конфигурации — C:\ProgramData\Docker\config\daemon.json. The configuration file can be found at ‘C:\ProgramData\Docker\config\daemon.json’. Если этот файл еще не существует, его можно создать. You can create this file if it doesn’t already exist.
Не все доступные параметры конфигурации Docker применяются к Docker в Windows. Not every available Docker configuration option applies to Docker on Windows. В примере ниже показаны параметры конфигурации, которые применяются. The following example shows the configuration options that do apply. Дополнительные сведения о конфигурации подсистемы Docker см. в статье Docker daemon configuration file (Файл конфигурации управляющей программы Docker). For more information about Docker Engine configuration, see Docker daemon configuration file.
Достаточно только внести необходимые изменения в файл конфигурации. You only need to add the desired configuration changes to the configuration file. Например, в этом случае подсистема Docker настраивается на прием входящих подключений через порт 2375. For example, the following sample configures the Docker Engine to accept incoming connections on port 2375. В других параметрах конфигурации будут использоваться значения по умолчанию. All other configuration options will use default values.
Аналогично в примере ниже настраивается хранение образов и контейнеров по альтернативному пути в управляющей программе Docker. Likewise, the following sample configures the Docker daemon to keep images and containers in an alternate path. Если оно не указано, по умолчанию используется значение c:\programdata\docker . If not specified, the default is c:\programdata\docker .
В примере ниже управляющая программа Docker настраивается на прием только защищенных подключений через порт 2376. The following sample configures the Docker daemon to only accept secured connections over port 2376.
Настройка Docker в службе Docker Configure Docker on the Docker service
Подсистему Docker можно также настроить, изменив службу Docker командой sc config . The Docker Engine can also be configured by modifying the Docker service with sc config . При использовании этого способа флаги подсистемы Docker задаются непосредственно в службе Docker. Using this method, Docker Engine flags are set directly on the Docker service. Выполните указанную ниже команду в командной строке (cmd.exe, не PowerShell). Run the following command in a command prompt (cmd.exe not PowerShell):
Не нужно выполнять эту команду в том случае, если файл daemon.json уже содержит запись «hosts»: [«tcp://0.0.0.0:2375»] . You don’t need to run this command if your daemon.json file already contains the «hosts»: [«tcp://0.0.0.0:2375»] entry.
Распространенные конфигурации Common configuration
В следующих примерах файла конфигурации представлены распространенные конфигурации Docker. The following configuration file examples show common Docker configurations. Их можно объединить в один файл конфигурации. These can be combined into a single configuration file.
Создание сети по умолчанию Default network creation
Чтобы настроить подсистему Docker таким образом, чтобы не была создана сеть NAT по умолчанию, используйте следующую конфигурацию. To configure the Docker Engine so that it doesn’t create a default NAT network, use the following configuration.
Дополнительные сведения см. в статье Управление сетями Docker. For more information, see Manage Docker Networks.
Задание группы безопасности для Docker Set Docker security group
После входа в систему на узле Docker и запуска команд Docker эти команды выполняются через именованный канал. When you’ve signed in to the Docker host and are locally running Docker commands, these commands are run through a named pipe. По умолчанию только члены группы «Администраторы» могут получить доступ к подсистеме Docker через именованный канал. By default, only members of the Administrators group can access the Docker Engine through the named pipe. Чтобы указать группу безопасности, имеющую такой доступ, используйте флаг group . To specify a security group that has this access, use the group flag.
Конфигурация прокси-сервера Proxy configuration
Чтобы задать данные о прокси-сервере для docker search и docker pull , создайте переменную среды Windows с именем HTTP_PROXY или HTTPS_PROXY и значением, содержащим данные о прокси-сервере. To set proxy information for docker search and docker pull , create a Windows environment variable with the name HTTP_PROXY or HTTPS_PROXY , and a value of the proxy information. Это можно сделать в PowerShell, используя команду следующего вида: This can be completed with PowerShell using a command similar to this:
После задания переменной перезапустите службу Docker. Once the variable has been set, restart the Docker service.
Дополнительные сведения см. в разделе Windows Configuration File (Файл конфигурации Windows) на сайте Docker.com. For more information, see Windows Configuration File on Docker.com.
Удаление Docker How to uninstall Docker
В этом разделе описывается, как удалить Docker и выполнить полную очистку компонентов системы Docker в Windows 10 или Windows Server 2016. This section will tell you how to uninstall Docker and perform a full cleanup of Docker system components from your Windows 10 or Windows Server 2016 system.
Все команды в этих инструкциях необходимо выполнять из сеанса PowerShell с повышенными привилегиями. You must run all commands in these instructions from an elevated PowerShell session.
Подготовка системы к удалению Docker Prepare your system for Docker’s removal
Перед удалением Docker убедитесь, что в системе не запущены контейнеры. Before you uninstall Docker, make sure no containers are running on your system.
Выполните следующие командлеты, чтобы найти работающие контейнеры: Run the following cmdlets to check for running containers:
Кроме того, перед удалением Docker рекомендуется удалить все контейнеры, образы контейнеров, сети и тома из системы. It’s also good practice to remove all containers, container images, networks, and volumes from your system before removing Docker. Это можно сделать, выполнив следующий командлет: You can do this by running the following cmdlet:
Удаление Docker Uninstall Docker
Затем необходимо начать собственно удаление Docker. Next, you’ll need to actually uninstall Docker.
Удаление Docker в Windows 10 To uninstall Docker on Windows 10
- На компьютере с Windows 10 перейдите в раздел Параметры >Приложения. Go to Settings >Apps on your Windows 10 machine
- В разделе Приложения и компоненты найдите пункт Docker для Windows Under Apps & Features, find Docker for Windows
- Последовательно выберите Docker для Windows >Удалить. Go to Docker for Windows >Uninstall
Удаление Docker в Windows Server 2016 To uninstall Docker on Windows Server 2016:
В сеансе PowerShell с повышенными привилегиями используйте командлеты Uninstall-Package и Uninstall-Module, чтобы удалить модуль Docker и соответствующий ему поставщик Управление пакетами из системы, как показано в следующем примере: From an elevated PowerShell session, use the Uninstall-Package and Uninstall-Module cmdlets to remove the Docker module and its corresponding Package Management Provider from your system, as shown in the following example:
Вы можете найти поставщик пакетов, который использовался для установки Docker с помощью команды PS C:\> Get-PackageProvider -Name *Docker* You can find the Package Provider that you used to install Docker with PS C:\> Get-PackageProvider -Name *Docker*
Очистка данных и системных компонентов Docker Clean up Docker data and system components
После удаления Docker необходимо удалить сети Docker по умолчанию, чтобы их конфигурация не оставалась в системе после того, как Docker будет удален. After you uninstall Docker, you’ll need to remove Docker’s default networks so their configuration won’t remain on your system after Docker is gone. Это можно сделать, выполнив следующий командлет: You can do this by running the following cmdlet:
Удалите сети по умолчанию Docker в Windows Server 2016. To remove Docker’s default networks on Windows Server 2016.
Выполните следующий командлет, чтобы удалить программные данные Docker из системы: Run the following cmdlet to remove Docker’s program data from your system:
Можно также удалить необязательные компоненты Windows, связанные с Docker и контейнерами в Windows. You may also want to remove the Windows optional features associated with Docker/containers on Windows.
К ним относится компонент «Контейнеры», который автоматически включается в любом экземпляре Windows 10 или Windows Server 2016 при установке Docker. This includes the «Containers» feature, which is automatically enabled on any Windows 10 or Windows Server 2016 when Docker is installed. Это также может быть компонент «Hyper-V», который автоматически включается в Windows 10 при установке Docker, однако в Windows Server 2016 он включается вручную. It may also include the «Hyper-V» feature, which is automatically enabled on Windows 10 when Docker is installed, but must be explicitly enabled on Windows Server 2016.
Компонент Hyper-V является общим компонентом виртуализации, который обеспечивает гораздо большую функциональность, чем при использовании одних только контейнеров. The Hyper-V feature is a general virtualization feature that enables much more than just containers. Прежде чем отключить Hyper-V, убедитесь, что в системе нет других виртуальных компонентов, которые зависят от Hyper-V. Before disabling the Hyper-V feature, make sure there are no other virtualized components on your system that require Hyper-V.
Удаление компонентов Windows 10 To remove Windows features on Windows 10:
- Выберите последовательно Панель управления >Программы >Программы и компоненты >Включение или отключение компонентов Windows. Go to Control Panel >Programs >Programs and Features >Turn Windows features on or off.
- Найдите имя компонента, который требуется отключить — в данном случае это Контейнеры и (необязательно) Hyper-V. Find the name of the feature or features you want to disable—in this case, Containers and (optionally) Hyper-V.
- Снимите флажок рядом с именем компонента, который нужно отключить. Uncheck the box next to the name of the feature you want to disable.
- Нажмите кнопку ОК. Select «OK»
Удаление компонентов Windows Server 2016 To remove Windows features on Windows Server 2016:
В сеансе PowerShell с повышенными привилегиями выполните следующие командлеты, чтобы отключить компоненты Контейнеры и (необязательно) Hyper-V. From an elevated PowerShell session, run the following cmdlets to disable the Containers and (optionally) Hyper-V features from your system:
Перезагрузка системы Reboot your system
Чтобы завершить удаление компонентов и очистить систему, выполните следующий командлет из сеанса PowerShell с повышенными привилегиями для перезагрузки системы: To finish uninstallation and cleanup, run the following cmdlet from an elevated PowerShell session to reboot your system:
Dockerfile on Windows
The Docker engine includes tools that automate container image creation. While you can create container images manually by running the docker commit command, adopting an automated image creation process has many benefits, including:
- Storing container images as code.
- Rapid and precise recreation of container images for maintenance and upgrade purposes.
- Continuous integration between container images and the development cycle.
The Docker components that drive this automation are the Dockerfile, and the docker build command.
The Dockerfile is a text file that contains the instructions needed to create a new container image. These instructions include identification of an existing image to be used as a base, commands to be run during the image creation process, and a command that will run when new instances of the container image are deployed.
Docker build is the Docker engine command that consumes a Dockerfile and triggers the image creation process.
This topic will show you how to use Dockerfiles with Windows containers, understand their basic syntax, and what the most common Dockerfile instructions are.
This document will discuss the concept of container images and container image layers. If you want to learn more about images and image layering, see container base images.
For a complete look at Dockerfiles, see the Dockerfile reference.
Basic Syntax
In its most basic form, a Dockerfile can be very simple. The following example creates a new image, which includes IIS, and a вЂhello world’ site. This example includes comments (indicated with a # ), that explain each step. Subsequent sections of this article will go into more detail on Dockerfile syntax rules, and Dockerfile instructions.
A Dockerfile must be created with no extension. To do this in Windows, create the file with your editor of choice, then save it with the notation «Dockerfile» (including the quotes).
For additional examples of Dockerfiles for Windows, see the Dockerfile for Windows repository.
Instructions
Dockerfile instructions provide the Docker Engine the instructions it needs to create a container image. These instructions are performed one-by-one and in order. The following examples are the most commonly used instructions in Dockerfiles. For a complete list of Dockerfile instructions, see the Dockerfile reference.
The FROM instruction sets the container image that will be used during the new image creation process. For instance, when using the instruction FROM mcr.microsoft.com/windows/servercore , the resulting image is derived from, and has a dependency on, the Windows Server Core base OS image. If the specified image is not present on the system where the Docker build process is being run, the Docker engine will attempt to download the image from a public or private image registry.
The FROM instruction’s format goes like this:
Here’s an example of the FROM command:
To download the ltsc2019 version windows server core from the Microsoft Container Registry (MCR):
For more detailed information, see the FROM reference.
The RUN instruction specifies commands to be run, and captured into the new container image. These commands can include items such as installing software, creating files and directories, and creating environment configuration.
The RUN instruction goes like this:
The difference between the exec and shell form is in how the RUN instruction is executed. When using the exec form, the specified program is run explicitly.
Here’s an example of the exec form:
The resulting image runs the powershell New-Item c:/test command:
To contrast, the following example runs the same operation in shell form:
The resulting image has a run instruction of cmd /S /C powershell New-Item c:\test .
Considerations for using RUN with Windows
On Windows, when using the RUN instruction with the exec format, backslashes must be escaped.
When the target program is a Windows installer, you’ll need to extract the setup through the /x: flag before you can launch the actual (silent) installation procedure. You must also wait for the command to exit before you do anything else. Otherwise, the process will end prematurely without installing anything. For details, please consult the example below.
Examples of using RUN with Windows
The following example Dockerfile uses DISM to install IIS in the container image:
This example installs the Visual Studio redistributable package. Start-Process and the -Wait parameter are used to run the installer. This ensures that the installation completes before moving on to the next instruction in the Dockerfile.
For detailed information on the RUN instruction, see the RUN reference.
The COPY instruction copies files and directories to the container’s file system. The files and directories must be in a path relative to the Dockerfile.
The COPY instruction’s format goes like this:
If either source or destination includes white space, enclose the path in square brackets and double quotes, as shown in the following example:
Considerations for using COPY with Windows
On Windows, the destination format must use forward slashes. For example, these are valid COPY instructions:
Meanwhile, the following format with backslashes won’t work:
Examples of using COPY with Windows
The following example adds the contents of the source directory to a directory named sqllite in the container image:
The following example will add all files that begin with config to the c:\temp directory of the container image:
For more detailed information about the COPY instruction, see the COPY reference.
The ADD instruction is like the COPY instruction, but with even more capabilities. In addition to copying files from the host into the container image, the ADD instruction can also copy files from a remote location with a URL specification.
The ADD instruction’s format goes like this:
If either the source or destination include white space, enclose the path in square brackets and double quotes:
Considerations for running ADD with Windows
On Windows, the destination format must use forward slashes. For example, these are valid ADD instructions:
Meanwhile, the following format with backslashes won’t work:
Additionally, on Linux the ADD instruction will expand compressed packages on copy. This functionality is not available in Windows.
Examples of using ADD with Windows
The following example adds the contents of the source directory to a directory named sqllite in the container image:
The following example will add all files that begin with «config» to the c:\temp directory of the container image.
The following example will download Python for Windows into the c:\temp directory of the container image.
For more detailed information about the ADD instruction, see the ADD reference.
WORKDIR
The WORKDIR instruction sets a working directory for other Dockerfile instructions, such as RUN , CMD , and also the working directory for running instances of the container image.
The WORKDIR instruction’s format goes like this:
Considerations for using WORKDIR with Windows
On Windows, if the working directory includes a backslash, it must be escaped.
Examples
For detailed information on the WORKDIR instruction, see the WORKDIR reference.
The CMD instruction sets the default command to be run when deploying an instance of the container image. For instance, if the container will be hosting an NGINX web server, the CMD might include instructions to start the web server with a command like nginx.exe . If multiple CMD instructions are specified in a Dockerfile, only the last is evaluated.
The CMD instruction’s format goes like this:
Considerations for using CMD with Windows
On Windows, file paths specified in the CMD instruction must use forward slashes or have escaped backslashes \\ . The following are valid CMD instructions:
However, the following format without the proper slashes will not work:
For more detailed information about the CMD instruction, see the CMD reference.
Escape character
In many cases a Dockerfile instruction will need to span multiple lines. To do this, you can use an escape character. The default Dockerfile escape character is a backslash \ . However, because the backslash is also a file path separator in Windows, using it to span multiple lines can cause problems. To get around this, you can use a parser directive to change the default escape character. For more information about parser directives, see Parser directives.
The following example shows a single RUN instruction that spans multiple lines using the default escape character:
To modify the escape character, place an escape parser directive on the very first line of the Dockerfile. This can be seen in the following example.
Only two values can be used as escape characters: \ and ` .
For more information about the escape parser directive, see Escape parser directive.
PowerShell in Dockerfile
PowerShell cmdlets
PowerShell cmdlets can be run in a Dockerfile with the RUN operation.
REST calls
PowerShell’s Invoke-WebRequest cmdlet can be useful when gathering information or files from a web service. For instance, if you build an image that includes Python, you can set $ProgressPreference to SilentlyContinue to achieve faster downloads, as shown in the following example.
Invoke-WebRequest also works in Nano Server.
Another option for using PowerShell to download files during the image creation process is to use the .NET WebClient library. This can increase download performance. The following example downloads the Python software, using the WebClient library.
Nano Server does not currently support WebClient.
PowerShell scripts
In some cases, it may be helpful to copy a script into the containers you use during the image creation process, then run the script from within the container.
This will limit any image layer caching and decrease the Dockerfile’s readability.
This example copies a script from the build machine into the container using the ADD instruction. This script is then run using the RUN instruction.
Docker build
Once a Dockerfile has been created and saved to disk, you can run docker build to create the new image. The docker build command takes several optional parameters and a path to the Dockerfile. For complete documentation on Docker Build, including a list of all build options, see the build reference.
The format of the docker build command goes like this:
For example, the following command will create an image named «iis.»
When the build process has been initiated, the output will indicate status and return any thrown errors.
The result is a new container image, which in this example is named «iis.»