Run Milvus in Docker (Windows)
This page demonstrates how to run Milvus on Windows using Docker Desktop for Windows.
Prerequisites
Install Python 3.8+.
Run Milvus in Docker
Milvus provides an installation script to install it as a Docker container. Once you have installed Docker Desktop on Microsoft Windows, you can access the Docker CLI from PowerShell or Windows Command Prompt in administrator mode and from WSL 2.
From PowerShell or Windows Command Prompt
If you are more familiar with PowerShell or Windows Command Prompt, the command prompt is as follows.
Open Docker Desktop in administrator mode by right-clicking and selecting Run as administrator.
Download the installation script and save it as
standalone.bat
.C:\>Invoke-WebRequest https://raw.githubusercontent.com/milvus-io/milvus/refs/heads/master/scripts/standalone_embed.bat -OutFile standalone.bat
Run the downloaded script to start Milvus as a Docker container.
C:\>standalone.bat start Wait for Milvus starting... Start successfully. To change the default Milvus configuration, edit user.yaml and restart the service.
After running the installation script:
A docker container named milvus-standalone has been started at port 19530.
An embed etcd is installed along with Milvus in the same container and serves at port 2379. Its configuration file is mapped to embedEtcd.yaml in the current folder.
The Milvus data volume is mapped to volumes/milvus in the current folder.
You can use the following commands to manage the Milvus container and stored data.
# Stop Milvus C:\>standalone.bat stop Stop successfully. # Delete Milvus container C:\>standalone.bat delete Delete Milvus container successfully. # Container has been removed. Delete successfully. # Data has been removed.
From WSL 2
If you prefer to start Milvus using Linux commands and shell scripts on Windows, ensure that you already have installed the WSL 2 command. For details on how to install WSL 2 command, you can refer to this Microsoft article.
Start WSL 2.
C:\>wsl --install Ubuntu already installed. Starting Ubuntu...
Download the installation script
# Download the installation script $ curl -sfL https://raw.githubusercontent.com/milvus-io/milvus/master/scripts/standalone_embed.sh -o standalone_embed.sh # Start the Docker container $ bash standalone_embed.sh start
Start Milvus as a docker container.
$ bash standalone_embed.sh start Wait for Milvus Starting... Start successfully. To change the default Milvus configuration, add your settings to the user.yaml file and then restart the service.
You can use the following commands to manage the Milvus container and stored data.
# Stop Milvus $ bash standalone_embed.sh stop Stop successfully. # Delete Milvus data $ bash standalone_embed.sh stop Delete Milvus container successfully. Delete successfully.
Run Milvus with Docker Compose
Once you have installed Docker Desktop on Microsoft Windows, you can access the Docker CLI from the PowerShell or Windows Command Prompt in administrator mode. You can run Docker Compose either in PowerShell, Windows Command Prompt, or WSL 2 to start Milvus.
From PowerShell or Windows Command Prompt
Open Docker Desktop in administrator mode by right-clicking and selecting Run as administrator.
Run the following commands in PowerShell or Windows Command Prompt to download the Docker Compose configuration file for Milvus Standalone and start Milvus.
# Download the configuration file and rename it as docker-compose.yml C:\>Invoke-WebRequest https://github.com/milvus-io/milvus/releases/download/v2.4.15/milvus-standalone-docker-compose.yml -OutFile docker-compose.yml # Start Milvus C:\>docker compose up -d Creating milvus-etcd ... done Creating milvus-minio ... done Creating milvus-standalone ... done
Depending on your network connection, downloading images for the Milvus installation may take a while. Once the containers named milvus-standalone, milvus-minio, and milvus-etcd are up, you can witness that
The milvus-etcd container does not expose any ports to the host and maps its data to volumes/etcd in the current folder.
The milvus-minio container serves ports 9090 and 9091 locally with the default authentication credentials and maps its data to volumes/minio in the current folder.
The milvus-standalone container serves ports 19530 locally with the default settings and maps its data to volumes/milvus in the current folder.
You can also call the Linux version of the Docker Compose commands if you have WSL 2 installed.
From WSL 2
The procedure is similar to using Docker Compose to install Milvus in Linux systems.
Start WSL 2.
C:\>wsl --install Ubuntu already installed. Starting Ubuntu...
Download the Milvus configuration file.
$ wget https://github.com/milvus-io/milvus/releases/download/v2.4.17/milvus-standalone-docker-compose.yml -O docker-compose.yml
Start Milvus.
$ sudo docker compose up -d Creating milvus-etcd ... done Creating milvus-minio ... done Creating milvus-standalone ... done
FAQs
How can I deal with the Docker Engine stopped
error?
Once you install Docker Desktop in Windows, you may encounter the Docker Engine stopped
error if your computer are not configured properly. In this case, you may need to make the following checks:
Check whether virtualization is enabled.
You can check whether virtualization is enabled by looking at the Performance tab in the Task Manager.
Virtualization in Task Manager
If virtualization is disabled, you may need to check the BIOS settings of your motherboard firmware. The way to enable virtualization in BIOS settings varies with motherboard vendors. For the ASUS motherboard, for example, you can refer to this article on enabling virtualization.
Then, you need to restart your computer and enable Hyper-V. For details, refer to this Microsoft article.
Check whether the Docker Desktop Service has been started.
You can run the following command to start the Docker Desktop Service.
C:\>net start com.docker.service The Docker for Windows Service service is starting. The Docker for Windows Service service was started successfully.
Check whether WSL has been installed properly.
You can run the following command to install or update the WSL 2 command.
C:\>wsl --update Checking for updates. The most recent version of Windows Subsystem for Linux is already installed.
Check whether Docker Daemon has been started.
You need to go to the installation directory of Docker Desktop and run
.\DockerCli.exe -SwitchDaemon
to start Docker Daemon.C:\>cd "C:\Program Files\Docker\Docker" C:\Program Files\Docker\Docker>.\DockerCli.exe -SwitchDaemon Switching to windows engine: Post "http://ipc/engine/switch": open \\.\pipe\dockerBackendApiServer: The system cannot find the file specified.
Check whether you have started Docker Desktop in administrator mode.
Ensure that you have started Docker Desktop in administrator mode. To do so, right-click on Docker Desktop and choose Run as administrator.
Start Docker Desktop as Administrator
How can I deal with WSL-related issues while deploying Milvus?
If you have encountered WSL-related issues while running Milvus from WSL 2, you may need to check whether you have configured Docker Desktop to use the WSL 2-based engine as follows:
Ensure that “Use the WSL 2 based engine” is checked in Settings > General.
Use the WSL 2 based engine in Docker Desktop Settings
Select from your installed WSL 2 distributions which you want to enable Docker integration on by going to: Settings > Resources > WSL Integration.
Select WSL 2 distributions in Docker Desktop Settings
How can I deal with the volume-related errors prompted during Milvus startup that reads Read config failed
?
Read config failed error prompt in Milvus startup
To deal with the error prompted during Milvus startup that reads “Read config failed,” you need to check whether the volume mounted into the Milvus container is correct. If the volume is correctly mounted into the container, you can use the docker exec
command to go into the container and list the /milvus/configs folder as follows:
List Milvus config files
What’s next
Having installed Milvus in Docker, you can:
Check Quickstart to see what Milvus can do.
Learn the basic operations of Milvus:
Deploy your Milvu cluster on clouds:
Explore Milvus WebUI, an intuitive web interface for Milvus observability and management.
Explore Milvus Backup, an open-source tool for Milvus data backups.
Explore Birdwatcher, an open-source tool for debugging Milvus and dynamic configuration updates.
Explore Attu, an open-source GUI tool for intuitive Milvus management.