Want to start, stop, and manage services on your Linux box? Then you
need to familiarize yourself with Upstart and take control of your
startup and boot processes on Linux.
When Linux boots up, the first process that runs is called
BSD, System V, Upstart and systemd
You might think that the way that the system starts would be fairly
well-agreed upon between Linux distributions. Unfortunately, that's not
been the case and may not be the case for some time.
Linux isn't directly derived from UNIX, but it takes a lot of ideas from UNIX, including the way that the system starts. Some Linux distros, most notably Slackware, used the BSD-style init. Slackware (and its derivatives) is the lone holdout for this style these days, and it includes a System V init compatibility workaround so that applications that expect to support System V init scripts can install them normally.
System V (from UNIX System V), the precursor to was the standard for most Linux distros for many years. Distros using SysV init would have several directories under
What's a runlevel, you ask? Essentially this is the grouping of services that are run by init. For example, runlevel 0 is "halt," runlevel 1 or S are the "single user mode," and runlevel 6 is reboot. On Fedora/Red Hat systems, runlevel 3 is a full set of services to run a multiuser system (networking, etc.), and runlevel 5 includes multiuser services and X11 with the display manager. You'll notice I didn't mention 2 or 4, because those runlevels are rarely used and runlevel 4 isn't even defined by default.
Note that you can switch between runlevels using the
Under each of the directories, you'd have a set of symbolic links that point back to scripts that include startup and shutdown directives for services like Apache and the SSH daemon. Each link has a name like
So now we have, or had, Upstart as the emerging standard. For now, Upstart is the sort-of standard for several distros. Upstart is used by Ubuntu, current Fedora releases, and openSUSE 11.3 includes it as an optional package. But the Fedora folks are working on a replacement for Upstart called systemd, which is a "system and session manager" that is meant to be a "drop-in replacement for sysvinit." There's a very detailed discussion of the rationale behind systemd by Lennart Poettering that is an interesting read if you're interested in the deep details. So at some point, you'll need to know Upstart or systemd, or both if you are managing systems using Upstart and systemd.
For now, we're going to look at Upstart.
For applications managed with Upstart, you'll first want to look at the
To see what's running on your system, use
To stop a job that's running, use
For jobs that are managed by Upstart, you can edit their configuration file under
If you're using a desktop system, you'll want to install the Boot-up Manager — a GUI tool for handling runlevel configuration. The package is
Note that Fedora uses Upstart in SysV compatibility mode, which means that a lot of jobs on Fedora are not managed with native Upstart scripts. For those jobs you'll want to use the
To see the status of all jobs on Fedora using
This will show which jobs are stopped, running, and in a few instances much more information. For example, iptables will spit out its entire set of policies that are running at the moment.
To manage a job with
If you want to tweak the services by runlevel, use the
What if you want to add a service or modify the scripts for existing services? One quick and dirty way is to use
Typically, this is unnecessary — almost any service that you'll be using should have init scripts pre-written. Writing an init script, whether for Upstart or for SysV, is a bit outside the scope of this tutorial.
Since many users are going to be transitioning to systemd, we'll take a longer look at managing jobs with systemd when Fedora 15 comes out.
Most of the time, your interaction with managing services should be minimal unless you're working with Linux as a full-time admin. If you are doing system administration, or planning to, you should already be familiar with the init system that your distros are using. If not, now's a good time to learn. If you're a desktop Linux user, you probably won't be managing services very often, but it's a good to know the basics that we've covered here in case you need to do any troubleshooting or just want to fine-tune your system.
Ref: https://www.linux.com/learn/tutorials/404619-manage-system-startup-and-boot-processes-on-linux-with-upstart
https://www.linux.com/learn/tutorials/524577
When Linux boots up, the first process that runs is called
init
. From there, init
takes the task of starting up system processes. But which init
? Turns out, there are several flavors of init
,
and it depends on which Linux distribution you're using and how modern
the release is. Let's take a look at some of the backstory.
BSD, System V, Upstart and systemd init
, Oh My...
You might think that the way that the system starts would be fairly
well-agreed upon between Linux distributions. Unfortunately, that's not
been the case and may not be the case for some time.Linux isn't directly derived from UNIX, but it takes a lot of ideas from UNIX, including the way that the system starts. Some Linux distros, most notably Slackware, used the BSD-style init. Slackware (and its derivatives) is the lone holdout for this style these days, and it includes a System V init compatibility workaround so that applications that expect to support System V init scripts can install them normally.
System V (from UNIX System V), the precursor to was the standard for most Linux distros for many years. Distros using SysV init would have several directories under
/etc
such as rc0.d
, rc1.d
, through rc6.d
for each runlevel — though many of the runlevels are not really implemented.What's a runlevel, you ask? Essentially this is the grouping of services that are run by init. For example, runlevel 0 is "halt," runlevel 1 or S are the "single user mode," and runlevel 6 is reboot. On Fedora/Red Hat systems, runlevel 3 is a full set of services to run a multiuser system (networking, etc.), and runlevel 5 includes multiuser services and X11 with the display manager. You'll notice I didn't mention 2 or 4, because those runlevels are rarely used and runlevel 4 isn't even defined by default.
Note that you can switch between runlevels using the
telinit
command, like so: telinit 3
would switch to runlevel 3, and telinit 6
would tell the system to reboot. Note that you would usually want to just use reboot
instead to reboot, but telinit 6
would also work.Under each of the directories, you'd have a set of symbolic links that point back to scripts that include startup and shutdown directives for services like Apache and the SSH daemon. Each link has a name like
KNNsshd
or SNNcups
, where the NN
determines the order in which services are killed (K) or started (S).
This became tricky with laptops and mobile systems, because the state of
a computer might determine the order in which services should be
started. See the rationale
for Upstart by Scott James Remnant for more detail — but the short of
it is that the SysV style init that served Linux well for many years
became rather fragile and creaky when Linux adapted to use as a notebook
OS as much as a server OS.So now we have, or had, Upstart as the emerging standard. For now, Upstart is the sort-of standard for several distros. Upstart is used by Ubuntu, current Fedora releases, and openSUSE 11.3 includes it as an optional package. But the Fedora folks are working on a replacement for Upstart called systemd, which is a "system and session manager" that is meant to be a "drop-in replacement for sysvinit." There's a very detailed discussion of the rationale behind systemd by Lennart Poettering that is an interesting read if you're interested in the deep details. So at some point, you'll need to know Upstart or systemd, or both if you are managing systems using Upstart and systemd.
For now, we're going to look at Upstart.
Managing Startup Services
Now, when we're talking about startup services, I mean the system-wide services like SSH and Apache, not the applications started up by your desktop. That's a whole different kettle of fish, and depends on the desktop that you're using. For example, if you're running a recent Linux distro with GNOME, you'll look at System -> Preferences -> Startup Applications.For applications managed with Upstart, you'll first want to look at the
initctl
command. This allows you to work with Upstart's init
daemon. Naturally, you're going to need to use sudo
to run initctl
or be logged in as root.To see what's running on your system, use
initctl list
. You'll see something like this:alsa-mixer-save stop/waiting
avahi-daemon start/running, process 690
mountall-net stop/waiting
rc stop/waiting
rsyslog start/running, process 482
screen-cleanup stop/waiting
tty4 start/running, process 859
udev start/running, process 334
upstart-udev-bridge start/running, process 304
ureadahead-other stop/waiting
This is from a system running Ubuntu 10.10, you'll see a different list
of jobs on Fedora 14 or another distro. The first field is the name of
the job — like rsyslog
. The second field is the "goal" of the job, followed by the state of the job.To stop a job that's running, use
initctl stop job
. To start a job, run initctl start job
. You can also request status of jobs with initctl status job
. Finally you can restart or reload jobs with the restart
and reload
commands. What's the difference between restarting and reloading?
Restarting does what it says on the tin — stops the job and then
restarts it. The reload
command sends the SIGHUP
signal to the job, which can be used to tell a daemon to re-read its configuration.For jobs that are managed by Upstart, you can edit their configuration file under
/etc/init
. They will have a few lines that describe which runlevels to start/stop on like so:start on runlevel [2345]
stop on runlevel [!2345]
Change the runlevels as necesary.If you're using a desktop system, you'll want to install the Boot-up Manager — a GUI tool for handling runlevel configuration. The package is
bum
, and it will let you manage jobs and configure
services by runlevel. It's simple to use, and shouldn't require a lot of
guidance.Note that Fedora uses Upstart in SysV compatibility mode, which means that a lot of jobs on Fedora are not managed with native Upstart scripts. For those jobs you'll want to use the
service
command.To see the status of all jobs on Fedora using
service
run:service --status-all
This will show which jobs are stopped, running, and in a few instances much more information. For example, iptables will spit out its entire set of policies that are running at the moment.
To manage a job with
service
use service servicename command
. The servicename
is the name of the configuration script under /etc/init.d
. For example, to start and stop the openSSH daemon, you'll use service sshd start
or service sshd stop
.If you want to tweak the services by runlevel, use the
chkconfig
command. You'd use something like chkconfig --level 35 cups on
to tell chkconfig
to make sure that cups is started in runlevels 3 and 5.What if you want to add a service or modify the scripts for existing services? One quick and dirty way is to use
/etc/rc.local
. The script should be run during any startup or change of runlevel. Another way is to modify the scripts under /etc/init.d
(for SysV compatibility) or /etc/init
(native Upstart scripts) or write your own for a new service.Typically, this is unnecessary — almost any service that you'll be using should have init scripts pre-written. Writing an init script, whether for Upstart or for SysV, is a bit outside the scope of this tutorial.
Since many users are going to be transitioning to systemd, we'll take a longer look at managing jobs with systemd when Fedora 15 comes out.
Most of the time, your interaction with managing services should be minimal unless you're working with Linux as a full-time admin. If you are doing system administration, or planning to, you should already be familiar with the init system that your distros are using. If not, now's a good time to learn. If you're a desktop Linux user, you probably won't be managing services very often, but it's a good to know the basics that we've covered here in case you need to do any troubleshooting or just want to fine-tune your system.
Ref: https://www.linux.com/learn/tutorials/404619-manage-system-startup-and-boot-processes-on-linux-with-upstart
https://www.linux.com/learn/tutorials/524577
No comments:
Post a Comment