From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: <pve-devel-bounces@lists.proxmox.com> Received: from firstgate.proxmox.com (firstgate.proxmox.com [212.224.123.68]) by lore.proxmox.com (Postfix) with ESMTPS id 00B4C1FF164 for <inbox@lore.proxmox.com>; Fri, 20 Jun 2025 16:33:59 +0200 (CEST) Received: from firstgate.proxmox.com (localhost [127.0.0.1]) by firstgate.proxmox.com (Proxmox) with ESMTP id F2D8BE32A; Fri, 20 Jun 2025 16:32:36 +0200 (CEST) From: Daniel Kral <d.kral@proxmox.com> To: pve-devel@lists.proxmox.com Date: Fri, 20 Jun 2025 16:31:20 +0200 Message-Id: <20250620143148.218469-13-d.kral@proxmox.com> X-Mailer: git-send-email 2.39.5 In-Reply-To: <20250620143148.218469-1-d.kral@proxmox.com> References: <20250620143148.218469-1-d.kral@proxmox.com> MIME-Version: 1.0 X-SPAM-LEVEL: Spam detection results: 0 AWL 0.011 Adjusted score from AWL reputation of From: address BAYES_00 -1.9 Bayes spam probability is 0 to 1% DMARC_MISSING 0.1 Missing DMARC policy KAM_DMARC_STATUS 0.01 Test Rule for DKIM or SPF Failure with Strict Alignment SPF_HELO_NONE 0.001 SPF: HELO does not publish an SPF Record SPF_PASS -0.001 SPF: sender matches SPF record Subject: [pve-devel] [PATCH ha-manager v2 08/26] manager: read and update rules config X-BeenThere: pve-devel@lists.proxmox.com X-Mailman-Version: 2.1.29 Precedence: list List-Id: Proxmox VE development discussion <pve-devel.lists.proxmox.com> List-Unsubscribe: <https://lists.proxmox.com/cgi-bin/mailman/options/pve-devel>, <mailto:pve-devel-request@lists.proxmox.com?subject=unsubscribe> List-Archive: <http://lists.proxmox.com/pipermail/pve-devel/> List-Post: <mailto:pve-devel@lists.proxmox.com> List-Help: <mailto:pve-devel-request@lists.proxmox.com?subject=help> List-Subscribe: <https://lists.proxmox.com/cgi-bin/mailman/listinfo/pve-devel>, <mailto:pve-devel-request@lists.proxmox.com?subject=subscribe> Reply-To: Proxmox VE development discussion <pve-devel@lists.proxmox.com> Content-Type: text/plain; charset="us-ascii" Content-Transfer-Encoding: 7bit Errors-To: pve-devel-bounces@lists.proxmox.com Sender: "pve-devel" <pve-devel-bounces@lists.proxmox.com> Read the rules configuration in each round and update the canonicalized rules configuration if there were any changes since the last round to reduce the amount of times of verifying the rule set. Signed-off-by: Daniel Kral <d.kral@proxmox.com> --- changes since v1: - only read and canonicalize rules here... introduce the migration from groups to services and rules in a later patch src/PVE/HA/Manager.pm | 21 ++++++++++++++++++++- 1 file changed, 20 insertions(+), 1 deletion(-) diff --git a/src/PVE/HA/Manager.pm b/src/PVE/HA/Manager.pm index 85bb114..08c2fd3 100644 --- a/src/PVE/HA/Manager.pm +++ b/src/PVE/HA/Manager.pm @@ -8,6 +8,9 @@ use Digest::MD5 qw(md5_base64); use PVE::Tools; use PVE::HA::Tools ':exit_codes'; use PVE::HA::NodeStatus; +use PVE::HA::Rules; +use PVE::HA::Rules::Location; +use PVE::HA::Rules::Colocation; use PVE::HA::Usage::Basic; use PVE::HA::Usage::Static; @@ -41,7 +44,11 @@ sub new { my $class = ref($this) || $this; - my $self = bless { haenv => $haenv, crs => {} }, $class; + my $self = bless { + haenv => $haenv, + crs => {}, + last_rules_digest => '', + }, $class; my $old_ms = $haenv->read_manager_status(); @@ -556,6 +563,18 @@ sub manage { delete $ss->{$sid}; } + my $new_rules = $haenv->read_rules_config(); + + if ($new_rules->{digest} ne $self->{last_rules_digest}) { + + my $messages = PVE::HA::Rules->canonicalize($new_rules); + $haenv->log('info', $_) for @$messages; + + $self->{rules} = $new_rules; + + $self->{last_rules_digest} = $self->{rules}->{digest}; + } + $self->update_crm_commands(); for (;;) { -- 2.39.5 _______________________________________________ pve-devel mailing list pve-devel@lists.proxmox.com https://lists.proxmox.com/cgi-bin/mailman/listinfo/pve-devel