PostgreSQL is an open-source, object-relational database system that provides an implementation of the SQL querying language. It has all the standard features of traditional commercial database systems with additional enhancements in next-generation DBMS systems.

Most Linux platforms, such as Debian, Red Hat / CentOS, SUSE, and Ubuntu, have PostgreSQL integrated with their package management. It is recommended that you install PostgreSQL this way since it ensures a proper integration with the operating system, including automatic patching and other update management functionality.

This tutorial will guide you through the process n how to install PostgreSQL on Ubuntu systems. We will be using Ubuntu 18.04 version and Ubuntu 16.04. 

What you will need (for Ubuntu 18.04)

  • An Ubuntu 18.04 Linux server
  • A root user account or a user account with sudo privileges
  • Access to the terminal window
  • Basic understanding of Linux commands

Method 1: Install from PostgreSQL Apt repository

Step 1: Add PostgreSQL Repository

PostgreSQL is available by default on all Ubuntu versions. However, it does not guarantee automatic updates when new releases come out. Therefore, the best way to install the software is from the PostgreSQL Apt repository.

First, enter the following commands to add the GPG repository key:

sudo apt-get install wget ca-certificates

wget --quiet -O - https://www.postgresql.org/media/keys/ACCC4CF8.asc | sudo apt-key add -

Now add the PostgreSQL repository by entering:

sudo sh -c 'echo "deb http://apt.postgresql.org/pub/repos/apt/ `lsb_release -cs`-pgdg main" >> /etc/apt/sources.list.d/pgdg.list'

Step 2: Install PostgreSQL

Now that the PostgreSQL repository has been added to your system, it’s best to run an update on your system’s package list. This will ensure that you will install the latest PostgreSQL package.

sudo apt-get update

To install PostgreSQL, enter the following:

sudo apt-get install postgresql postgresql-contrib

The -contrib will add some additional utilities and functionalities to the PostgreSQL installation.

Method 2: Install from the Local Ubuntu repository

Step 1: Check the available PostgreSQL version

In this section, we will install PostgreSQL from the local ubuntu repository. However, remember that you will likely not get the latest package version.

First, we will update the repository:

sudo apt-get update

Now enter the following command to verify which version of PostgreSQL is available and if it will be okay for you. The following command will show all necessary information, including version and size.

apt show postgresql

Step 2: Install PostgreSQL package

To install PostgreSQL, enter the following command:

sudo apt-get install postgresql postgresql-contrib

With that, you have completed the installation of PostgreSQL on Ubuntu1 18.04. After installing from either the local repository or the PostgreSQL Apt Repository, the following steps will be used to connect to PostgreSQL successfully.

If you're also looking to configure a DNS server on your Ubuntu system, check out our detailed guide on how to install BIND on Ubuntu.

Step 3: Connect to PostgreSQL

By default, Postgres uses a concept called “roles” to handle authentication and authorization. During the installation process, a user account called Postgres was created, and you can access this by this command:

$ sudo su – postgres

Now with one simple command, you can enter the Postgres prompt:

$ Psql

This will log you into the PostgreSQL prompt, and from here, you are free to interact with the database management system immediately.

If you’re interested in installing .deb files on Ubuntu for managing packages and dependencies, check out our guide on how to install .deb files on Ubuntu for a detailed walkthrough.

If you would like to exit the PostgreSQL prompt:

postgres-# \q

This will bring you to the Postgres Linux command prompt. If you would like to return to your regular system user, enter:

exit

Another way to connect to the Postgres prompt is to run the psql command directly. To do this, enter the following command:

$ sudo -u postgres psql

This command will log you into Postgres without going through the intermediary bash shell.

Step 4: Check connectivity

If you are connected to PostgreSQL and want to see details of the connection, use the command:

postgres-# conninfo

The output displays the database name, the account you are logged in to, the socket path, and the port number.

Step 5: Create a new role

Once you are logged into the Postgres account, you can create a new role by using this command:

postgres-# createuser –interactive

If you don’t want to switch to the Postgres account, you can do this using the sudo command:

$ sudo -u postgres createuser –interactive

No matter how you want to add the user, the run script will be the same. You will be prompted with some choices to create a user.

What you will need (for Ubuntu 16.04)

  • An Ubuntu 16.04 Linux server
  • A root user account or a user account with sudo privileges
  • Access to the terminal window
  • Basic understanding of Linux commands

Step 1: Update the system

First, ensure that all your system packages are up-to-date by running the following apt-get commands in the terminal.

sudo apt-get update

sudo apt-get upgrade

Step 2: Installing the PostgreSQL server

PostgreSQL is available in the default repositories. So enter the following command from the terminal to install it:

apt-get install postgresql postgresql-contrib phppgadmin

If you're also interested in using Ruby on Rails with your PostgreSQL setup, check out our guide on how to install Ruby on Rails in Ubuntu for a complete walkthrough.

Step 3: Access the PostgreSQL command prompt.

After installing the PostgreSQL database server, it automatically creates a user ‘Postgres with role ‘Postgres. It also creates a system account with the same name ‘Postgres. So to connect to the Postgres server, log in to your system as user of Postgres and connect database:

su - postgres

psql

Now you are logged in to the PostgreSQL database server. To check login info, use the following command from a database command prompt:

postgres-# \conninfo

To disconnect from the PostgreSQL database command prompt, type the below command and press enter. It will return you to the Ubuntu command prompt:

postgres-# \q

Step 4: Create a new user and database

For example, let us create a new user called “idroot” with the password “idrootnet”, and a database called “idrootdb”.

sudo -u postgres createuser -D -A -P idroot

sudo -u postgres createdb -O idroot idrootdb

Step 5: Configure Apache2 for phpPgAdmin.

phpPgAdmin is a web-based administration tool for PostgreSQL. It is perfect for PostgreSQL DBAs, newbies, and hosting services. You need to configure apache for phpPgAdmin. Edit the file /etc/apache2/conf-available/phppgadmin.conf:

nano /etc/apache2/conf-available/phppgadmin.conf

Comment out the line #Require local by adding a # in front of the line and below the line allow from all so that you can access your browser.

Step 6: Configure phpPgAdmin

Next, edit the file /etc/phppgadmin/config.inc.php:

nano /etc/phppgadmin/config.inc.php

Now change the following option:

$conf[‘extra_login_security'] = true;

to

$conf[‘extra_login_security'] = false;

Now, we can restart Apache and phpPgAdmin so that the changes take place:

systemctl restart postgresql

systemctl restart apache2

systemctl enable postgresql

systemctl enable apache2

Step 7: Accessing phpPgAdmin.

phpPgAdmin will be available on HTTP port 80 by default. Open your favourite browser and navigate to:

http://yourdomain.com/phppgadmin

or

http://server-ip/phppgadmin.

If you are using a firewall, please open port 80 to enable access to the control panel. Congratulations! You have successfully installed PostgreSQL Server.

Conclusions

This article should help you set up PostgreSQL on Ubuntu 18.04 and Ubuntu 16.04. Both installations are straightforward, whether you choose to install from the PostgreSQL repository or the local Ubuntu repository.

For those looking to manage their databases on a remote server, you might find it useful to set up a Ubuntu VPS server or an RDP server for Ubuntu. These setups can greatly enhance your ability to work with PostgreSQL from different locations and environments.

If this article was of help, let us know in the comments below (we are always eager to hear your feedback).

People also read: