A logo showing the text blog.marcnuri.com
Español
Home»Operations»Windows: How to run PostgreSQL without installation (portable)

Recent Posts

  • Fabric8 Kubernetes Client 7.2 is now available!
  • Connecting to an MCP Server from JavaScript using AI SDK
  • Connecting to an MCP Server from JavaScript using LangChain.js
  • The Future of Developer Tools: Adapting to Machine-Based Developers
  • Connecting to a Model Context Protocol (MCP) Server from Java using LangChain4j

Categories

  • Artificial Intelligence
  • Front-end
  • Go
  • Industry and business
  • Java
  • JavaScript
  • Legacy
  • Operations
  • Personal
  • Pet projects
  • Tools

Archives

  • May 2025
  • April 2025
  • March 2025
  • February 2025
  • January 2025
  • December 2024
  • November 2024
  • August 2024
  • June 2024
  • May 2024
  • April 2024
  • March 2024
  • February 2024
  • January 2024
  • December 2023
  • November 2023
  • October 2023
  • September 2023
  • August 2023
  • July 2023
  • June 2023
  • May 2023
  • April 2023
  • March 2023
  • February 2023
  • January 2023
  • December 2022
  • November 2022
  • October 2022
  • September 2022
  • August 2022
  • July 2022
  • June 2022
  • May 2022
  • March 2022
  • February 2022
  • January 2022
  • December 2021
  • November 2021
  • October 2021
  • September 2021
  • August 2021
  • July 2021
  • January 2021
  • December 2020
  • November 2020
  • October 2020
  • September 2020
  • August 2020
  • July 2020
  • June 2020
  • May 2020
  • February 2020
  • January 2020
  • December 2019
  • October 2019
  • September 2019
  • July 2019
  • March 2019
  • November 2018
  • July 2018
  • June 2018
  • May 2018
  • April 2018
  • March 2018
  • February 2018
  • December 2017
  • July 2017
  • January 2017
  • December 2015
  • November 2015
  • December 2014
  • March 2014
  • February 2011
  • November 2008
  • June 2008
  • May 2008
  • April 2008
  • January 2008
  • November 2007
  • September 2007
  • August 2007
  • July 2007
  • June 2007
  • May 2007
  • April 2007
  • March 2007

Windows: How to run PostgreSQL without installation (portable)

2017-01-08 in Operations tagged Windows / PostgreSQL / Database / Service by Marc Nuri | Last updated: 2024-11-11
Versión en Español

Introduction

Running a PostgreSQL database server on Windows is usually done by installing the PostgreSQL server using the official installer. However, there are many scenarios where you might want to run a PostgreSQL server without installing it in your system.

In this post, I'll show you how to run a PostgreSQL server on Windows without installation and how to manage it as a Windows service.

Downloading PostgreSQL

The first step is to download the PostgreSQL binaries. In general, PostgeSQL can be downloaded from the postgresql.org website. However, the official community website only hosts the installer for Windows. The binary-only packages are only available from the commercial EnterpriseDB website.

You can download the PostgreSQL binaries from the EnterpriseDB website.

Extracting the PostgreSQL binaries

The next step is extracting the downloaded archive into a directory of your choice. Notice that this is the directory where the PostgreSQL server will be running from.

Initializing the PostgreSQL database

Before starting the PostgreSQL server, you need to initialize the database. To do this, open a command prompt and navigate to the directory where you extracted the PostgreSQL binaries.

Run the following command to initialize the database:

cmd.exe
.\bin\initdb.exe -D data -U postgres -W -E UTF8 -A scram-sha-256

The following table describes the parameters used in the initdb command:

ParameterDescription
-D dataSpecifies the directory where the database cluster will be created. In this case .\data.
-U postgresSpecifies the user that will own the database cluster. In this case postgres.
-WPrompts for the password of the user specified with the -U parameter.
-E UTF8Specifies the encoding of the database. In this case UTF8.
-A scram-sha-256Specifies the authentication method for the database. In this case password authentication.

In this case, I've opted to create the data directory in the same directory where the PostgreSQL binaries were extracted. However, you can specify any directory you want, even in a different drive.

Starting the PostgreSQL server

To start the PostgreSQL server, run the following command:

cmd.exe
.\bin\pg_ctl.exe start -D data

The command will start the PostgreSQL server in the background and print server started when the server is ready.

Stopping the PostgreSQL server

To shut down the PostgreSQL server, run the following command:

cmd.exe
.\bin\pg_ctl.exe stop -D data

When the server stops, it will print server stopped.

Running PostgreSQL as a Windows service

Note

Administrative privileges are required to run the following commands.

You can optionally run the PostgreSQL server as a Windows service. To do this, you need to install the service by running the following command:

cmd.exe
.\bin\pg_ctl.exe register -N PostgreSQL -D data

The command will install the PostgreSQL server as a Windows service named PostgreSQL.

To remove the service, you can run the following command:

cmd.exe
.\bin\pg_ctl.exe unregister -N PostgreSQL

Note that you need to specify the same name you used when installing the service.

Additional tools

In addition to the PostgreSQL server binaries, the archive also contains the psql command-line tool and the pgAdmin graphical user interface.

The psql command-line tool can be used to interact with the PostgreSQL server from the command line. You can find it in the .\bin directory.

The pgAdmin graphical user interface can be used to manage the PostgreSQL server in a more user-friendly way. You can find it in the .\pgAdmin directory.

Twitter iconFacebook iconLinkedIn iconPinterest iconEmail icon

Post navigation
Angular + Spring Boot integration using GradleSpring Data JPA + EclipseLink: Configuring Spring-Boot to use EclipseLink as the JPA provider
© 2007 - 2025 Marc Nuri