-
-
Notifications
You must be signed in to change notification settings - Fork 232
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
Strange behavior of idmapping for unprivileged isolated containers #1294
Comments
About the 2. issue. |
Figured the off by one issue:
|
HOWEVER, in most cases, the system having |
Thanks for answer and quick fix of the bug. |
Closes #1294 Signed-off-by: Stéphane Graber <stgraber@stgraber.org>
I discovered two strange behaviors of Incus when setting subgid/subuid files and creating isolated containers.
1) First
When using Incus 6.0.1 from Debian Bookworm backports or Incus 6.0.2 from Debian Trixie. Also happened when I tried self-compiling. Clean install, all settings default.
In this case Incus needs 1 more ID range than necessary.
Example and how to replicate:
We want to create 2 isolated containers and set subgid/subuid at minimum range needed.
By default Incus starts isolated containers at 65536 position and uses range 65536 for each. That means 3*65536 = 196608 should be enough.
We set subgid/subuid:
root:1000000:196608
This should allow us to use host IDs: 1 000 000 ........ 1 196 607
Incus should then map IDs of isolated containers like this:
0 ............... 1 065 536
65 535 .... 1 131 071
0 ............... 1 131 072
65 535 .... 1 196 607
But this doesnt work and Incus complains that for 2. container there is not enough gid/uid available.
Error: Failed instance creation: Failed creating instance record: Failed initializing instance: Not enough uid/gid available for the container
This error comes from here:
incus/internal/server/instance/drivers/driver_lxc.go
Line 631 in dc287b6
To get around this you need to set subgid/subuid range one ID larger:
root:1000000:196609
Seems like maybe small bug.
2) Second
When using Incus 6.0.2 or Incus Daily build from Zabbly repo on Debian Bookworm. Clean install, all settings default.
This is much simpler. In this case Incus never complains about uid/gid even if I set small range and use more isolated containers than should be possible.
Example and how to replicate:
We set subgid/subuid:
root:1000000:80000
This shouldnt be enough even for one isolated container.
If you try creating any number of isolated containers it works even when it shouldnt.
When checking
/run/incus/container/lxc.conf
you can see isolated containers mapped out of range.When trying unisolated container it's range is set as 1 000 000 000.
So it looks like Incus dosnt see the setting of subgid/subuid and uses it's default ranges as described here: https://linuxcontainers.org/incus/docs/main/userns-idmap/
The text was updated successfully, but these errors were encountered: