How to change the default port in PostgreSQL

PostgreSQL, by default, listens on port 5432. There might be scenarios where you need to change this default port due to conflicts, security concerns, or other reasons. This guide walks you through the steps to do this efficiently and safely.

Prerequisites

Ensure you have the following:

  • Administrative or superuser access to the PostgreSQL server
  • Familiarity with command-line tools
  • Before making changes to your database system, always take a backup

Locate the configuration file

The PostgreSQL configuration file, typically named postgresql.conf, contains various settings including the port number. It's located in the PostgreSQL data directory. The location might vary based on the installation method and OS.

For standard installations on Unix-like systems, the configuration file can often be found in:

/etc/postgresql/{VERSION}/main/postgresql.conf or /var/lib/pgsql/{VERSION}/data/postgresql.conf

On Windows installations, it's usually in:

C:\Program Files\PostgreSQL\{VERSION}\data\postgresql.conf

Modify the port number

Open postgresql.conf in your preferred text editor. For instance, using nano:

nano /path/to/your/postgresql.conf

Search for the port setting, which might look like:

# port = 5432

Uncomment the line (remove the # at the start) and change 5432 to your desired port number. For example, to set the port to 5433:

port = 5433

Save and close the file.

Restart the PostgreSQL service

The change will only take effect after a service restart.

On Unix-like systems:

sudo systemctl restart postgresql

On Windows, restart using the Services application or run:

pg_ctl restart -D "C:\Program Files\PostgreSQL\{VERSION}\data"

Verify the port change

Use the netstat tool or ss command to verify PostgreSQL is now listening on the new port.

netstat -tuln | grep [new_port_number]

or

ss -tln | grep [new_port_number]

You should see your PostgreSQL instance listening on the specified port.

Update client connections

Once you’ve updated your PostgreSQL database port, you’ll have to ensure that any applications or clients connecting to the PostgreSQL server are updated to use the new port. This often involves updating connection strings or configurations in those applications. Ideally, you should compile a list of all services that connect to your database before changing the port so that you can update them all as soon as the port has changed.

If you’re using a cloud-based tool like Basedash to access your database, you’ll only need to update the connection to your database once for your whole team. This might make the migration much smoother, especially if you have multiple developers or non-technical teammates who need to access your database.

Invite only

The next generation of charts.

Coming soon.

The next generation of charts. Coming soon.

The next generation of charts. Coming soon.

Fast. Opinionated. Collaborative. Local-first. Keyboard centric. Crafted to the last pixel. We've got 50 slots for Alpha access.