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

Use the the original PostgreSQL configuration file #41

Open
wants to merge 11 commits into
base: master
Choose a base branch
from
17 changes: 16 additions & 1 deletion defaults/main.yml
Original file line number Diff line number Diff line change
Expand Up @@ -31,6 +31,7 @@
# Recursively reset the owner/group of the postgres datadir?
postgresql_server_chown_datadir: false

postgres_config_file_contents: ''
######################################################################
# Internal role variables, do not modify
######################################################################
Expand All @@ -52,13 +53,27 @@
(postgresql_package_version | length > 0) |
ternary('-' + postgresql_package_version, '')
}}
conf_sample_file: "/usr/pgsql-{{ postgresql_version }}/share/postgresql.conf.sample"

Check failure on line 56 in defaults/main.yml

View workflow job for this annotation

GitHub Actions / Test (rockylinux9)

56:81 [line-length] line too long (86 > 80 characters)

Check failure on line 56 in defaults/main.yml

View workflow job for this annotation

GitHub Actions / Test (ubuntu2204)

56:81 [line-length] line too long (86 > 80 characters)

# Attributes are parsed and used to set facts at tasks/debian.yml.
# Debian variation, following the same principles of postgresql_dist_redhat
postgresql_dist_debian:
bindir: /usr/lib/postgresql/{{ postgresql_version }}/bin
confdir: /etc/postgresql/{{ postgresql_version }}/main
conf_postgresql_src: postgresql-conf-10-ubuntu.j2
conf_postgresql_src: postgresql-conf.j2
datadir: /var/lib/postgresql/{{ postgresql_version }}/main
basename: postgresql-{{ postgresql_version }}
conf_sample_file: "/usr/share/postgresql/{{ postgresql_version }}/postgresql.conf.sample"

Check failure on line 66 in defaults/main.yml

View workflow job for this annotation

GitHub Actions / Test (rockylinux9)

66:81 [line-length] line too long (91 > 80 characters)

Check failure on line 66 in defaults/main.yml

View workflow job for this annotation

GitHub Actions / Test (ubuntu2204)

66:81 [line-length] line too long (91 > 80 characters)
service: postgresql

# conf_sample_file: sample configuration file, it should be copied during the installation by the installation package

Check failure on line 69 in defaults/main.yml

View workflow job for this annotation

GitHub Actions / Test (rockylinux9)

69:81 [line-length] line too long (118 > 80 characters)

Check failure on line 69 in defaults/main.yml

View workflow job for this annotation

GitHub Actions / Test (ubuntu2204)

69:81 [line-length] line too long (118 > 80 characters)
sbesson marked this conversation as resolved.
Show resolved Hide resolved

# the following two variables are used to download link ofr the source to get the sample configuration file

Check failure on line 71 in defaults/main.yml

View workflow job for this annotation

GitHub Actions / Test (rockylinux9)

71:81 [line-length] line too long (107 > 80 characters)

Check failure on line 71 in defaults/main.yml

View workflow job for this annotation

GitHub Actions / Test (ubuntu2204)

71:81 [line-length] line too long (107 > 80 characters)
# It will be used in case of the sample file is not find locally for any reason
Copy link
Member

Choose a reason for hiding this comment

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

Any reason not to have a hard fail in case conf_sample_file does not exist?

Are you aware of any scenario where this file could legitimately be expected to be missing?

Copy link
Contributor Author

@khaledk2 khaledk2 Jun 11, 2024

Choose a reason for hiding this comment

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

On our RHEL 9 test machine, there are 4 PostgreSQL versions have been installed (13, 14, 15, 16). Only version 16 folder has the sample file and the others do not have this file. I am not sure how these versions have been installed but I think the file should be there. I am not sure why it is missing. So, I have added the logic of downloading and extracting the file to account for similar cases.

Copy link
Member

Choose a reason for hiding this comment

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

Interesting (and slightly concerning). Note all of the PSQL sample configuration file checks seem to be currently skipped in the Molecule tests on both Rocky Linux. I don't know if that's expected or indicates another issue.

Copy link
Contributor Author

Choose a reason for hiding this comment

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

It will check for the sample file if the original file does not exist and the configuration file has been edited before, i.e. in case of installing the same PostgreSQL version with a previous role version.

versions_source_download:
13: "13.15"
14: "14.12"
15: "15.7"
16: "16.3"

source_download_linnk: "https://ftp.postgresql.org/pub/source/v{{ versions_source_download [postgresql_version] }}/postgresql-{{ versions_source_download [postgresql_version] }}.tar.gz"

Check failure on line 79 in defaults/main.yml

View workflow job for this annotation

GitHub Actions / Test (rockylinux9)

79:81 [line-length] line too long (185 > 80 characters)

Check warning on line 79 in defaults/main.yml

View workflow job for this annotation

GitHub Actions / Test (rockylinux9)

jinja[spacing]

Jinja2 spacing could be improved: https://ftp.postgresql.org/pub/source/v{{ versions_source_download \[postgresql_version] }}/postgresql-{{ versions_source_download \[postgresql_version] }}.tar.gz -> https://ftp.postgresql.org/pub/source/v{{ versions_source_download\[postgresql_version] }}/postgresql-{{ versions_source_download\[postgresql_version] }}.tar.gz

Check failure on line 79 in defaults/main.yml

View workflow job for this annotation

GitHub Actions / Test (rockylinux9)

yaml[line-length]

Line too long (185 > 160 characters)

Check failure on line 79 in defaults/main.yml

View workflow job for this annotation

GitHub Actions / Test (ubuntu2204)

79:81 [line-length] line too long (185 > 80 characters)

Check warning on line 79 in defaults/main.yml

View workflow job for this annotation

GitHub Actions / Test (ubuntu2204)

jinja[spacing]

Jinja2 spacing could be improved: https://ftp.postgresql.org/pub/source/v{{ versions_source_download \[postgresql_version] }}/postgresql-{{ versions_source_download \[postgresql_version] }}.tar.gz -> https://ftp.postgresql.org/pub/source/v{{ versions_source_download\[postgresql_version] }}/postgresql-{{ versions_source_download\[postgresql_version] }}.tar.gz

Check failure on line 79 in defaults/main.yml

View workflow job for this annotation

GitHub Actions / Test (ubuntu2204)

yaml[line-length]

Line too long (185 > 160 characters)
13 changes: 11 additions & 2 deletions molecule/resources/tests/test_default.py
Original file line number Diff line number Diff line change
Expand Up @@ -48,14 +48,23 @@ def test_server_listen(host):
assert listen_addresses == "listen_addresses = localhost"


def test_backup_config_exist(host):
version = get_version(host)
if host.system_info.distribution == 'rocky':
config_backup = '/var/lib/pgsql/{version}/data/postgresql.conf.org'
else:
config_backup = '/etc/postgresql/{version}/main/postgresql.conf.org'
with host.sudo():
backup_file = config_backup.format(version=version)
assert host.file(backup_file).is_file


def test_psql_version(host):
ver = get_version(host)
out = host.check_output('psql --version')
assert out.startswith('psql (PostgreSQL) {}.'.format(ver))


# Create

def createdb(host, db, should_pass, password, name):
try:
host.check_output(
Expand Down
4 changes: 2 additions & 2 deletions molecule/resources/tests/test_extra_options.py
Original file line number Diff line number Diff line change
Expand Up @@ -23,9 +23,9 @@ def test_server_log_file_name(host):
# Check previous day too in case this is run at midnight
version = get_version(host)
if host.system_info.distribution == 'rocky':
logdir = '/var/lib/pgsql/{version}/data/pg_log'
logdir = '/var/lib/pgsql/{version}/data/log'
else:
logdir = '/var/lib/postgresql/{version}/main/pg_log'
logdir = '/var/lib/postgresql/{version}/main/log'
date1 = datetime.today()
date0 = date1 - timedelta(days=1)
logdir = logdir.format(version=version)
Expand Down
52 changes: 46 additions & 6 deletions tasks/initialise.yml
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
---
# tasks file for ome.postgresql
##Ansible managed

Check warning on line 3 in tasks/initialise.yml

View workflow job for this annotation

GitHub Actions / Test (rockylinux9)

3:3 [comments] missing starting space in comment

Check warning on line 3 in tasks/initialise.yml

View workflow job for this annotation

GitHub Actions / Test (ubuntu2204)

3:3 [comments] missing starting space in comment
sbesson marked this conversation as resolved.
Show resolved Hide resolved

- block:
- name: postgres | set permissions on data directory
Expand All @@ -22,27 +23,66 @@
PGSETUP_INITDB_OPTIONS: >-
--encoding=UTF8 --locale=en_US.UTF-8 --auth-host=md5

- name: postgres | postgresql config file
template:
- name: postgres | check for presence of "#Ansible Managed" in file
ansible.builtin.lineinfile:
path: "{{ postgresql_dist_confdir }}/postgresql.conf"
line: "#Ansible managed"
Copy link
Member

Choose a reason for hiding this comment

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

Assuming the new logic is to always recreate a configuration file from the combination of the original PSQL configuration file and the role variables (in the same spirit as the previous template task), my impression is this check is redundant and the config_file_changed logic should be removed?

Copy link
Contributor Author

Choose a reason for hiding this comment

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

The modified file check should work for the fresh installation, as the original configure file will be copied from the configuration file.

Copy link
Member

Choose a reason for hiding this comment

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

The previous RedHat/Rocky template had # {{ ansible_managed }} so this will mark this file as not changed. Is that the expectation?

Copy link
Contributor Author

Choose a reason for hiding this comment

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

I have changed the template to include #{{ ansible_managed }}.

It will check for it, i.e. looking for "#Ansible managed" in the file; if it is not found it will mark it as an alerted configuration file and start looking for the org file (postgresql.conf.org) that may exist in the current folder, if not it will invoke the tasks inside org_config_file.yml to determine the sample file.
If the configuration file does not have the "#Ansible managed" it will assume the file is the original configuration file then copy it to postgresql.conf.org and use its contents in the configuration template.

The configuration file does not have "#Ansible managed" on test122b; it will assume it is the original configuration file and copy it to org.
I think because you are in check mode, the file is not copied so it failed when trying to get the file contents.

Copy link
Member

Choose a reason for hiding this comment

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

Taking the example of test122b here

[sbesson@test122b-database ~]$  sudo tail -n 20 /var/lib/pgsql/16/data/postgresql.conf


#------------------------------------------------------------------------------
# CUSTOMIZED OPTIONS
#------------------------------------------------------------------------------

# Add settings for extensions here

listen_addresses = '*'

shared_buffers = 8002MB


listen_addresses = '*'

effective_cache_size = 23880MB

shared_buffers = 7960MB

[sbesson@test122b-database ~]$ sudo head -n 2 /var/lib/pgsql/16/data/postgresql.conf
#Modified by ome postgresql ansible role
# -----------------------------

It does not have the #Ansible managed marker but it is also not the original configuration.
In that case, copying it as postgresql.conf.org is incorrect and also means that every invocation of the role will append the options at the bottom of the configuration file.

state: absent
check_mode: yes

Check warning on line 31 in tasks/initialise.yml

View workflow job for this annotation

GitHub Actions / Test (rockylinux9)

31:19 [truthy] truthy value should be one of [false, true]

Check warning on line 31 in tasks/initialise.yml

View workflow job for this annotation

GitHub Actions / Test (ubuntu2204)

31:19 [truthy] truthy value should be one of [false, true]
changed_when: false
register: config_file_changed
sbesson marked this conversation as resolved.
Show resolved Hide resolved

- name: postgres | check that the postgresql.conf.org file exists
ansible.builtin.stat:
path: "{{ postgresql_dist_confdir }}/postgresql.conf.org"
register: org_file

- name: postgres | copy a postgresql.conf to postgresql.conf.org
become_user: "{{ postgresql_become_user }}"
ansible.builtin.copy:
src: "{{ postgresql_dist_confdir }}/postgresql.conf"
dest: "{{ postgresql_dist_confdir }}/postgresql.conf.org"
remote_src: yes

Check warning on line 45 in tasks/initialise.yml

View workflow job for this annotation

GitHub Actions / Test (rockylinux9)

45:21 [truthy] truthy value should be one of [false, true]

Check warning on line 45 in tasks/initialise.yml

View workflow job for this annotation

GitHub Actions / Test (ubuntu2204)

45:21 [truthy] truthy value should be one of [false, true]
when:
- not config_file_changed.found
- not org_file.stat.exists

- name: postgres | get the orginal configuration file
become_user: "{{ postgresql_become_user }}"
import_tasks: org_config_file.yml
when:
- not org_file.stat.exists
- config_file_changed.found

# read the default postgresql configuration file
- name: postgres | get the postgres conf file contents
become_user: "{{ postgresql_become_user }}"
ansible.builtin.slurp:
src: "{{ postgresql_dist_confdir }}/postgresql.conf.org"
register: postgres_config_file_contents_o

- set_fact: postgres_config_file_contents={{ postgres_config_file_contents_o }}

Check failure on line 64 in tasks/initialise.yml

View workflow job for this annotation

GitHub Actions / Test (rockylinux9)

64:81 [line-length] line too long (83 > 80 characters)

Check failure on line 64 in tasks/initialise.yml

View workflow job for this annotation

GitHub Actions / Test (ubuntu2204)

64:81 [line-length] line too long (83 > 80 characters)

- name: postgres | copy postgresql config file
become_user: "{{ postgresql_become_user }}"
ansible.builtin.template:
dest: >-
{{ postgresql_dist_confdir }}/postgresql.conf
src: "{{ postgresql_dist_conf_postgresql_src }}"
mode: 0644
owner: "{{ postgresql_become_user }}"
notify:
- restart postgresql

become_user: "{{ postgresql_become_user }}"
sbesson marked this conversation as resolved.
Show resolved Hide resolved

- name: postgres | configure client authorisation
become_user: "{{ postgresql_become_user }}"
template:
dest: "{{ postgresql_dist_confdir }}/pg_hba.conf"
src: pg_hba-conf.j2
mode: 0640
notify:
- restart postgresql

become_user: "{{ postgresql_become_user }}"

- name: postgres | start service
service:
enabled: true
Expand Down
45 changes: 45 additions & 0 deletions tasks/org_config_file.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,45 @@
---
# get the original configuration file

- name: postgres | Check that the postgresql.conf.sample file exists (ubuntu)
ansible.builtin.stat:
path: "{{ postgresql_dist_debian.conf_sample_file }}"
register: conf_sample_file
when: ansible_os_family | lower == 'debian'

- name: postgres | Check that the postgresql.conf.sample file exists (redhat)
ansible.builtin.stat:
path: "{{ postgresql_dist_redhat.conf_sample_file }}"
register: conf_sample_file
when: ansible_os_family | lower == 'redhat'

- name: postgres | copy the sample file to org
become_user: "{{ postgresql_become_user }}"
ansible.builtin.copy:
src: "{{ postgresql_dist_redhat.conf_sample_file }}"
dest: "{{ postgresql_dist_confdir }}/postgresql.conf.org"
when:
- conf_sample_file.stat.exists

Check failure on line 22 in tasks/org_config_file.yml

View workflow job for this annotation

GitHub Actions / Test (rockylinux9)

22:7 [hyphens] too many spaces after hyphen

Check failure on line 22 in tasks/org_config_file.yml

View workflow job for this annotation

GitHub Actions / Test (ubuntu2204)

22:7 [hyphens] too many spaces after hyphen

- name: postgres | download the source code
ansible.builtin.get_url:
url: "{{ source_download_linnk }}"
dest: /tmp/postgresql.tar.gz
when:
- not conf_sample_file.stat.exists

- name: postgres | extract the files
ansible.builtin.unarchive:
src: /tmp/postgresql.tar.gz
dest: /tmp
remote_src: yes

Check warning on line 35 in tasks/org_config_file.yml

View workflow job for this annotation

GitHub Actions / Test (rockylinux9)

35:17 [truthy] truthy value should be one of [false, true]

Check warning on line 35 in tasks/org_config_file.yml

View workflow job for this annotation

GitHub Actions / Test (ubuntu2204)

35:17 [truthy] truthy value should be one of [false, true]
when:
- not conf_sample_file.stat.exists

- name: postgres | copy the file to org file
become_user: "{{ postgresql_become_user }}"
ansible.builtin.copy:
src: "/tmp/postgresql-{{ versions_source_download [postgresql_version] }}/src/backend/utils/misc/postgresql.conf.sample"

Check failure on line 42 in tasks/org_config_file.yml

View workflow job for this annotation

GitHub Actions / Test (rockylinux9)

42:81 [line-length] line too long (124 > 80 characters)

Check warning on line 42 in tasks/org_config_file.yml

View workflow job for this annotation

GitHub Actions / Test (rockylinux9)

jinja[spacing]

Jinja2 spacing could be improved: /tmp/postgresql-{{ versions_source_download \[postgresql_version] }}/src/backend/utils/misc/postgresql.conf.sample -> /tmp/postgresql-{{ versions_source_download\[postgresql_version] }}/src/backend/utils/misc/postgresql.conf.sample

Check failure on line 42 in tasks/org_config_file.yml

View workflow job for this annotation

GitHub Actions / Test (ubuntu2204)

42:81 [line-length] line too long (124 > 80 characters)

Check warning on line 42 in tasks/org_config_file.yml

View workflow job for this annotation

GitHub Actions / Test (ubuntu2204)

jinja[spacing]

Jinja2 spacing could be improved: /tmp/postgresql-{{ versions_source_download \[postgresql_version] }}/src/backend/utils/misc/postgresql.conf.sample -> /tmp/postgresql-{{ versions_source_download\[postgresql_version] }}/src/backend/utils/misc/postgresql.conf.sample
dest: "{{ postgresql_dist_confdir }}/postgresql.conf.org"
when:
- not conf_sample_file.stat.exists
Loading
Loading