How to easily create a Postgres database in Docker
Wasiu Idowu

Wasiu Idowu

Oct 11, 2022

How to easily create a Postgres database in Docker

Have you ever had the problem where a tool or a piece of software works fine on your machine, but the moment you install it on someone else's you get all kinds of issues? Well, I have, and particularly for this reason Docker was invented! In this blog post we will take a quick look at what Docker is and how easy it is to run a database in a Docker container. This container will work on any machine. I promise. Along the way you also learn some Docker specific lingo.

What is Docker?

According to the  official doc, Docker is an" open platform for developing, shipping, and running applications. Docker enables you to separate your applications from your infrastructure so you can deliver software quickly. With Docker, you can manage your infrastructure in the same ways you manage your applications. "

For fully understanding Docker we also need to talk about the difference between Docker and a Virtual Machine (VM). The latter often runs in cloud environments like AWS and Azure. Whenever you create a VM you are sharing the hardware with others and other VMs. What these cloud environments are doing is 'virtualise' the hardware. Docker doesn't do that and does it differently. In a VM you can have multiple Operating Systems running on the same hardware, whilst with Docker you virtualise the Operating System. Therefore, the big difference between VMs and Docker containers is that the former can have multiple (Guest) Operating Systems on the same hardware, through for example VMWare (which is called a Hypervisor). Whilst when you install Docker, you are going to use the Docker Engine to create isolated entities on the OS. These entities are called containers. Docker therefore allows you to automate the deployment of applications in these containers.

Let's install Docker

Enough theory, let's jump into installing Docker and firing up a Postgres database. In order to use Docker you first need to install it. You can either install Docker on a Desktop machine (both Windows and Mac), or on a server (Linux based installations). For this tutorial we're going to install Docker on a Mac. Windows installation instructions can be found here. For a Mac (and I think also for Windows) the installation is fairly straightforward. You download the app and drag it to Applications. Then you double click the  and it should start. You can check if it's working when there is a Docker icon (the whale or ship like image with containers) on the top right next to your other small icons. If this is the case you can quickly follow the 'Hello World' example to get up and running.

How to create a Postgres database

Hands down the easiest way of running a clean Postgres database is by running this command in a terminal window (after Docker has been installed):

docker run --name postgres-db -e POSTGRES_PASSWORD=docker -p 5432:5432 -d postgres

But what does it do?

  • Last section of the command grabs the latest 'postgres' Docker image from the Docker Hub
  • -d means that you enable Docker to run the container in the background
  • -p plus the port numbers means you map the containers port 5432 to the external port 5432 - this allows you to connect to it from the outside.
  • POSTGRES_PASSWORD sets the password to docker. This is the password that gives you access to your database
  • the —name property gives your container a name and means you can easily find it back

Now you can connect to this brand new Postgres database in any tool that allows you to communicate with databases. I tend to use RazorSQL or DBeaver. You need to use the following connection details to actually connect to the DB:

  • Host: localhost
  • Port: 5432
  • User: postgres
  • Password: docker

Once connected you can do anything you want with the database (Create tables, load data etc). But as you can see the database is completely empty. However, the real power of Docker is when you want to easily provision a database that has already content in it. This can be a simple or a complex database structure and schema. The choice is all yours. What this also means is that you can easily spin up such a container (and shut it down). Let's see how below:

useFetch.png

Wasiu Idowu

Wasiu Idowu

Wasiu breaks down complex topics into smaller, simpler bits

Leave a Reply

5 Comments

Olu Falae on Oct 30, 2022

Lorem ipsum dolor sit amet

Martins on Oct 30, 2022

lorem ipsum dolor sit amet consectetur

Magdalene Arthur on Oct 30, 2022

Lorem ipsum dolor sit amet consectetur, adipisicing elit. Quo natus dolores tenetur distinctio ullam, voluptatibus labore inventore numquam nulla, itaque animi dolorem cupiditate repellendus doloribus tempore quod quas laudantium quae. Lorem, ipsum dolor sit amet consectetur adipisicing elit. Ad vel obcaecati sapiente harum distinctio quidem magni, delectus maiores eius veniam, quia mollitia nobis voluptatem corrupti minus provident! Consectetur numquam iusto officiis ratione sequi placeat illum dolor eum veritatis libero voluptatum assumenda, architecto modi quaerat sint sit aspernatur, nobis nihil! Ducimus facilis minima aspernatur dolor! Eius consequatur quae in ut commodi magni perferendis ullam cupiditate! Sapiente.

Aidan Madina on Oct 30, 2022

Lorem ipsum dolor sit amet consectetur adipisicing elit. Vel ullam repudiandae placeat nesciunt vero suscipit qui dolorem quidem culpa laudantium!

Adam Smith on Oct 30, 2022

Lorem ipsum dolor sit amet consectetur, adipisicing elit. Deserunt rerum nobis quia, iste similique, ut, totam atque amet nostrum temporibus omnis dicta. Earum maxime quia veritatis, ipsa quibusdam veniam dolorem ducimus architecto exercitationem molestias atque! Fugit vitae obcaecati iure nostrum.

Related Posts

Categories