-
Notifications
You must be signed in to change notification settings - Fork 85
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
ipv6 connectivity -- managing NDP entries #270
Comments
Moved to netavark since we would need to implement it here. I think netavark does only ipv6 nat at the moment and I think you want global routeable addresses? |
I think we do support globally-routable addresses, but I don't know if we documented the "how" of it particularly well, and we definitely aren't testing them in CI on account of not having any to work with. |
I do not see any conditionals in the ipv6 iptables code so i think we always NAT them. |
Well, damn. I know we talked about it, evidently it wasn't implemented. Should definitely get on this, as it's a regression from CNI's v6 support; @baude PTAL |
I don't think cni supports this either |
We've definitely been instructing people to do this in CNI land for several years. I have to imagine at least some of them were successful? |
Vanishingly few hosting providers will route the entire ipv6 subnet they assign you. Usually there needs to be |
This can be done with an OCI hook. I think the kernel will GC stale NDP entries automatically. #!/bin/sh
in=$(</dev/stdin)
ip=$(echo $in | jq -r '.annotations | .[\"hatchery.pod.ip\"]')
if=$(/usr/sbin/ip -6 r | awk '/^default/ {printf $5}')
/usr/sbin/ip -6 neigh add proxy $ip dev $if |
Yes, rootful. Vanishingly few hosting providers will actually route the entire ipv6 subnet they give you, so usually there needs to be something on your host responding to the upstream NDP solicitations for each pod. Linux does not automatically know how to respond to these and needs to be configured manually (see https://github.com/DanielAdolfsson/ndppd/blob/0.2.5/README, https://yoursunny.com/t/2021/ndpresponder/)
Mar 28, 2022 4:23:32 AM Paul Holzinger ***@***.***>:
… Moved to netavark since we would need to implement it here.
I assume you want to use this with rootful podman because rootless would be another story.
I think netavark does only ipv6 nat at the moment and I think you want global routeable addresses?
Why would need to manually manage ndp entries? Shouldn't the kernel handle this automatically?
—
Reply to this email directly, view it on GitHub[#270 (comment)], or unsubscribe[https://github.com/notifications/unsubscribe-auth/ABDLDWDIKS5OD4Q4N52PE2DVCGJDFANCNFSM5R2ZPVMQ].
You are receiving this because you authored the thread. [###24x24:true###][Tracking image][https://github.com/notifications/beacon/ABDLDWEQ2ZZZYRACAUPBUFLVCGJDFA5CNFSM5R2ZPVM2YY3PNVWWK3TUL52HS4DFVREXG43VMVBW63LNMVXHJKTDN5WW2ZLOORPWSZGOIBTZAGY.gif]
|
Is there any update on this? I want to use public routable ipv6 addresses for my containers, but I can not find any documentation on how to do this with podman. |
Not NAt-ed global ipv6 address sounds easy enough to implement, contributions welcome. |
Got it working by fiddling with network namespaces and interfaces by hand. Should be easy to implement, but e.g. integrating with systemd-networkd for prefix delegation from host interface will be more difficult. Might start working on a patch for systemd to add an API for container runtimes if it does not exist |
/kind feature
Description
Podman 4.0 has added support for ipv6 static addresses (really appreciating the perf improvements with netavark, btw). Podman also has facilities for routing traffic to containers (e.g. managing firewall rules). With this in mind, it could be nice if Podman also took the step of ensuring ipv6 connectivity through managing the host's NDP table.
Linux has some support for responding to NDP requests, but this must manually set with iproute2 per address and not an entire subnet. It is therefore more practical to run a daemon (ndppd, ndpresponder) to do this mapping dynamically. Could Podman remove the need for this extra dependency by managing the host's NDP table to automatically ensure connectivity to containers?
The text was updated successfully, but these errors were encountered: