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

Ensure correct bin_dir for pg params configuration #966

Merged
merged 3 commits into from
Feb 15, 2024

Conversation

hughcapet
Copy link
Member

Make inplace upgrade code use the bin_dir of the proper version throught the whole process, so that
ConfigHandler.write_postgresql_conf() validates provided params using the proper PG version.

Make inplace upgrade code use the bin_dir of the proper version
throught the whole process, so that
ConfigHandler.write_postgresql_conf() validates provided params using
the proper PG version.
@hughcapet hughcapet force-pushed the fix/bin_dir_upgrade branch from 46f3e5e to a89ca13 Compare January 26, 2024 07:30
Patroni caches available GUCs since 3.2.1
@hughcapet hughcapet marked this pull request as ready for review January 26, 2024 13:24
@hughcapet hughcapet requested a review from FxKu February 5, 2024 13:29
@FxKu
Copy link
Member

FxKu commented Feb 6, 2024

👍

Copy link
Member

@macedigital macedigital left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

It took me a couple of passes to get an understanding of the changes, because the broader context of the full code base must be considered.

This pull-request should fix the failed upgrade from 10 -> 15 which triggered this PR, but I'm honestly not 100% certain all side-effects are caught.

@@ -50,11 +52,15 @@ def get_cluster_version(self):
with open(self._version_file) as f:
return f.read().strip()

def set_bin_dir(self, version):
def set_bin_dir_for_version(self, version):
from spilo_commons import get_bin_dir
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Curious: Is this import inside the function because of circular dependencies?

Comment on lines 58 to 63
self._bin_dir = get_bin_dir(version)
self._available_gucs = None

def set_bin_dir(self, bin_dir):
self._bin_dir = bin_dir
self._available_gucs = None
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Was it considered to call set_bin_dir from specialized function set_bin_dir_for_version ? This could reduce chances of "drift" in the future

Suggested change
self._bin_dir = get_bin_dir(version)
self._available_gucs = None
def set_bin_dir(self, bin_dir):
self._bin_dir = bin_dir
self._available_gucs = None
self.set_bin_dir(get_bin_dir(version))
def set_bin_dir(self, bin_dir):
self._bin_dir = bin_dir
self._available_gucs = None

@macedigital
Copy link
Member

👍

@macedigital
Copy link
Member

👍

1 similar comment
@hughcapet
Copy link
Member Author

👍

@hughcapet hughcapet merged commit 9091d78 into master Feb 15, 2024
4 checks passed
@hughcapet hughcapet deleted the fix/bin_dir_upgrade branch February 15, 2024 14:56
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants