DEV Community

Rutam Prita Mishra
Rutam Prita Mishra

Posted on • Edited on

Deploying MindsDB on a Digital Ocean Droplet

MindsDB in Action

Introduction

MindsDB has the vision to enforce advanced predictive capabilities directly in our Database. With this, anyone who knows SQL can utilize the built-in machine learning techniques without needing any other outsourced tools or training.

In short, MindsDB aims to provide intelligent databases to make better data-driven decisions in the existing database without the effort of creating a new one.

Deployment on Digital Ocean

Digital Ocean is a Cloud computing platform that provides cloud computing services with predictable pricing, developer-friendly features, and scalability as you need.

Today, we will be deploying the MindsDB server on a Digital Ocean Droplet (a scalable virtual machine on DO Platform) and trying to connect to it using our local MySQL client or Dbeaver.

Step 1: Sign up for a Digital Ocean account if you don't have one yet. They provide 100$ Credits when you sign up so that you can try it for free.

DO Singup

Step 2: Once you've created an account, you should see a dashboard like this. If you look towards the left panel, you can find the Droplets option. Now click on Droplets.

DO Dashboard

Step 3: Once you are in the Droplets Dashboard, hit Create Droplet.

Droplet Dashboard

Step 4: Now the Create Droplet dashboard opens. Here you need to choose the configurations you want for your virtual machine and can also select any additional applications you want to install on your VM from the Marketplace. For now, we will move ahead with the following configurations that would boot up a standard VM for us with the required performance.

Distributions : Ubuntu 20.04(LTS) x64
Choose a Plan : Shared CPU (Basic)
CPU Options : $20/mo (4GB/2CPUs, 80GB SSD Disk, 4TB Transfer)
Datacenter Region : Closest Region to you to reduce Latency (Bangalore for me)
Authentication : SSH Key (If you have one) or Root Password (Set your Root Password below to login to the VM)
Select Additional Option : Choose Monitoring and IPv6 which are free services
Finalize and Create : Set the number of Droplets you want (1 for now) and the Name of Droplet
Select a Project : Leave it at default for now

Or you can simply go to the top and select Marketplace and search for Docker there and select Docker on Ubuntu directly, as we would be using Docker to install the MindsDB server on our Droplet, instead of choosing a Ubuntu LTS distribution and then installing docker on top of it manually.

Hit Create Droplet and wait for a while till it spins one for us in the cloud.

Create Droplet Dashboard

NOTE: The above sample specs for the Ubuntu Docker instance is also the basic minimum configuration that you would need to successfully deploy and run your self-hosted MindsDB version on a DigitalOcean Droplet.

Step 5: Once your Droplet is created, you can always click on the Droplets in the left Navigation pane and Click on the Droplet name to go into the Droplet Dashboard details. Now click on the Console from the top right corner. This should open up a terminal for you where you can interact with your VM.

Created Droplet

Step 6: Now while you are inside the console, simply check whether Docker is installed or not using the following command.

docker run hello-world
Enter fullscreen mode Exit fullscreen mode

If the command successfully returns Hello From Docker, then you're good to go. Now we start with the installation of MindsDB on our Droplet.

Hello from Docker

Step 7: Now we will use the following commands in sequence to get done with the installation of MindDB Sever.

docker pull mindsdb/mindsdb
Enter fullscreen mode Exit fullscreen mode

This should pull the latest Production image to our Droplet. You can also use the latest Beta version as well using the following command.

docker pull mindsdb/mindsdb_beta
Enter fullscreen mode Exit fullscreen mode

MindsDB install using Docker

Step 8: After that, we need to publish the ports so that we can hit the endpoints and communicate with the MindsDB Server in our Droplet. So, we will first expose the MindsDB GUI Port and then the MySQL Port that we will be using for now with the commands below.

MindsDB GUI with MySQL API

docker run -p 47334:47334 -p 47335:47335 mindsdb/mindsdb
Enter fullscreen mode Exit fullscreen mode

You can always follow the MindsDB Getting Started documentation if you need further information or want to install MindsDB by any other means other than Docker.

Running MindsDB using Docker

Step 9: Now you can access the MindsDB GUI using the Droplet IPv4:47334. Make sure you have turned off any VPN service you're using or else you may not be able to connect to the GUI using the URL.

MindsDB GUI

Step 10: This step enables us to connect a database client to our MindsDB server. For now, I would be using DBeaver to do the same. You can also connect your local MySQL server following the steps here.

NOTE: You should follow the local deployment steps instead of cloud as this is a local instance hosted on the cloud and not the official MindsDB cloud edition. The default username is mindsdb and the default password is empty.

We will first need to define the connection settings in Dbeaver before we can connect it. Always make sure you're using MySQL only or MySQL8 or higher from the available options.

DBeaver Connection

Click on Next and fill in the following details in the upcoming screen.

Hostname : Your Droplet IPv4
Port : 47335
Username : mindsdb
Password : Leave it empty.

DBeaver Connection

Now hit the Test Connection and once it returns success, click on Finish.

NOTE: If you're running it for the first time, it may ask you to download some additional driver files. Check Force Download/Overwrite and hit `Download to proceed.

Install Drivers

Tables in MindsDB

Tables in MindsDB

Once connected to the mindsdb database, it will contain 3 tables predictors, commands and datasources. You can simply run a query show tables; to see these as shown in the snippet above.
The Predictors table contains all the newly trained ML models as a new record. Each column in the Predictors table contains information about each of these models. You can always find more information by visiting MindsDB Documentation page.

This concludes the tutorial on how to deploy the MindsDB server on a Digital Ocean Droplet and connect to it using a local client. Please drop a like let me know in the comments if you found this useful or have any other suggestions.

NOTE: The dashboard images belong to the official platforms of Digital Ocean and MindsDB respectively and are used here only for illustrative purposes.

Top comments (2)

Collapse
 
smyja profile image
Smyja

great tutorial. Demo account is seriously limited.

Collapse
 
rutamhere profile image
Rutam Prita Mishra

Thanks for liking the tutorial @smyja