Go back

Setup and installation of 'Milvus DB: AI-Ready Vector Database Environment' on Azure

This section describes how to launch and connect to ‘Milvus DB: AI-Ready Vector Database Environment’ VM solution on Azure Platform.

  1. Open Milvus DB: AI-Ready Vector Database Environment VM listing on Azure Marketplace.

/img/azure/milvus-vm/marketplace.png

  1. Click on Get It Now
  • Login with your credentials, provide the details here. Once done click on Continue. /img/azure/milvus-vm/continue.png

  • It will take you to the Product details page. Click on Create. /img/azure/milvus-vm/create.png

  • Select a Resource group for your virtual machine

  • Select a Region where you want to launch the VM(such as East US)

/img/azure/milvus-vm/basics-page-01.png

  • Note: If you see “This image is not compatible with selected security type. To keep trusted launch virtual machines, select a compatible image. Otherwise change your security type back to Standard” error message below the Image name as shown in the screenshot below then please change the Security type to Standard.

/img/azure/milvus-vm/image-mismatch-error.png

/img/azure/milvus-vm/standard-security-type.png

  • Optionally change the number of cores and amount of memory.

Minimum VM Specs : 8GB vRAM / 2vCPU, but for swift performace please choose 16GB vRAM/4vCPU configuration.

Select the Authentication type as Password and enter Username as ubuntu and Password of your choice.

/img/azure/milvus-vm/basics-page-02.png

  • Optionally change the OS disk size and its type. By default the VM comes with 40GB of disk.

/img/azure/milvus-vm/disk.png

  • Optionally change the network and subnetwork names. Be sure that whichever network you specify has ports 22 (for ssh), 3389 (for RDP), port 80 (for HTTP) and 443 (for HTTPS) exposed.

The VM comes with the preconfigured NSG rules. You can check them by clicking on Create New option available under the security group option.

/img/azure/milvus-vm/network.png

/img/azure/milvus-vm/ports.png

  • Optionally go to the Management, Advanced and Tags tabs for any advance settings you want for the VM.
  • Click on Review + create and then click on Create when you are done.
    Virtual Machine will begin deploying.
  1. A summary page displays when the virtual machine is successfully created. Click on Go to resource link to go to the resource page. It will open an overview page of virtual machine.

/img/azure/milvus-vm/vm-overview.png

  1. If you want to update your password then open up the left navigation pane, select Run command, select RunShellScript and enter following command to change the password of the vm .
sudo echo ubuntu:yourpassword | chpasswd

/img/azure/run_command_option-01.png

/img/azure/run_command_change_passwd-01.png

Now the password for ubuntu user is set, you can SSH to the VM. To do so, first note the public IP address of the VM from VM details page as highlighted below

/img/azure/milvus-vm/public-ip.png

Open putty, paste the IP address and click on Open.

/img/azure/desktop-linux-ubuntu2404/putty-01.png

login as ubuntu and provide the password for ‘ubuntu’ user.

/img/azure/milvus-vm/ssh-login.png

  1. You can also connect to the VM’s desktop environment from any local windows machine using RDP protocol or local linux machine using Remmina.

  2. To connect using RDP via Windows Machine, first note the public IP address of the VM from VM details page as highlighted below

/img/azure/milvus-vm/public-ip.png

  1. Then From your local windows machine, goto “start” menu, in the search box type and select “Remote desktop connection”.
    In the “Remote Desktop connection” wizard, copy the public IP address and click connect

/img/azure/desktop-linux/rdp.png

  1. This will connect you to the VM’s desktop environment. Provide the username (e.g “ubuntu”) and the password set in the step4 to authenticate. Click OK

/img/azure/desktop-linux/rdp-login.png

  1. Now you are connected to the out of box “Milvus DB: AI-Ready Vector Database Environment” VM’s desktop environment via Windows Machine.

/img/azure/milvus-vm/rdp-desktop.png

  1. To connect using RDP via Linux machine, first note the external IP of the VM from VM details page, then from your local Linux machine, goto menu, in the search box type and select “Remmina”.

Note: If you don’t have Remmina installed on your Linux machine, first Install Remmina as per your linux distribution.

/img/gcp/common/remmina-search.png

  1. In the “Remmina Remote Desktop Client” wizard, select the RDP option from dropdown and paste the external ip and click enter.

/img/gcp/common/remmina-external-ip.png

  1. This will connect you to the VM’s desktop environment. Provide “ubuntu” as the userid and the password set in above reset password step to authenticate. Click OK

/img/gcp/common/remmina-rdp-login.png

  1. Now you are connected to out of box “Milvus DB: AI-Ready Vector Database Environment” VM’s desktop environment via Linux machine.

/img/azure/milvus-vm/rdp-desktop.png

  1. Once you are in RDP session, Open the FireFox from RDP desktop and enter below url to access the Milvus Web UI.
http://localhost:9091/webui/

/img/azure/milvus-vm/milvus-webui-in-rdp.png

Note: Milvius UI is available only via RDP as it did not provide any kind of authentication. However if you want to access it publicly using Public IP of the VM in your local browser then please follow the steps given in Milvus WebUI Proxy Setup .

  1. To access the JupyterHub Web Interface, copy the public IP address of the VM and paste it in the browser as https://public_ip_of_vm.

Browser will display a SSL certificate warning message. Accept the certificate warning and Continue.

/img/azure//milvus-vm/browser-warning.png

  1. Provide the ‘ubuntu’ user and its password set during VM creation. ubuntu is configured as an admin user here.

/img/azure/milvus-vm/jupyter-login.png

  1. If your jupyter server did not spawn in 30 sec you will see error message as shown in below screenshot. In this case simply click on Home tab and click Start My Server button. It will spawn the server again.

/img/azure/milvus-vm/jupyter-server-error.png

/img/azure/milvus-vm/start-my-server.png

  1. Now you are logged in to jupyterhub. Here you can see we have setup folder configured with jupyter-venv, jupyterhub_config.py files along with other jupyterhub configuration files. You can use jupyter notebook to run and test your AI projects.

/img/azure/milvus-vm/jupyterlab.png

  1. The VM comes preloaded with “Build RAG with Milvus” example. The example file “Build RAG with Milvus and Ollama.ipynb” is available in /home/ubuntu/setup/ directory. Once you logged in the jupyterhub, navigate to setup directory and click on “Build RAG with Milvus and Ollama.ipynb” file.

/img/azure/milvus-vm/example-file.png

In this example, we will show you how to build a RAG(Retrieval-Augmented Generation) pipeline with Milvus and Ollama.

The RAG system combines a retrieval system with a generative model to generate new text based on a given prompt. This example uses the FAQ pages from the Milvus Documentation 2.4.x as the private knowledge in our RAG for a simple RAG pipeline.

The documents are already Downloaded as a zip and extracted to the folder milvus_docs in the same setup directory. The example is using ollama local model to execute , so you don’t need to provide any API keys here.

  1. Click in the first cell and click on + icon to add a cell above option to install the dependencies. Add below line and press shift+ enter to execute the cell or click on play button to run the cell. It will download the required dependencies to execute this example demo.
pip install --upgrade pymilvus openai requests tqdm

/img/azure/milvus-vm/insert-cell-above.png

/img/azure/milvus-vm/install-dependencies.png

  1. You can simply run each cell one by one in same sequence or you can select the Run All Cells option from Run Menu at the top.

/img/azure/milvus-vm/run-all-cells.png

/img/azure/milvus-vm/final-output.png

  1. You can access the Milvus WebUI via RDP session Browser as explained above or if you made it publicly available using your public IP of the VM, and can check the new values got inserted into your Milvus DB after execution of this Example demo.

/img/azure/milvus-vm/collection-output.png

/img/azure/milvus-vm/query-output.png

  1. If suppose at any point of running this example you get a connection error, or if any cell is not wokring then please check the running status of mulvus Docker container. For that connect via SSH terminal of this VM and run below command.
sudo docker ps -alias

If it shows container in exited state, then restart it using:

sudo docker start milvus-standalone

/img/azure/milvus-vm/docker-restart.png

  1. In this Example demo we used milvus documentation and asked a specific query for ,you can play around by updating this example with other values and see how it works in real time.

For more details, please visit Official Documentation page

Go back