-
Notifications
You must be signed in to change notification settings - Fork 324
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
network lock method for checkpoint/restore defaults to iptables #1627
Comments
CC: @danishprakash It is also worth noting the following pull request with a fix for network locking with nftables: checkpoint-restore/criu#2550 |
should we default to diff --git a/src/libcrun/criu.c b/src/libcrun/criu.c
index 2e4e0d9d..614dc35f 100644
--- a/src/libcrun/criu.c
+++ b/src/libcrun/criu.c
@@ -647,7 +647,7 @@ libcrun_container_checkpoint_linux_criu (libcrun_container_status_t *status, lib
libcriu_wrapper->criu_set_manage_cgroups_mode (cr_options->manage_cgroups_mode);
libcriu_wrapper->criu_set_manage_cgroups (true);
- if (libcriu_wrapper->criu_set_network_lock)
+ if (libcriu_wrapper->criu_set_network_lock && cr_options->network_lock_method)
libcriu_wrapper->criu_set_network_lock (cr_options->network_lock_method);
ret = libcriu_wrapper->criu_dump (); |
No, Looking closer at the code I am confused it works at all. Ah, the return value is not checked. Setting it to Your patch does sound like a good idea. Return value checking would have helped here, but most of the CRIU library function return codes are not checked currently (which I am probably also to blame for). |
commit c4f8c87 introduced the issue. Closes: containers#1627 Signed-off-by: Giuseppe Scrivano <[email protected]>
commit c4f8c87 introduced the issue. Closes: containers#1627 Signed-off-by: Giuseppe Scrivano <[email protected]>
opened a PR: #1628 |
commit c4f8c87 introduced the issue. Closes: containers#1627 Signed-off-by: Giuseppe Scrivano <[email protected]>
I think PR #1613 is not helpful as it is. With this change crun always defaults to iptables as network lock method (because if nothing is set the parameter will always be 0 (which is iptables based locking)). This breaks podman container restore on CentOS 10. On CentOS 10 I am switching CRIU to default to the nftables locking backend. With PR #1613, if nothing is specified, crun forces the iptables locking backend.
If the user does not select a specific locking backend crun should not explicitly set the parameter as it overwrites the defaults from CRIU.
Please revert #1613 or do not force a certain locking backend. Maybe default to -1 and skip telling CRIU about the locking backend if the parameter is -1. Would be good to have a fix in CentOS 10 also as soon as possible.
The text was updated successfully, but these errors were encountered: