Alin Dobre <alin.dobre@xxxxxxxxxxxxxxxx> writes: > Hello, > > I am trying to run the following command inside an image using user > namespaces via contain [1], a very simplistic implementation of linux > containers: > contain /path/to/image /bin/bash > > Although the host kernel does have support for owner matching and it > works with no errors, running the following iptables command inside the > container: > iptables -A OUTPUT -m owner --uid-owner root -j ACCEPT > returns the error "Invalid argument". > > The last commit for the netfilter xt_owner module is exactly Eric's > basic support for user namespaces, but there might be some other recent > changes either in the namespaces area or netfilter in general, which > brought the module in an unusable state inside containers - at least for > the above command usage. The code says. static int owner_check(const struct xt_mtchk_param *par) { struct xt_owner_match_info *info = par->matchinfo; /* For now only allow adding matches from the initial user namespace */ if ((info->match & (XT_OWNER_UID|XT_OWNER_GID)) && (current_user_ns() != &init_user_ns)) return -EINVAL; return 0; } So it is not expected to work in user namespaces by design. > I can try to send the image I used for testing to anyone who desires, > but a handy shortcut should be "deboostrap trusty /path/to/image" and > "chroot /path/to/image apt-get install iptables". > > The host kernel is 3.14.4, iptables version on the host is 1.4.15 and > inside the Ubuntu container is 1.4.18. I have tried with Ubuntu 13.* and > Ubuntu 14.04, but I don't think the userspace has anything to do with this. > > I can provide with any additional information needed. > > Any insights on this? As I recall this code largely matches directly on the values passed in from userspace. Which in this case is a problem because I would like to store kuids and kgids in the data structures and compare those. I believe it would take some careful refactoring to allow massaging the data from the form the user supplied to something more appropriate before we perform the match. That is making this work is tricky so I punted and did not support it from inside a user namespace. Eric _______________________________________________ Containers mailing list Containers@xxxxxxxxxxxxxxxxxxxxxxxxxx https://lists.linuxfoundation.org/mailman/listinfo/containers