1 <!DOCTYPE html PUBLIC
"-//W3C//DTD XHTML 1.0 Strict//EN"
2 "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
3 <html xmlns=
"http://www.w3.org/1999/xhtml" dir=
"ltr">
5 <meta http-equiv=
"Content-Type" content=
"text/html;charset=utf-8" />
6 <title>Petter Reinholdtsen: How is booting into runlevel
1 different from single user boots?
</title>
7 <link rel=
"stylesheet" type=
"text/css" media=
"screen" href=
"http://people.skolelinux.org/pere/blog/style.css" />
8 <link rel=
"stylesheet" type=
"text/css" media=
"screen" href=
"http://people.skolelinux.org/pere/blog/vim.css" />
13 <a href=
"http://people.skolelinux.org/pere/blog/">Petter Reinholdtsen
</a>
21 <div class=
"title">How is booting into runlevel
1 different from single user boots?
</div>
22 <div class=
"date"> 4th August
2011</div>
23 <div class=
"body"><p>Wouter Verhelst have some
24 <a href=
"http://grep.be/blog/en/retorts/pere_kubuntu_boot">interesting
25 comments and opinions
</a> on my blog post on
26 <a href=
"http://people.skolelinux.org/pere/blog/What_should_start_from__etc_rcS_d__in_Debian____almost_nothing.html">the
27 need to clean up /etc/rcS.d/ in Debian
</a> and my blog post about
28 <a href=
"http://people.skolelinux.org/pere/blog/What_is_missing_in_the_Debian_desktop__or_why_my_parents_use_Kubuntu.html">the
29 default KDE desktop in Debian
</a>. I only have time to address one
30 small piece of his comment now, and though it best to address the
31 misunderstanding he bring forward:
</p>
34 Currently, a system admin has four options: [...] boot to a
35 single-user system (by adding 'single' to the kernel command line;
36 this runs rcS and rc1 scripts)
39 <p>This make me believe Wouter believe booting into single user mode
40 and booting into runlevel
1 is the same. I am not surprised he
41 believe this, because it would make sense and is a quite sensible
42 thing to believe. But because the boot in Debian is slightly broken,
43 runlevel
1 do not work properly and it isn't the same as single user
44 mode. I'll try to explain what is actually happing, but it is a bit
47 <p>Single user mode is defined like this in /etc/inittab:
48 "
<tt>~~:S:wait:/sbin/sulogin
</tt>". This means the only thing that is
49 executed in single user mode is sulogin. Single user mode is a boot
50 state "between
" the runlevels, and when booting into single user mode,
51 only the scripts in /etc/rcS.d/ are executed before the init process
52 enters the single user state. When switching to runlevel 1, the state
53 is in fact not ending in runlevel 1, but it passes through runlevel 1
54 and end up in the single user mode (see /etc/rc1.d/S03single, which
55 runs "init -t1 S
" to switch to single user mode at the end of runlevel
56 1. It is confusing that the 'S' (single user) init mode is not the
57 mode enabled by /etc/rcS.d/ (which is more like the initial boot
60 <p>This summary might make it clearer. When booting for the first
61 time into single user mode, the following commands are executed:
62 "<tt>/etc/init.d/rc S; /sbin/sulogin
</tt>". When booting into
63 runlevel 1, the following commands are executed: "<tt>/etc/init.d/rc
64 S; /etc/init.d/rc
1; /sbin/sulogin
</tt>". A problem show up when
65 trying to continue after visiting single user mode. Not all services
66 are started again as they should, causing the machine to end up in an
67 unpredicatble state. This is why Debian admins recommend rebooting
68 after visiting single user mode.</p>
70 <p>A similar problem with runlevel 1 is caused by the amount of
71 scripts executed from /etc/rcS.d/. When switching from say runlevel 2
72 to runlevel 1, the services started from /etc/rcS.d/ are not properly
73 stopped when passing through the scripts in /etc/rc1.d/, and not
74 started again when switching away from runlevel 1 to the runlevels
75 2-5. I believe the problem is best fixed by moving all the scripts
76 out of /etc/rcS.d/ that are not <strong>required</strong> to get a
77 functioning single user mode during boot.</p>
79 <p>I have spent several years investigating the Debian boot system,
80 and discovered this problem a few years ago. I suspect it originates
81 from when sysvinit was introduced into Debian, a long time ago.</p>
84 <div class="tags
">Tags: <a href="http://people.skolelinux.org/pere/blog/tags/bootsystem
">bootsystem</a>, <a href="http://people.skolelinux.org/pere/blog/tags/debian
">debian</a>, <a href="http://people.skolelinux.org/pere/blog/tags/english
">english</a>.</div>
102 <li><a href="http://people.skolelinux.org/pere/blog/archive/
2013/
01/
">January (11)</a></li>
104 <li><a href="http://people.skolelinux.org/pere/blog/archive/
2013/
02/
">February (2)</a></li>
111 <li><a href="http://people.skolelinux.org/pere/blog/archive/
2012/
01/
">January (7)</a></li>
113 <li><a href="http://people.skolelinux.org/pere/blog/archive/
2012/
02/
">February (10)</a></li>
115 <li><a href="http://people.skolelinux.org/pere/blog/archive/
2012/
03/
">March (17)</a></li>
117 <li><a href="http://people.skolelinux.org/pere/blog/archive/
2012/
04/
">April (12)</a></li>
119 <li><a href="http://people.skolelinux.org/pere/blog/archive/
2012/
05/
">May (12)</a></li>
121 <li><a href="http://people.skolelinux.org/pere/blog/archive/
2012/
06/
">June (20)</a></li>
123 <li><a href="http://people.skolelinux.org/pere/blog/archive/
2012/
07/
">July (17)</a></li>
125 <li><a href="http://people.skolelinux.org/pere/blog/archive/
2012/
08/
">August (6)</a></li>
127 <li><a href="http://people.skolelinux.org/pere/blog/archive/
2012/
09/
">September (9)</a></li>
129 <li><a href="http://people.skolelinux.org/pere/blog/archive/
2012/
10/
">October (17)</a></li>
131 <li><a href="http://people.skolelinux.org/pere/blog/archive/
2012/
11/
">November (10)</a></li>
133 <li><a href="http://people.skolelinux.org/pere/blog/archive/
2012/
12/
">December (7)</a></li>
140 <li><a href="http://people.skolelinux.org/pere/blog/archive/
2011/
01/
">January (16)</a></li>
142 <li><a href="http://people.skolelinux.org/pere/blog/archive/
2011/
02/
">February (6)</a></li>
144 <li><a href="http://people.skolelinux.org/pere/blog/archive/
2011/
03/
">March (6)</a></li>
146 <li><a href="http://people.skolelinux.org/pere/blog/archive/
2011/
04/
">April (7)</a></li>
148 <li><a href="http://people.skolelinux.org/pere/blog/archive/
2011/
05/
">May (3)</a></li>
150 <li><a href="http://people.skolelinux.org/pere/blog/archive/
2011/
06/
">June (2)</a></li>
152 <li><a href="http://people.skolelinux.org/pere/blog/archive/
2011/
07/
">July (7)</a></li>
154 <li><a href="http://people.skolelinux.org/pere/blog/archive/
2011/
08/
">August (6)</a></li>
156 <li><a href="http://people.skolelinux.org/pere/blog/archive/
2011/
09/
">September (4)</a></li>
158 <li><a href="http://people.skolelinux.org/pere/blog/archive/
2011/
10/
">October (2)</a></li>
160 <li><a href="http://people.skolelinux.org/pere/blog/archive/
2011/
11/
">November (3)</a></li>
162 <li><a href="http://people.skolelinux.org/pere/blog/archive/
2011/
12/
">December (1)</a></li>
169 <li><a href="http://people.skolelinux.org/pere/blog/archive/
2010/
01/
">January (2)</a></li>
171 <li><a href="http://people.skolelinux.org/pere/blog/archive/
2010/
02/
">February (1)</a></li>
173 <li><a href="http://people.skolelinux.org/pere/blog/archive/
2010/
03/
">March (3)</a></li>
175 <li><a href="http://people.skolelinux.org/pere/blog/archive/
2010/
04/
">April (3)</a></li>
177 <li><a href="http://people.skolelinux.org/pere/blog/archive/
2010/
05/
">May (9)</a></li>
179 <li><a href="http://people.skolelinux.org/pere/blog/archive/
2010/
06/
">June (14)</a></li>
181 <li><a href="http://people.skolelinux.org/pere/blog/archive/
2010/
07/
">July (12)</a></li>
183 <li><a href="http://people.skolelinux.org/pere/blog/archive/
2010/
08/
">August (13)</a></li>
185 <li><a href="http://people.skolelinux.org/pere/blog/archive/
2010/
09/
">September (7)</a></li>
187 <li><a href="http://people.skolelinux.org/pere/blog/archive/
2010/
10/
">October (9)</a></li>
189 <li><a href="http://people.skolelinux.org/pere/blog/archive/
2010/
11/
">November (13)</a></li>
191 <li><a href="http://people.skolelinux.org/pere/blog/archive/
2010/
12/
">December (12)</a></li>
198 <li><a href="http://people.skolelinux.org/pere/blog/archive/
2009/
01/
">January (8)</a></li>
200 <li><a href="http://people.skolelinux.org/pere/blog/archive/
2009/
02/
">February (8)</a></li>
202 <li><a href="http://people.skolelinux.org/pere/blog/archive/
2009/
03/
">March (12)</a></li>
204 <li><a href="http://people.skolelinux.org/pere/blog/archive/
2009/
04/
">April (10)</a></li>
206 <li><a href="http://people.skolelinux.org/pere/blog/archive/
2009/
05/
">May (9)</a></li>
208 <li><a href="http://people.skolelinux.org/pere/blog/archive/
2009/
06/
">June (3)</a></li>
210 <li><a href="http://people.skolelinux.org/pere/blog/archive/
2009/
07/
">July (4)</a></li>
212 <li><a href="http://people.skolelinux.org/pere/blog/archive/
2009/
08/
">August (3)</a></li>
214 <li><a href="http://people.skolelinux.org/pere/blog/archive/
2009/
09/
">September (1)</a></li>
216 <li><a href="http://people.skolelinux.org/pere/blog/archive/
2009/
10/
">October (2)</a></li>
218 <li><a href="http://people.skolelinux.org/pere/blog/archive/
2009/
11/
">November (3)</a></li>
220 <li><a href="http://people.skolelinux.org/pere/blog/archive/
2009/
12/
">December (3)</a></li>
227 <li><a href="http://people.skolelinux.org/pere/blog/archive/
2008/
11/
">November (5)</a></li>
229 <li><a href="http://people.skolelinux.org/pere/blog/archive/
2008/
12/
">December (7)</a></li>
240 <li><a href="http://people.skolelinux.org/pere/blog/tags/
3d-printer
">3d-printer (13)</a></li>
242 <li><a href="http://people.skolelinux.org/pere/blog/tags/amiga
">amiga (1)</a></li>
244 <li><a href="http://people.skolelinux.org/pere/blog/tags/aros
">aros (1)</a></li>
246 <li><a href="http://people.skolelinux.org/pere/blog/tags/bankid
">bankid (4)</a></li>
248 <li><a href="http://people.skolelinux.org/pere/blog/tags/bitcoin
">bitcoin (6)</a></li>
250 <li><a href="http://people.skolelinux.org/pere/blog/tags/bootsystem
">bootsystem (12)</a></li>
252 <li><a href="http://people.skolelinux.org/pere/blog/tags/bsa
">bsa (2)</a></li>
254 <li><a href="http://people.skolelinux.org/pere/blog/tags/debian
">debian (70)</a></li>
256 <li><a href="http://people.skolelinux.org/pere/blog/tags/debian edu
">debian edu (118)</a></li>
258 <li><a href="http://people.skolelinux.org/pere/blog/tags/digistan
">digistan (9)</a></li>
260 <li><a href="http://people.skolelinux.org/pere/blog/tags/docbook
">docbook (7)</a></li>
262 <li><a href="http://people.skolelinux.org/pere/blog/tags/drivstoffpriser
">drivstoffpriser (4)</a></li>
264 <li><a href="http://people.skolelinux.org/pere/blog/tags/english
">english (176)</a></li>
266 <li><a href="http://people.skolelinux.org/pere/blog/tags/fiksgatami
">fiksgatami (21)</a></li>
268 <li><a href="http://people.skolelinux.org/pere/blog/tags/fildeling
">fildeling (12)</a></li>
270 <li><a href="http://people.skolelinux.org/pere/blog/tags/freeculture
">freeculture (10)</a></li>
272 <li><a href="http://people.skolelinux.org/pere/blog/tags/frikanalen
">frikanalen (9)</a></li>
274 <li><a href="http://people.skolelinux.org/pere/blog/tags/intervju
">intervju (32)</a></li>
276 <li><a href="http://people.skolelinux.org/pere/blog/tags/isenkram
">isenkram (5)</a></li>
278 <li><a href="http://people.skolelinux.org/pere/blog/tags/kart
">kart (17)</a></li>
280 <li><a href="http://people.skolelinux.org/pere/blog/tags/ldap
">ldap (8)</a></li>
282 <li><a href="http://people.skolelinux.org/pere/blog/tags/lenker
">lenker (6)</a></li>
284 <li><a href="http://people.skolelinux.org/pere/blog/tags/ltsp
">ltsp (1)</a></li>
286 <li><a href="http://people.skolelinux.org/pere/blog/tags/multimedia
">multimedia (25)</a></li>
288 <li><a href="http://people.skolelinux.org/pere/blog/tags/norsk
">norsk (220)</a></li>
290 <li><a href="http://people.skolelinux.org/pere/blog/tags/nuug
">nuug (148)</a></li>
292 <li><a href="http://people.skolelinux.org/pere/blog/tags/offentlig innsyn
">offentlig innsyn (6)</a></li>
294 <li><a href="http://people.skolelinux.org/pere/blog/tags/open311
">open311 (2)</a></li>
296 <li><a href="http://people.skolelinux.org/pere/blog/tags/opphavsrett
">opphavsrett (41)</a></li>
298 <li><a href="http://people.skolelinux.org/pere/blog/tags/personvern
">personvern (62)</a></li>
300 <li><a href="http://people.skolelinux.org/pere/blog/tags/raid
">raid (1)</a></li>
302 <li><a href="http://people.skolelinux.org/pere/blog/tags/reprap
">reprap (11)</a></li>
304 <li><a href="http://people.skolelinux.org/pere/blog/tags/rfid
">rfid (2)</a></li>
306 <li><a href="http://people.skolelinux.org/pere/blog/tags/robot
">robot (6)</a></li>
308 <li><a href="http://people.skolelinux.org/pere/blog/tags/rss
">rss (1)</a></li>
310 <li><a href="http://people.skolelinux.org/pere/blog/tags/ruter
">ruter (4)</a></li>
312 <li><a href="http://people.skolelinux.org/pere/blog/tags/scraperwiki
">scraperwiki (2)</a></li>
314 <li><a href="http://people.skolelinux.org/pere/blog/tags/sikkerhet
">sikkerhet (28)</a></li>
316 <li><a href="http://people.skolelinux.org/pere/blog/tags/sitesummary
">sitesummary (4)</a></li>
318 <li><a href="http://people.skolelinux.org/pere/blog/tags/skepsis
">skepsis (4)</a></li>
320 <li><a href="http://people.skolelinux.org/pere/blog/tags/standard
">standard (39)</a></li>
322 <li><a href="http://people.skolelinux.org/pere/blog/tags/stavekontroll
">stavekontroll (3)</a></li>
324 <li><a href="http://people.skolelinux.org/pere/blog/tags/stortinget
">stortinget (5)</a></li>
326 <li><a href="http://people.skolelinux.org/pere/blog/tags/surveillance
">surveillance (13)</a></li>
328 <li><a href="http://people.skolelinux.org/pere/blog/tags/sysadmin
">sysadmin (1)</a></li>
330 <li><a href="http://people.skolelinux.org/pere/blog/tags/valg
">valg (7)</a></li>
332 <li><a href="http://people.skolelinux.org/pere/blog/tags/video
">video (35)</a></li>
334 <li><a href="http://people.skolelinux.org/pere/blog/tags/vitenskap
">vitenskap (4)</a></li>
336 <li><a href="http://people.skolelinux.org/pere/blog/tags/web
">web (26)</a></li>
342 <p style="text-align: right
">
343 Created by <a href="http://steve.org.uk/Software/chronicle
">Chronicle v4.4</a>