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 5CA6A1FF17A
	for <inbox@lore.proxmox.com>; Fri,  4 Jul 2025 16:43:31 +0200 (CEST)
Received: from firstgate.proxmox.com (localhost [127.0.0.1])
	by firstgate.proxmox.com (Proxmox) with ESMTP id 0B5743A917;
	Fri,  4 Jul 2025 16:44:11 +0200 (CEST)
Message-ID: <f82ae0b8-0dbe-497e-8cbd-c7c2f6a7a9c6@proxmox.com>
Date: Fri, 4 Jul 2025 16:43:37 +0200
MIME-Version: 1.0
User-Agent: Mozilla Thunderbird
To: Proxmox VE development discussion <pve-devel@lists.proxmox.com>,
 Daniel Kral <d.kral@proxmox.com>
References: <20250620143148.218469-1-d.kral@proxmox.com>
 <20250620143148.218469-11-d.kral@proxmox.com>
Content-Language: en-US
From: =?UTF-8?Q?Michael_K=C3=B6ppl?= <m.koeppl@proxmox.com>
In-Reply-To: <20250620143148.218469-11-d.kral@proxmox.com>
X-SPAM-LEVEL: Spam detection results:  0
 AWL 0.015 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: Re: [pve-devel] [PATCH ha-manager v2 06/26] rules: add global
 checks between location and colocation rules
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>

On 6/20/25 16:31, Daniel Kral wrote:
> Add checks, which determine infeasible colocation rules, because their
> services are already restricted by their location rules in such a way,
> that these cannot be satisfied or are reasonable to be proven to be
> satisfiable.
> 
> Positive colocation rule services need to have at least one common node
> to be feasible and negative colocation rule services need to have at
> least the amount of nodes available that nodes are restricted to in
> total, i.e. services that are in strict location rules.
> 
> Since location rules allow nodes to be put in priority groups, but the
> information which priority group is relevant depends on the online
> nodes, these checks currently prohibit colocation rules with services,
> which make use of these kinds of location rules.
> 
> Even though location rules are restricted to only allow a service to be
> used in a single location rule, the checks here still go over all
> location rules, as this restriction is bound to be changed in the
> future.
> 
> Signed-off-by: Daniel Kral <d.kral@proxmox.com>
> ---
> changes since v1:
>     - moved global checks from Colocation plugin to base plugin
>     - add check to only allow colocation rules for services which are in
>       single-priority location rules / ha groups because these are quite
>       stateful and cannot be easily verified to be possible
> 
>  src/PVE/HA/Rules.pm | 189 ++++++++++++++++++++++++++++++++++++++++++++
>  1 file changed, 189 insertions(+)
> 
> diff --git a/src/PVE/HA/Rules.pm b/src/PVE/HA/Rules.pm
> index 4134283..588e53b 100644
> --- a/src/PVE/HA/Rules.pm
> +++ b/src/PVE/HA/Rules.pm
> @@ -3,6 +3,7 @@ package PVE::HA::Rules;
>  use strict;
>  use warnings;
>  
> +use PVE::HashTools;
>  use PVE::JSONSchema qw(get_standard_option);
>  use PVE::Tools;
>  
> @@ -469,4 +470,192 @@ sub foreach_rule : prototype($$;$) {
>      }
>  }
>  
> +=head1 INTER-PLUGIN RULE CHECKERS
> +
> +=cut
> +
> +=head3 check_single_priority_location_for_colocated_services($location_rules, $colocation_rules)
> +
> +Returns a list of colocation rule ids defined in C<$colocation_rules>, where
> +the services in the colocation rule are in location rules, defined in
> +C<$location_rules>, which have multiple priority groups defined. That is, the
> +colocation rule cannot be statically checked to be feasible as the selection of
> +the priority group is dependent on the currently online nodes.

Might be that I'm misinterpreting this, but doesn't that only apply when
the location rule contains more than 1 node? At the moment, this check
would fail if I have location rules vm:100->node1 and vm:101->node2,
either of them has a priority assigned and I then try to add a
colocation rule that separates them. This would be possible without the
priority assigned.

> +
> +If there are none, the returned list is empty.
> +
> +=cut
> +
> +sub check_single_priority_location_for_colocated_services {
> +    my ($colocation_rules, $location_rules) = @_;
> +
> +    my @errors = ();
> +
> +    while (my ($colocationid, $colocation_rule) = each %$colocation_rules) {
> +        my $priority;
> +        my $services = $colocation_rule->{services};
> +
> +        for my $locationid (keys %$location_rules) {
> +            my $location_rule = $location_rules->{$locationid};
> +
> +            next if PVE::HashTools::sets_are_disjoint($services, $location_rule->{services});
> +
> +            for my $node (values %{ $location_rule->{nodes} }) {
> +                $priority = $node->{priority} if !defined($priority);
> +
> +                if ($priority != $node->{priority}) {
> +                    push @errors, $colocationid;
> +                    last; # early return to check next colocation rule
> +                }
> +            }
> +        }
> +    }
> +


_______________________________________________
pve-devel mailing list
pve-devel@lists.proxmox.com
https://lists.proxmox.com/cgi-bin/mailman/listinfo/pve-devel