Skip to content

-P option cannot show the process:

Since ruri use pivot_root() for unshare container for better security,
if your device does not support PID ns,
we cannot get process info by reading the link /proc/$PID/root, because after pivot_root, it will always be /

Network issue:

You might have temporary failure resolving xxxxx or bad address xxxxx.
Try:

rm /etc/resolv.conf
echo nameserver 1.1.1.1 > /etc/resolv.conf
Or, for Android, run https://github.com/Moe-hacker/daijin/raw/refs/heads/main/src/share/fixup.sh in container.

About container environment:

For safety, ruri container is like default docker container, it will mask some directory in /sys and /proc, drop unneed capabilities, and you are not able to run command like mknod or mount by default.

About capability:

ruri will set capability to the same as docker common container by default, you can use -k [cap] or -d [cap] to change the capability settings.
For example, use -d cap_sys_admin to drop CAP_SYS_ADMIN.
In fulture, maybe new caps will be added to the kernel, and their name might cannot be recognized if you are using old builds. You can use the value of cap (use capsh --explain=[cap] to get the value) to drop it, for example, use -d 114 to drop the cap 114 (I don't know what the cap should be, mabe can make superuser to be a homo).

About config:

Since v3.0, ruri can use k2v, a new simple config format, to store the config of a container.

About rurienv:

Since v3.0, ruri removed the daemon, it use a new way to store the info of a running container.
ruri will creat /.rurienv file into the container, to store runtime info of container.
The rurienv file is automatically controled by ruri, please do not edit it.

About tty:

The command tty in ruri might say that "not a tty".
If you need to run some program like gpg, please use script -q -O /dev/null in container.

About runtime dirs:

ruri will create /dev/, /sys/ and /proc/ after chroot(2) into container for better security. You can use -S option to force it to bind-mount system runtime dirs.

About multi-arch container:

Yes, you can run multi-arch containers via ruri if your device support.
It needs CONFIG_BINFMT_MISC enabled in your kernel config.
You need to copy qemu-*-static to your container first.
The path of qemu is the absolute path of qemu binary in the chroot container, for example, you have a qemu binary at /path/to/container/qemu-amd64-static, use -a x86_64 -q /qemu-amd64-static arguments to start the container.

About rootless container:

If you get error like Couldn't create temporary file /tmp/apt.conf.sIKx3J for passing config to apt-key in container, please chmod 777 /tmp.
You need uidmap installed in your host.
You might need /etc/subuid and /etc/subgid configured in your host.

About Seccomp:

The seccomp rule of ruri is based on Docker's default seccomp profile. ruri does not provide the way to change it, but you can edit src/seccomp.c and rewrite setup_seccomp() with your own config.