Skip to content

mnahkies/ephemeral-postgres

Repository files navigation

ephemeral-postgres

A bash script that starts an ephemeral postgres locally in docker for development purposes.

Data is destroyed between runs, on Linux the data is stored on a tmpfs / ramdisk for faster startup.

The container loads a ClientAuthentication hook ensure_role_and_database_exists that automatically creates roles & databases that don't exist when connections are made.

This allows you to just start the container and not worry about pre-creating users or databases for your integration test suites, etc.

By default, it will create users with LOGIN CREATEDB and authenticate using TRUST but this can be customized with the environment variables below.

Installation

Usage

Start the postgres server:

start-ephemeral-postgres.sh

Options

  • POSTGRES_VERSION=16
  • POSTGRES_PASSWORD=postgres
  • POSTGRES_HOST_AUTH_METHOD=trust - could be scram-sha-256 / md5 / etc
  • ROLE_ATTRIBUTES='LOGIN CREATEDB' - could be SUPERUSER / CREATEROLE BYPASSRLS / etc

Connect using psql:

docker exec -it postgres psql -U postgres postgres
docker exec -it postgres psql -U any_username any_database_name

References

See https://github.com/taminomara/psql-hooks for the unofficial documentation of Postgresql hooks

These slides are also a good reference: https://wiki.postgresql.org/images/e/e3/Hooks_in_postgresql.pdf

About

Starts a postgres in docker where any credentials or database name is accepted

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published