From afd6f80d90e8bec979a295524e3b10b368be0f63 Mon Sep 17 00:00:00 2001 From: Nathan Scott Date: Wed, 21 Aug 2024 15:48:51 +1000 Subject: [PATCH] fix: add support for Valkey, sync tests with ansible-pcp --- .ansible-lint | 2 +- .ostree/packages-runtime-CentOS-10.txt | 3 +-- .ostree/packages-runtime-RedHat-10.txt | 3 +-- .ostree/packages-testing-CentOS-10.txt | 3 +-- .ostree/packages-testing-Fedora.txt | 4 +--- .ostree/packages-testing-RedHat-10.txt | 3 +-- CHANGELOG.md | 8 +++---- README.md | 30 +++++++++++++++----------- defaults/main.yml | 6 +++--- meta/main.yml | 1 + tasks/firewall.yml | 13 +++++++++-- tasks/main.yml | 4 +--- tests/check_default_datasources.yml | 22 +++++++++++++++++++ tests/check_firewall_selinux.yml | 15 +++++++++++++ tests/check_keyserver.yml | 20 +++++++++++++++++ tests/check_redis.yml | 7 ------ tests/restore_services_state.yml | 1 + tests/tests_verify_fullstack.yml | 4 ++-- tests/tests_verify_query.yml | 2 +- 19 files changed, 104 insertions(+), 47 deletions(-) create mode 100644 tests/check_keyserver.yml delete mode 100644 tests/check_redis.yml diff --git a/.ansible-lint b/.ansible-lint index 3fb9eba0..c220f9d7 100644 --- a/.ansible-lint +++ b/.ansible-lint @@ -29,7 +29,7 @@ mock_roles: - performancecopilot.metrics.mssql - performancecopilot.metrics.pcp - performancecopilot.metrics.postfix - - performancecopilot.metrics.redis + - performancecopilot.metrics.keyserver - performancecopilot.metrics.repository - performancecopilot.metrics.spark supported_ansible_also: diff --git a/.ostree/packages-runtime-CentOS-10.txt b/.ostree/packages-runtime-CentOS-10.txt index e87908b7..295a742f 100644 --- a/.ostree/packages-runtime-CentOS-10.txt +++ b/.ostree/packages-runtime-CentOS-10.txt @@ -5,5 +5,4 @@ pcp-export-pcp2elasticsearch pcp-pmda-bpftrace pcp-pmda-mssql pcp-system-tools -redis -redis-doc +valkey diff --git a/.ostree/packages-runtime-RedHat-10.txt b/.ostree/packages-runtime-RedHat-10.txt index e87908b7..295a742f 100644 --- a/.ostree/packages-runtime-RedHat-10.txt +++ b/.ostree/packages-runtime-RedHat-10.txt @@ -5,5 +5,4 @@ pcp-export-pcp2elasticsearch pcp-pmda-bpftrace pcp-pmda-mssql pcp-system-tools -redis -redis-doc +valkey diff --git a/.ostree/packages-testing-CentOS-10.txt b/.ostree/packages-testing-CentOS-10.txt index f6da445f..cacb9e19 100644 --- a/.ostree/packages-testing-CentOS-10.txt +++ b/.ostree/packages-testing-CentOS-10.txt @@ -12,5 +12,4 @@ pcp-zeroconf postfix postfix-perl-scripts python3-pyodbc -redis -redis-doc +valkey diff --git a/.ostree/packages-testing-Fedora.txt b/.ostree/packages-testing-Fedora.txt index 716532aa..cacb9e19 100644 --- a/.ostree/packages-testing-Fedora.txt +++ b/.ostree/packages-testing-Fedora.txt @@ -12,6 +12,4 @@ pcp-zeroconf postfix postfix-perl-scripts python3-pyodbc -redis -redis-doc -RediSearch +valkey diff --git a/.ostree/packages-testing-RedHat-10.txt b/.ostree/packages-testing-RedHat-10.txt index f6da445f..cacb9e19 100644 --- a/.ostree/packages-testing-RedHat-10.txt +++ b/.ostree/packages-testing-RedHat-10.txt @@ -12,5 +12,4 @@ pcp-zeroconf postfix postfix-perl-scripts python3-pyodbc -redis -redis-doc +valkey diff --git a/CHANGELOG.md b/CHANGELOG.md index c16a2eda..ff1660e3 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -192,13 +192,13 @@ Changelog - Use the firewall role and the selinux role from the metrics role - Introduce metrics_manage_firewall to use the firewall role to - manage the pmcd port, the pmproxy ports, the grafana port and - the redis port depending upon the configuration parameters. + manage the pmcd, pmproxy, grafana and valkey or redis ports, + depending on the configuration parameters. metrics_manage_firewall is set to false, by default. - Introduce metrics_manage_selinux to use the selinux role to - manage the pmcd port, the pmproxy ports, the grafana port and - the redis port depending upon the configuration parameters. + manage the pmcd, pmproxy, grafana and valkey or redis ports, + depending on the configuration parameters. metrics_manage_selinux is set to false, by default. - Add the test check task check_firewall_selinux.yml for verify diff --git a/README.md b/README.md index a90091b5..ee696a91 100644 --- a/README.md +++ b/README.md @@ -14,7 +14,8 @@ from the standard repositories on Fedora, CentOS 8, and RHEL 8. On RHEL on the managed host. The role can optionally use Grafana v6+ (`metrics_graph_service`) and -Redis v5+ (`metrics_query_service`) on Fedora, CentOS 8, RHEL 8 and later. +Valkey (`metrics_query_service`) on Fedora, CentOS 10, RHEL 10 and later, +or Redis v5+ (`metrics_query_service`) on CentOS 8 or 9, RHEL 8 or 9. ### Collection requirements @@ -70,9 +71,11 @@ RHEL 8, or later versions of these platforms. ### metrics_query_service: false Boolean flag allowing host to be setup with time series query services. -Enabling this starts PCP and Redis servers for querying recorded PCP metrics. -This option requires Redis v5+ which is available on Fedora, CentOS 8, -RHEL 8, or later versions of these platforms. +Enabling this starts PCP and Valkey or Redis servers for querying any +recorded PCP metrics. +This option requires either Valkey or Redis v5+ which is available on +Fedora, CentOS 8, RHEL 8, or later versions of these platforms (Valkey +is the prefered solution on Fedora, Centos 10, RHEL 10 and later). ### metrics_into_elasticsearch: false @@ -115,14 +118,14 @@ The metrics collector to use to provide metrics. Currently Performance Co-Pilot is the only supported metrics provider. When using the PCP provider these TCP ports will be used - 44321 (pmcd, live metric value sampling), 44322 (pmproxy, with metrics_query_service -or metrics_graph_service), 6379 (redis-server for metrics_query_service) -and 3000 (grafana-server for metrics_graph_service). +or metrics_graph_service), 6379 (either valkey-server or redis-server for +metrics_query_service) and 3000 (grafana-server for metrics_graph_service). ### metrics_manage_firewall: false Boolean flag allowing to configure firewall using the firewall role. -Manage the pmcd port, the pmproxy port, the Grafana port and the Redis -port depending upon the configuration parameters. +Manage the pmcd port, the pmproxy port, the Grafana port and either the +Valkey or Redis port depending upon the configuration parameters. If the variable is set to false, the `metrics role` does not manage the firewall. @@ -136,16 +139,17 @@ NOTE: the firewall management is not supported on RHEL 6. ### metrics_manage_selinux: false Boolean flag allowing to configure selinux using the selinux role. -Assign the pmcd port, the pmproxy port, the Grafana port and the Redis -port depending upon the configuration parameters. +Assign the pmcd port, the pmproxy port, the Grafana port and either the +Valkey or Redis port depending upon the configuration parameters. If the variable is set to false, the `metrics role` does not manage the selinux. Please note that the pmcd and pmproxy services are in the "ephemeral" range requiring no special setup and the Grafana port is "unregistered". -The Redis port is gated by the redis_port_t SELinux type and may need to -be further configured, if you require direct access (not required if you -are accessing it from metrics role tools like Grafana and PCP). +The Valkey or Redis ports are gated by the valkey_port_t or redis_port_t +SELinux types respectively, and may need to be further configured if you +require direct access (not required if you are accessing it from metrics +role tools like Grafana and PCP). Use the `selinux` system role to manage port access, for SELinux contexts. NOTE: `metrics_manage_selinux` is limited to *adding* policy. diff --git a/defaults/main.yml b/defaults/main.yml index 573f475d..8427d7ba 100644 --- a/defaults/main.yml +++ b/defaults/main.yml @@ -9,7 +9,7 @@ metrics_retention_days: 7 # analysis) and automated rule inference (for alerting). metrics_monitored_hosts: [] -# Provide a scalable query language (using Redis) and the +# Provide a scalable query language (using Valkey) and the # PMWEBAPI(3) REST API for metrics at localhost:44322 # OpenMetrics endpoint at localhost:44322/metrics metrics_query_service: false @@ -39,8 +39,8 @@ metrics_password: metrics metrics_provider: pcp # If true, manage the pmcd port, pmproxy ports, grafana service and -# redis service using the firewall role depending upon the configuration -# parameters. +# valkey or redis service using the firewall role depending upon the +# configuration parameters. metrics_manage_firewall: false # If true, manage the pmcd port, pmproxy ports using the selinux role diff --git a/meta/main.yml b/meta/main.yml index 8c962f88..a324c0de 100644 --- a/meta/main.yml +++ b/meta/main.yml @@ -35,5 +35,6 @@ galaxy_info: - redis - telemetry - timeseries + - valkey - visualization dependencies: [] diff --git a/tasks/firewall.yml b/tasks/firewall.yml index 40cf535a..3f9ede6f 100644 --- a/tasks/firewall.yml +++ b/tasks/firewall.yml @@ -21,7 +21,7 @@ __metrics_firewall: "{{ __metrics_firewall | union([{'port': '44322/tcp', 'state': 'enabled'}]) }}" when: - - metrics_graph_service|bool or metrics_query_service|bool + - metrics_graph_service | bool or metrics_query_service | bool - name: Service for grafana set_fact: @@ -30,12 +30,21 @@ when: - metrics_graph_service|bool + - name: Service for valkey + set_fact: + __metrics_firewall: "{{ __metrics_firewall | + union([{'service': 'valkey', 'state': 'enabled'}]) }}" + when: + - metrics_query_service | bool + - ansible_facts['distribution_version'] is version('10', '>=') + - name: Service for redis set_fact: __metrics_firewall: "{{ __metrics_firewall | union([{'service': 'redis', 'state': 'enabled'}]) }}" when: - - metrics_query_service|bool + - metrics_query_service | bool + - ansible_facts['distribution_version'] is version('10', '<') - name: Ensure the service and the port status with the firewall role include_role: diff --git a/tasks/main.yml b/tasks/main.yml index edd0e4ec..d8609e59 100644 --- a/tasks/main.yml +++ b/tasks/main.yml @@ -75,11 +75,9 @@ when: metrics_from_bpftrace | d(false) | bool - name: Setup metric querying service. - vars: - redis_metrics_provider: "{{ metrics_provider }}" include_role: # noqa role-name[path] - name: "{{ role_path }}/roles/redis" + name: "{{ role_path }}/roles/keyserver" when: metrics_query_service | bool - name: Setup metric collection service. diff --git a/tests/check_default_datasources.yml b/tests/check_default_datasources.yml index ac8ba585..2d78eefc 100644 --- a/tests/check_default_datasources.yml +++ b/tests/check_default_datasources.yml @@ -14,4 +14,26 @@ - Redis - Vector - bpftrace + when: + - ansible_distribution in ['RedHat', 'CentOS'] + - ansible_distribution_major_version | int > 6 + - ansible_distribution_major_version | int < 10 + +- name: Check if grafana-pcp datasources are configured + uri: + url: "http://admin:admin@localhost:3000/api/datasources/name/PCP%20{{ item }}" + force_basic_auth: true + headers: + Content-Type: application/json + Accept: application/json + method: GET + status_code: 200 + loop: + - Valkey + - Vector + - bpftrace + when: (ansible_distribution in ['RedHat', 'CentOS'] and + ansible_distribution_major_version | int >= 10) or + ansible_distribution not in ['RedHat', 'CentOS'] + # yamllint enable rule:line-length diff --git a/tests/check_firewall_selinux.yml b/tests/check_firewall_selinux.yml index bcef14ec..9b2d9522 100644 --- a/tests/check_firewall_selinux.yml +++ b/tests/check_firewall_selinux.yml @@ -18,6 +18,18 @@ when: - metrics_graph_service|d(false)|bool + - name: "Check firewall service status for valkey; + metrics_manage_firewall is true" + command: firewall-cmd --list-services + register: _result + failed_when: "'valkey' not in _result.stdout" + changed_when: false + when: + - metrics_query_service | d(false) | bool + - ansible_distribution not in ['RedHat', 'CentOS'] or + (ansible_distribution in ['RedHat', 'CentOS'] and + ansible_distribution_major_version | int >= 10) + - name: "Check firewall service status for redis; metrics_manage_firewall is true" command: firewall-cmd --list-services @@ -26,6 +38,9 @@ changed_when: false when: - metrics_query_service|d(false)|bool + - ansible_distribution in ['RedHat', 'CentOS'] + - ansible_distribution_major_version | int > 6 + - ansible_distribution_major_version | int < 10 - name: "Check firewall port status for pmproxy; metrics_manage_firewall is true" diff --git a/tests/check_keyserver.yml b/tests/check_keyserver.yml new file mode 100644 index 00000000..5783dcc8 --- /dev/null +++ b/tests/check_keyserver.yml @@ -0,0 +1,20 @@ +# SPDX-License-Identifier: MIT +--- +- name: Check if Valkey responds + shell: | + set -euo pipefail + valkey-cli PING | grep PONG + changed_when: false + when: (ansible_distribution in ['RedHat', 'CentOS'] and + ansible_distribution_major_version | int >= 10) or + ansible_distribution not in ['RedHat', 'CentOS'] + +- name: Check if Redis responds + shell: | + set -euo pipefail + redis-cli PING | grep PONG + changed_when: false + when: + - ansible_distribution in ['RedHat', 'CentOS'] + - ansible_distribution_major_version | int > 6 + - ansible_distribution_major_version | int < 10 diff --git a/tests/check_redis.yml b/tests/check_redis.yml deleted file mode 100644 index 216a7cc4..00000000 --- a/tests/check_redis.yml +++ /dev/null @@ -1,7 +0,0 @@ -# SPDX-License-Identifier: MIT ---- -- name: Check if Redis responds - shell: | - set -euo pipefail - redis-cli PING | grep PONG - changed_when: false diff --git a/tests/restore_services_state.yml b/tests/restore_services_state.yml index 228a988a..73c5e787 100644 --- a/tests/restore_services_state.yml +++ b/tests/restore_services_state.yml @@ -23,6 +23,7 @@ - pmie - pmproxy - redis + - valkey - grafana-server # yamllint enable rule:line-length diff --git a/tests/tests_verify_fullstack.yml b/tests/tests_verify_fullstack.yml index 009ef418..6fffb7fb 100644 --- a/tests/tests_verify_fullstack.yml +++ b/tests/tests_verify_fullstack.yml @@ -1,6 +1,6 @@ # SPDX-License-Identifier: MIT --- -- name: Test the full PCP/Redis/Grafana stack +- name: Test the full PCP and Grafana stack hosts: all vars: metrics_query_service: true @@ -32,7 +32,7 @@ - check_pcp.yml - check_pmlogger.yml - check_pmie.yml - - check_redis.yml + - check_keyserver.yml - check_pmproxy.yml - check_grafana.yml - check_grafanapcp.yml diff --git a/tests/tests_verify_query.yml b/tests/tests_verify_query.yml index 37847e5d..aba70146 100644 --- a/tests/tests_verify_query.yml +++ b/tests/tests_verify_query.yml @@ -29,7 +29,7 @@ - check_pcp.yml - check_pmlogger.yml - check_pmie.yml - - check_redis.yml + - check_keyserver.yml - check_pmproxy.yml - check_firewall_selinux.yml