When I run a basic Docker container (from within Google Cloud Shell) like so
docker pull debian
docker run -i -t debian:wheezy /bin/bash
and then type runlevel
at the running container's shell prompt, the run level is unknown
. Am I supposed to install (apt-get
) particular packages in order to add support for run levels. If so, which ones, or what else could be wrong?
Docker is an application isolation tool, not an OS virtualization tool. Runlevel's are at the OS level, the OS comes up, mounts directories, and starts services to achieve a runlevel. In a container, your application is launched, the end. You can assume the container is at a single user run level, since you're the only user accessing the environment, but it really shouldn't matter for installing applications.
BMitch is right. Docker has nothing to do with runlevels, it will never change a runlevel. But there is more.
runlevel
unknown
is common on some systems runningsystemd
. Your question is tagged with Debian though, and Debian Jessie (the latest Debian release, which uses systemd, uses compatibility script to print a runlevel). Arch based distros, and the unstable RedHat based distros (e.g. Fedora) printunknown
when executingrunlevel
, i.e. they do not even care to print a fake runlevel.If you check your runlevel script you will get the following output on a recent distro:
(that is on arch,
runlevel
is in/usr/sbin
on Debian, but it also points tosystemctl
on Debian)The
runlevel
script points tosysemtd
control on most recent distros.In general
runlevel
has no meaning on recent distros (because ofsystemd
to which pretty much everyone switched to). If you look inside the/etc/rc.d/rc*.d/
directories, they're almost empty.What is actually defining how
init
processes the system boot is the systemd default target, located here:Or
/etc/systemd/system/default.target
, if that exists.