Install Postgresql On Docker

Postgresql.i686 9.2.24-1.el75 ol7latest postgresql.x8664 9.2.24-1.el75 ol7latest. [email protected] # [email protected] # yum install postgresql11-server Loaded. But before that I wanted to start using PostgreSql with Docker. So I followed this post: Setup PostgreSQL on Windows with Docker and this one: Stop Installing Postgres on Your Laptop: Use Docker Instead. So this was my first idea for a docker container. Docker pull Postgres is a simple way to install and run software on your local machine. The Docker pull command pulls down the latest stable release Postgres image from the official Postgres docker hub repository. Don’t install Postgres. Create a directory to serve as the local host point for Postgres Data Files. Docker and PostgreSQL Download and install Docker and PostgreSQL. Download and Install Docker. (You may have to restart your system.) Open your command prompt and type 'docker -help' and you should see many commands that are provided with Docker. Inside: — name is the Docker container name that you want to set to the PostgreSQL server’s container.-e POSTGRESUSER= declares the environment variable POSTGRESUSER, which is the username we will use to log into the PostgreSQL server.

Introduction to the creation of PostgreSQL and docker container

If you’re developing an application that interacts with a PostgreSQL database, there’s a good chance you may want to use a Docker container. Packaging an application and its dependencies in a container is an effective way to ensure that your app will work smoothly in any environment. In this article, we’ll show you how to use PostgreSQL and Docker together, providing step-by-step instructions on the installation and setup process.

Prerequisites to using Postgres

Although we’ll be running Postgres in a Docker container, we still need to have PostgreSQL and psql installed on our system.

Install Postgres and psql on Linux

Before you can use psql, you’ll need to install the postgresql-client-common library. The following command shows how to install it on a Linux distribution using the APT repository:

sudo apt install postgresql-client-common

The following commands will install the PostgreSQL client:

sudoapt-get install postgresql-client
sudoapt-get install postgresql postgresql-contrib

Install Postgres and psql on macOS

If you’re running macOS, you can use Homebrew’s brew command to install Postgres and psql with the command shown below:

Use these commands to install and start the PostgreSQL service with Homebrew:

brew install postgres
brew services start postgresql

Install the Docker Engine

Make sure that you’ve also installed Docker because we’ll be using this to pull the Postgres image.

Install Docker on Windows

If you’re running Windows, login and download the installer here.

Install Docker on macOS

You can sign in and then download the DMG file for the interactive installer on macOS, or you can use Homebrew to install Docker.

Install ‘Docker’ on mac using Homebrew

Here’s how to use Homebrew’s brew command to install the Docker CE:

You can then use the command docker --version to display the version.

Install the Docker-Machine using Homebrew

The following Homebrew command can be used to install the Docker Machine on macOS:

brew install docker-machine

Before you can create a machine, you’ll need to install the virtual box. You can use this command to install it:

Install ‘Docker CE’ on Ubuntu Linux

Now that we’ve covered the installation process on Windows and macOS, let’s talk about how to install Docker on an Ubuntu distribution of Linux. We’ll be using the APT-GET repository to handle the installation, so we’ll start the process by using the command sudo apt-get update. This command will update the repository packages before installing.

First, we’ll install the dependency package for Docker:

sudoapt-get-yinstall apt-transport-https ca-certificates curl software-properties-common

Next, we’ll need to add the GPG key to the Docker Packages.

For a Debian-based distribution such as Linux Mint or Ubuntu, use the following command:

curl -fsSL sudoapt-key add -

Then add the .deb` file for the Docker repository:

sudo add-apt-repository 'deb [arch=amd64] $(. /etc/os-release; echo '$UBUNTU_CODENAME') stable'

Next, we’ll use the command cat /etc/apt/sources.list.d/additional-repositories.list to view the newly-added line in the repositories file. After that, we’ll need to run sudo apt-get update again to update the index of the package.

Finally, we’ll install both Docker CE and Docker Compose from the repository:

At this point, it would be a good idea to check if Docker has been installed and the daemon has been started. Let’s run the command shown below:

sudo systemctl status docker

This command will display output stating that Docker is active:

If you’re using the YUM repository on a Red Hat Linux distribution such as CentOS or Fedora, you’ll need to perform the following steps:

sudoyum install-y yum-utils

Then you’ll need to grab the stable repository:

sudo yum-config-manager

Last but not least, you can install the Docker CE using the command shown below:

After you complete the installation, you can start it by typing this command:

sudo systemctl start docker

Use Docker ps to list containers

To show all running containers, we can use the docker ps command. We use the docker -v command to get the version of Docker that’s installed on the machine. When you run these commands, you might encounter a permissions error that says something like the following:

Got permission denied while trying to connect
to the Docker daemon socket..

If this occurs, use the following command to add your user, then log out and log in again:

Now try running docker ps again, and it should list the following:


Pull the Postgres Docker image

We can use the docker pull command to have the Docker engine download the official Docker image for Postgres from the registry. The following command will pull the image to the local Docker directory– typically, this location will be /var/lib/docker:

Since we already installed everything we need for Docker, we can go ahead and create a Docker container that pulls the Postgres image:

A Docker image is made up of a series of read-only layers that are generated during the build of a Docker container. If you modify the files, Docker will just copy the layer where the changes were applied. When a Docker container is deleted, all of the changes made to the container will be lost. To persist this data, we’ll implement the concept of volumes in the Docker container.

Let’s look at the command used to create a volume:

docker volume create pgdata

To inspect the volume we just created, we use the following command:

This command should return output that looks like this:

'CreatedAt': '2019-11-05T16:12:44+08:00',
'Driver': 'local',
'Labels': {},
'Mountpoint': '/var/lib/docker/volumes/pgdata/_data',
'Name': 'pgdata',
'Options': {},
'Scope': 'local'
Install Postgresql On Docker

Next, we’ll start our instance of Postgres and use the 5432:5432 part of the command to bind the default 5432 PostgreSQL port to our localhost. The following example illustrates how this is done:

docker run -p 5432:5432 -d
-e POSTGRES_USER=postgres
-v pgdata:/var/lib/postgresql/data

We’ll check that the container is running by using the docker ps or docker container ls commands. The returned results should look something like the following:

b2e72fa0444f postgres 'docker-entrypoint.s…' 2 minutes ago Up 2 minutes>5432/tcp silly_sinoussi

There’s a lot going on in the command shown above. Let’s take a closer look at how it works:

  • The -p 5432:5432 binds the port on localhost to the container. This means you’ll able to run applications outside of the Docker container and connect to the PostgreSQL server.

  • The -d is used to enable the launcher of the container in the background.

  • The -e sets an environment variable containing the value of the Docker container. It sets the password, user and the database. If these values are not provided, it will use the default value of “postgres”.

  • The -v is used to mount ‘pgdata’ to the container path. This volume will persist even if the container is deleted.

Postgres Docker project directory

If you’d like to create a project folder with a bind-mounted volume for Postgres data at that project location, simply create a directory for the project and then change into it:

We’ll need to create a docker-compose.yml config file to modify our container so that we can bind-mount a local directory for our Postgres databases and tables. The following command will create the YAML file using the Sublime editor:

subl docker-compose.yml

Set up the docker-compose file for the Postgres container

The following YAML script shows how you can set up the docker.compose.yml file for your project:

version: '3'
# Service for the Postgres database
# Pull the latest 'postgres' image
image: 'postgres'
container_name: 'postgres_docker'
# Postgres environment parameters
- POSTGRES_USER = objectrocket
- POSTGRES_DB = some_database
# Bind mount the default Postgres port
- '54321:5432'
# Bind mount local volume for Postgres data
- ./pg-data:/var/lib/postgresql/data

NOTE: Be sure to change the 54321 port and the pg-data bind-mounted directory to match your personal specifications.

Install postgresql on docker windows

Use docker-compose to start the container

Install Postgresql On Docker

After modifying your docker-compose file with the YAML data, save it and then run the following command inside of your project directory. This will have Docker create a container using the above specifications:

If we use the ls command (or dir in Windows) in another terminal tab, we’ll see that the pd-data folder was automatically created.

We can use the following commands to enter Postgres:

Install Postgresql On Docker
sudo-u postgres -i

Connect and run some queries in the psql

If you already have PostgreSQL installed on your machine, you can use the command shown below to connect:

Otherwise, you can connect to the container using the Docker exec:

docker exec -it b2e72fa0444f psql -U postgres demo

NOTE: Remember to replace b2e72fa0444f with your container ID. If you’re not sure of the ID, use the docker ps command to have the Docker engine return a list of all of your containers.

Conclusion to PostgreSQL and Docker

Install Postgresql On Docker

If you’re interested in developing an application that can be packaged to work seamlessly in nearly any environment, a Docker container may be the right tool for the job. In this tutorial, we explained how to use PostgreSQL in a Docker container, walking through each step involved in the installation and configuration process. With these instructions to guide you, you’ll be able to work with PostgreSQL and Docker in your own development efforts.