Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[RFE] Reloadable PostgreSQL #65296

Open
danbst opened this issue Jul 23, 2019 · 3 comments
Open

[RFE] Reloadable PostgreSQL #65296

danbst opened this issue Jul 23, 2019 · 3 comments
Labels
0.kind: enhancement Add something new 2.status: stale https://github.com/NixOS/nixpkgs/blob/master/.github/STALE-BOT.md 6.topic: nixos Issues or PRs affecting NixOS modules, or package usability issues specific to NixOS 6.topic: user experience 9.needs: module (update) This needs a module to be changed

Comments

@danbst
Copy link
Contributor

danbst commented Jul 23, 2019

Meta-issue for making PG truly reloadable. The reason for this is because not everybody implements correct handling of PG reboots

General thoughts

  • reloadIfChanged NixOS systemd option doesn't work well here. Yes, it sends SIGHUP, but no, nothing actually changes on filesystem (due to immutability)
  • if I set reloadable = true; for PG, I still want to be notified about when restart is required. Maybe warn during activation, maybe something automatible (allow send webhooks, notification, etc)
  • to make things easier, original postgres service shouldn't change during reloads (change in Nix sense). Only when PG itself has version bump (channel advanced). The "reloader" should be a separate service, which actually can be restartable, and which manages the state for postgres service.

Configuration

Some configuration option require restart, but most often they don't. The only reliable way to distiguish them is to parse sample PG config and extract params with (change requires restart). We can't just SIGHUP PG and parse it's reload output - it does reload but still barfs about "restart required".

Then split extraConfig into "reloadable" and "restart-required" configs, and disallow "restart-only" options in "reloadable" subconfig. Kinda complicated...

And yes, "reloadable" config should be implemented using environment.etc or any other kind of managed state. Alternatively, drop immutability for PG config and move it back to PG datadir.

Same for pg_hba.conf. It's change doesn't require restart.

Plugins

In #61480 @jamessewell notes, that some plugins can be added without restart. This requires some managed state for plugins, which can be implemented using environment.etc.

Plugins which must set shared_preload_libraries should trigger restart as per configuration change.

SQL scripts

Currently adding SQL scripts in postStart makes PG restarts. This includes ensureDatabases option. It really shouldn't.

@danbst danbst added the 0.kind: bug Something is broken label Jul 23, 2019
@danbst danbst added 0.kind: enhancement Add something new 6.topic: nixos Issues or PRs affecting NixOS modules, or package usability issues specific to NixOS 6.topic: user experience 9.needs: module (update) This needs a module to be changed and removed 0.kind: bug Something is broken labels Jul 23, 2019
@domenkozar
Copy link
Member

Another mid-term remedy would be to use socket activation, so if postgresql does restart, at least there's only delay instead of connection issues.

@flokli
Copy link
Contributor

flokli commented May 23, 2020

Related: #49528 (comment)

@stale
Copy link

stale bot commented Nov 20, 2020

I marked this as stale due to inactivity. → More info

@stale stale bot added the 2.status: stale https://github.com/NixOS/nixpkgs/blob/master/.github/STALE-BOT.md label Nov 20, 2020
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
0.kind: enhancement Add something new 2.status: stale https://github.com/NixOS/nixpkgs/blob/master/.github/STALE-BOT.md 6.topic: nixos Issues or PRs affecting NixOS modules, or package usability issues specific to NixOS 6.topic: user experience 9.needs: module (update) This needs a module to be changed
Projects
None yet
Development

No branches or pull requests

3 participants