netfilter: conntrack: adopt safer max chain length
authorEric Dumazet <edumazet@google.com>
Tue, 7 Mar 2023 05:22:54 +0000 (05:22 +0000)
committerPablo Neira Ayuso <pablo@netfilter.org>
Tue, 7 Mar 2023 09:58:06 +0000 (10:58 +0100)
commitc77737b736ceb50fdf150434347dbd81ec76dbb1
tree8f5c30ea32208c34b6f2468729dcecc28aff8e75
parent4a02426787bf024dafdb79b362285ee325de3f5e
netfilter: conntrack: adopt safer max chain length

Customers using GKE 1.25 and 1.26 are facing conntrack issues
root caused to commit c9c3b6811f74 ("netfilter: conntrack: make
max chain length random").

Even if we assume Uniform Hashing, a bucket often reachs 8 chained
items while the load factor of the hash table is smaller than 0.5

With a limit of 16, we reach load factors of 3.
With a limit of 32, we reach load factors of 11.
With a limit of 40, we reach load factors of 15.
With a limit of 50, we reach load factors of 24.

This patch changes MIN_CHAINLEN to 50, to minimize risks.

Ideally, we could in the future add a cushion based on expected
load factor (2 * nf_conntrack_max / nf_conntrack_buckets),
because some setups might expect unusual values.

Fixes: c9c3b6811f74 ("netfilter: conntrack: make max chain length random")
Signed-off-by: Eric Dumazet <edumazet@google.com>
Signed-off-by: Pablo Neira Ayuso <pablo@netfilter.org>
net/netfilter/nf_conntrack_core.c