blob: 04735d61b47a37571ca3fd8c29b9d11b5aaa10c4 [file] [log] [blame]
Lennart Poetteringd657c512012-01-25 02:20:38 +01001systemd System and Service Manager
Lennart Poettering31cee6f2010-05-13 03:30:21 +02002
3DETAILS:
4 http://0pointer.de/blog/projects/systemd.html
5
6WEB SITE:
7 http://www.freedesktop.org/wiki/Software/systemd
8
9GIT:
Kay Sievers9fa2f412012-01-22 18:40:13 +010010 git://anongit.freedesktop.org/systemd/systemd
11 ssh://git.freedesktop.org/git/systemd/systemd
Lennart Poettering31cee6f2010-05-13 03:30:21 +020012
13GITWEB:
Kay Sievers9fa2f412012-01-22 18:40:13 +010014 http://cgit.freedesktop.org/systemd/systemd
Lennart Poettering31cee6f2010-05-13 03:30:21 +020015
16MAILING LIST:
17 http://lists.freedesktop.org/mailman/listinfo/systemd-devel
18 http://lists.freedesktop.org/mailman/listinfo/systemd-commits
19
20IRC:
21 #systemd on irc.freenode.org
22
23BUG REPORTS:
24 https://bugs.freedesktop.org/enter_bug.cgi?product=systemd
25
26AUTHOR:
Lennart Poettering5430f7f2012-04-12 00:20:58 +020027 Lennart Poettering
28 Kay Sievers
29 ...and many others
Lennart Poettering31cee6f2010-05-13 03:30:21 +020030
Lennart Poettering673eab92011-07-14 23:53:53 +020031LICENSE:
Lennart Poettering5430f7f2012-04-12 00:20:58 +020032 LGPLv2.1+ for all code
33 - except sd-daemon.[ch] and sd-readahead.[ch] which are MIT
Kay Sievers7c09aaf2012-04-14 19:25:28 +020034 - except src/udev/ which is GPLv2.0+
Lennart Poettering673eab92011-07-14 23:53:53 +020035
Lennart Poettering31cee6f2010-05-13 03:30:21 +020036REQUIREMENTS:
Lennart Poetteringb7f44df2011-11-01 13:52:28 +010037 Linux kernel >= 2.6.39
Kay Sievers713bc0c2013-03-06 19:36:39 +010038 CONFIG_DEVTMPFS
39 CONFIG_CGROUPS (it's OK to disable all controllers)
40 CONFIG_INOTIFY_USER
41 CONFIG_SIGNALFD
42 CONFIG_TIMERFD
43 CONFIG_EPOLL
44 CONFIG_HOTPLUG
45 CONFIG_SYSFS
46
47 Udev will fail to work with the legacy layout:
48 CONFIG_SYSFS_DEPRECATED*=n
49
50 Legacy hotplug slows down the system and confuses udev:
51 CONFIG_UEVENT_HELPER_PATH=""
52
53 Userspace firmware loading is deprecated, will go away, and
54 sometimes causes problems:
55 CONFIG_FW_LOADER_USER_HELPER=n
56
57 Some udev rules and virtualization detection relies on it:
58 CONFIG_DMIID
59
60 Mount and bind mount handling might require it:
61 CONFIG_FHANDLE
62
63 Optional but strongly recommended:
64 CONFIG_IPV6
65 CONFIG_AUTOFS4_FS
66 CONFIG_TMPFS_POSIX_ACL
67 CONFIG_TMPFS_XATTR
68
69 For systemd-bootchart a kernel with procfs support and several
70 proc output options enabled is required:
71 CONFIG_PROC_FS
72 CONFIG_SCHEDSTATS
73 CONFIG_SCHED_DEBUG
74
Kay Sieversc1c8ca82010-11-26 20:48:29 +010075 dbus >= 1.4.0
Lennart Poettering3ede8352011-02-16 19:09:11 +010076 libcap
Tom Gundersene3043162012-11-20 01:24:32 +010077 libblkid >= 2.20 (from util-linux) (optional)
78 libkmod >= 5 (optional)
Lennart Poettering3ede8352011-02-16 19:09:11 +010079 PAM >= 1.1.2 (optional)
80 libcryptsetup (optional)
81 libaudit (optional)
Zbigniew Jędrzejewski-Szmek19d5d4c2011-07-12 13:57:48 +020082 libacl (optional)
Lennart Poetteringfb0951b2012-10-16 22:58:07 +020083 libattr (optional)
Lennart Poettering3ede8352011-02-16 19:09:11 +010084 libselinux (optional)
Zbigniew Jędrzejewski-Szmek19d5d4c2011-07-12 13:57:48 +020085 liblzma (optional)
Lennart Poettering3ede8352011-02-16 19:09:11 +010086 tcpwrappers (optional)
Lennart Poettering7b17a7d2012-09-28 00:46:32 +020087 libgcrypt (optional)
88 libqrencode (optional)
89 libmicrohttpd (optional)
Zbigniew Jędrzejewski-Szmek2cc86f02012-11-22 15:30:50 +010090 libpython (optional)
91 make, gcc, and similar tools
Lennart Poettering3ede8352011-02-16 19:09:11 +010092
Zbigniew Jędrzejewski-Szmek2cc86f02012-11-22 15:30:50 +010093 During runtime you need the following additional dependencies:
94
Tom Gundersenc3d2d862012-11-25 21:59:00 +010095 util-linux >= v2.19 (requires fsck -l, agetty -s)
96 sulogin (from util-linux >= 2.22 or sysvinit-tools, optional but recommended)
Zbigniew Jędrzejewski-Szmek2cc86f02012-11-22 15:30:50 +010097 dracut (optional)
Lennart Poettering46ba8aa2013-02-13 22:56:43 +010098 PolicyKit (optional)
Zbigniew Jędrzejewski-Szmek2cc86f02012-11-22 15:30:50 +010099
100 When building from git you need the following additional dependencies:
Lennart Poettering3ede8352011-02-16 19:09:11 +0100101
Lennart Poettering3ede8352011-02-16 19:09:11 +0100102 docbook-xsl
103 xsltproc
104 automake
105 autoconf
106 libtool
Zbigniew Jędrzejewski-Szmek19d5d4c2011-07-12 13:57:48 +0200107 intltool
Michael Bieblb62cfce2011-08-03 17:09:55 +0200108 gperf
Zbigniew Jędrzejewski-Szmek19d5d4c2011-07-12 13:57:48 +0200109 gtkdocize (optional)
110 python (optional)
Zbigniew Jędrzejewski-Szmek9015fa62013-02-09 15:37:35 -0500111 sphinx (optional)
Lennart Poettering21bc9232011-02-23 01:12:07 +0100112
Lennart Poetteringfff2e5b2011-05-17 19:35:56 +0200113 When systemd-hostnamed is used it is strongly recommended to
114 install nss-myhostname to ensure that in a world of
Thomas Hindoe Paaboel Andersenedca2e22012-11-05 21:13:28 +0100115 dynamically changing hostnames the hostname stays resolvable
Lennart Poetteringfff2e5b2011-05-17 19:35:56 +0200116 under all circumstances. In fact, systemd-hostnamed will warn
Kay Sieversbf9e4772013-01-24 10:31:34 +0100117 if nss-myhostname is not installed.
Lennart Poetteringfff2e5b2011-05-17 19:35:56 +0200118
Lennart Poettering6705c2d2011-08-24 23:29:28 +0200119 Note that D-Bus can link against libsystemd-login.so, which
Ville Skyttä49f43d52012-07-15 11:41:40 +0300120 results in a cyclic build dependency. To accommodate for this
Lennart Poettering6705c2d2011-08-24 23:29:28 +0200121 please build D-Bus without systemd first, then build systemd,
122 then rebuild D-Bus with systemd support.
123
Zbigniew Jędrzejewski-Szmek9015fa62013-02-09 15:37:35 -0500124 To build HTML documentation for python-systemd using sphinx,
125 please first install systemd (using 'make install'), and then
126 invoke sphinx-build with 'make sphinx-<target>', with <target>
127 being 'html' or 'latexpdf'. If using DESTDIR for installation,
128 pass the same DESTDIR to 'make sphinx-html' invocation.
129
Lennart Poetteringa24c64f2013-03-05 18:53:21 +0100130USERS AND GROUPS:
Lennart Poettering37495ee2013-03-05 19:15:31 +0100131 Default udev rules use the following standard system group
132 names, which need to be resolvable by getgrnam() at any time,
133 even in the very early boot stages, where no other databases
134 and network are available:
135
136 tty, dialout, kmem, video, audio, lp, floppy, cdrom, tape, disk
Kay Sievers37c0e8f2013-03-05 19:04:48 +0100137
Lennart Poetteringa24c64f2013-03-05 18:53:21 +0100138 During runtime the journal daemon requires the
Michael Biebl1a9ce3f2013-03-05 19:19:26 +0100139 "systemd-journal" system group to exist. New journal files will
Lennart Poetteringa24c64f2013-03-05 18:53:21 +0100140 be readable by this group (but not writable) which may be used
141 to grant specific users read access.
142
143 It is also recommended to grant read access to all journal
144 files to the system groups "wheel" and "adm" with a command
145 like the following in the post installation script of the
146 package:
147
148 # setfacl -nm g:wheel:rx,d:g:wheel:rx,g:adm:rx,d:g:adm:rx /var/log/journal/
149
Lennart Poettering37495ee2013-03-05 19:15:31 +0100150 The journal gateway daemon requires the
Michael Biebl1a9ce3f2013-03-05 19:19:26 +0100151 "systemd-journal-gateway" system user and group to
Lennart Poettering37495ee2013-03-05 19:15:31 +0100152 exist. During execution this network facing service will drop
153 privileges and assume this uid/gid for security reasons.
154
Lennart Poettering21bc9232011-02-23 01:12:07 +0100155WARNINGS:
156 systemd will warn you during boot if /etc/mtab is not a
157 symlink to /proc/mounts. Please ensure that /etc/mtab is a
158 proper symlink.
159
160 systemd will warn you during boot if /usr is on a different
161 file system than /. While in systemd itself very little will
Lennart Poetteringed1c99f2011-03-04 03:58:52 +0100162 break if /usr is on a separate partition many of its
Lennart Poettering21bc9232011-02-23 01:12:07 +0100163 dependencies very likely will break sooner or later in one
164 form or another. For example udev rules tend to refer to
165 binaries in /usr, binaries that link to libraries in /usr or
166 binaries that refer to data files in /usr. Since these
167 breakages are not always directly visible systemd will warn
168 about this, since this kind of file system setup is not really
169 supported anymore by the basic set of Linux OS components.
Lennart Poetteringfc7a7442011-03-01 23:44:26 +0100170
Lennart Poetteringaa167132011-03-04 05:07:01 +0100171 For more information on this issue consult
172 http://freedesktop.org/wiki/Software/systemd/separate-usr-is-broken
173
Zbigniew Jędrzejewski-Szmek1b4bb4f2012-10-12 12:56:19 +0000174 To run systemd under valgrind, compile with VALGRIND defined
175 (e.g. ./configure CPPFLAGS='... -DVALGRIND=1'). Otherwise,
176 false positives will be triggered by code which violates
177 some rules but is actually safe.