How To
This guide covers how to get Vagrant and Ansible running together on Windows 10 using WSL (Windows Subsystem for Linux), such that they use VirtualBox on the Windows host.
Action | Steps |
---|---|
Install Git on Windows |
|
Install VirtualBox on Windows |
|
Install WSL on Windows 10 Pro |
|
Install Ubuntu 18.04 LTS from Windows Store |
|
Configure VS Code to use WSL in the Integrated Terminal |
|
Install Python and PIP in WSL |
|
Install Ansible in WSL |
|
Install Vagrant in WSL |
|
Configure Vagrant in WSL to Use VirtualBox on Windows |
|
Clone my Demo GitHub Repository |
|
Start the VM in VirtualBox using Vagrant |
|
Verify VM was Provisioned |
|
Stop and Destroy the VM |
|
Helpful Links
- https://docs.microsoft.com/en-us/windows/wsl/install-win10
- https://pip.pypa.io/en/stable/installing/
- https://www.vagrantup.com/downloads.html
- https://www.vagrantup.com/docs/other/wsl.html
- https://www.digitalocean.com/community/tutorial_series/getting-started-with-configuration-management
- https://github.com/erikaheidi/cfmgmt
This article is just a collection of my personal notes while I work through using OpenStack in my new role.
General
OpenStack components can be divided into control, network, and compute.
- Control runs API services, web interfaces, databases, and message bus.
- Network runs service agents for networking.
- Compute is the virtualization hypervisor.
All components use a database and/or a message bus.
- Databases can be MySQL, MariaDB, or PostgreSQL.
- Message buses can be RabbitMQ, Qpid, and ActiveMQ.
Everything in OpenStack must exist in a tenant/project.
Tenants/projects are simply groupings of objects; and users, instances, networks, etc. are examples of objects.
In order to launch an instance, four components are essential:
- Keystone
- Glance
- Neutron
- Nova
Keystone
Keystone manages tenants/projects, users, roles, and catalogs services and endpoints for all components running in a cluster.
- Users must be granted a role in a tenant/project.
- A user cannot log in to a cluster unless they are a member of a tenant/project.
- Even the users the OpenStack components use to communicate with each other have to be members of a tenant to be able to authenticate.
Keystone uses username & password authentication to request tokens, and then uses these tokens for future requests.
Glance
Glance is the image management component.
Before a compute node instance is started, a Glance image is copied and cached onto the ephemeral disk of the new instance.
Glance images are “sealed-disk” images that have had things like SSH host keys and MAC addresses removed.
- This is done so that they can be used repeatedly without interfering with each other.
- Missing host specific information is generated at boot time via a post booting configuration facility named cloud-init.
Cloud-init is a script that is ran post boot to connect back to a metadata service.
Glance images can be found online by searching for a distributions’ name combined with “cloud image”.
To save time, custom images can be created with software “baked” into it. For example, if a LAMP or MEAN stack was required, that software can be pre-installed in the cloud image to reduce time spent setting those items up after deploying the instances.
Custom images can be made by configuring a virtual machine manually. Host specific information is removed, cloud-init is included, and an image is created.
Alternative tools for creating custom cloud images are:
- virt-install
- Oz
- appliance-creator
Neutron
Neutron is the network management component.
Neutron provides an API frontend that manages the SDN (Software Defined Networking) infrastructure.
Using Neutron allows each tenant/project to have its own virtual isolated network.
Each isolated network can be connected to a virtual router to create routes between them.
A virtual router can have an external gateway connected to it — so that when each instance has a floating IP it can have external access to a larger network or the internet.
Traffic sent to a floating IP address is routed through Neutron to an active/launched instance.
The capabilities of Neutron can be referred to as NaaS (Network as a Service).
A hard definition for NaaS would be: “Providing networks and network resources on demand via software.”
Open vSwitch (a virtually managed switch) is a commonly used virtualized networking infrastructure.
Physically managed switches can also be used in place of virtual ones to handle the virtual networks managed by Neutron.
Nova
Nova is the instance management component.
An SSH key pair and a security group must be configured before launching a Nova instance.
A security group is a firewall at the cloud infrastructure layer. It prevents access from anything not within the same security group from making connections outside of the security group.
General (cont.)
Once Keystone has tenants & roles, Glance has a cloud image, a Neutron network is created, an SSH key pair has been made, and a security group is established, a new Nova instance can be started.
The following are the steps taken when a new Nova instance is being launched:
- Resource identifiers are provided to Nova.
- Nova reviews what resources are being used on each hypervisor.
- Nova schedules a new instance to spawn on a compute node.
- The compute node gets a Glance image, creates all necessary virtual network devices, and boots the instance.
- During boot, cloud-init is run and connects to the metadata service.
- The metadata service provides the SSH public key needed for SSH logins to the instance.
- Any post boot configurations are ran.
Cinder
Cinder is the block storage management component.
Volumes can be created and attached to instances.
Block devices can be partitioned; and have filesystems created, formatted, and mounted on them.
Cinder handles snapshots as well.
Several storage backends can be used with Cinder to store volumes and snapshots:
- LVM (Logical Volume Manager)
- GlusterFS
- Ceph
Swift
Swift is the object storage management component.
Object storage is a simple content-only storage system — files are stored without the metadata that a block filesystem uses.
Two layers are used as part of Swift’s deployment:
- Proxy
- Storage Engine
The proxy is an API layer — it communicates with the storage engine on the user’s behalf.
The default storage engine is the Swift storage engine, but GlusterFS and Ceph can also be used.
Ceilometer
Ceilometer is the telemetry component.
It collects resource measurements and is able to monitor the cluster.
It was originally designed for billing users by metering the system, but it evolved into a general purpose telemetry system.
A meter is called a “sample“.
Samples get recorded on a regular basis; and a collection of samples is called a “statistic“.
Statistics can give insights into how resources are being used on an OpenStack deployment.
Alarms can be made with the samples.
Heat
Heat is the orchestration component.
Orchestration is the process of launching multiple instances that are supposed to work together.
Templates are used to define what will be launched during orchestration.
Heat is compatible with AWS CloudFormation templates and implements additional features beyond their template language.
When a template is launched it creates a collection of virtual resources (instances, networks, storage devices, etc.) — referred to as a “stack“.
It is important to note that Heat is not CM (configuration management). It is used for orchestration.
Heat can execute simple post boot configurations, such as invoking an actual CM to do more complex configurations.
RDO using TripleO
One of the easiest ways to get started using OpenStack is to use RDO (http://rdoproject.org/).
TripleO stands for “OpenStack on OpenStack”; and it is intended to deploy an all-in-one OpenStack installation, which is then used as a provisioning tool for a multi-node OpenStack deployment.
The two OpenStacks are called the undercloud and the overcloud.
The undercloud is the baremetal management all-in-one OpenStack installation.
The overcloud is the target deployment of OpenStack that is meant to be provided to end users.
The undercloud can take a cluster of nodes provided to it and deploy the overcloud on them.
Preface
These are my sloppy personal notes as I prepare to take the final Linux+/LPIC1 exam. This will be replaced (in time) with better notes.
Display Managers
LightDM
- LightDM’s main configuration file is
/etc/lightdm/lightdm.conf
:- The main section is:
[SeatDefaults]
- Common options within this section include:
greeter-session=name
— sets a greeter (i.e. a welcome screen).- The
name
value is the name of the*.desktop
file in the/usr/share/xgreeters/
directory.
- The
user-session=name
— sets a user environment (i.e. a desktop environment).- The
name
value is the name of the*.desktop
file in the/usr/share/xsessions/
directory.
- The
allow-guest=true
— enables guest login.greeter-show-manual-login=true
— shows a field to type in a username.greeter-hide-users=true
— hides user selection.autologin-user=user
— automatically logs in as user.autologin-user-timeout=30
— automatic logs in after 30 seconds.
/etc/lightdm/lightdm.conf.d/
contains many sub-configuration files.
- The main section is:
GDM3
- Main configuration file is
/etc/gdm3/custom.conf
:[daemon]
section:AutomaticLoginEnable=True
— enables automatic login.AutomaticLogin=user
— auto login as user.WaylandEnable=false
— disables Wayland and uses Xorg X11 instead.
[security]
section:DisallowTCP=false
— re-enables TCP, useful for X11Forwarding without SSH.
X
- Protocol is XDMCP (X Display Manager Control Protocol)
on port 177 UDP incomming and ports 6000-6005 TCP bidirectional. - Five XDMCP servers are common:
- XDM
- KDM
- GDM
- LightDM
- MDM
xorg.conf file
- Major sections
- Module
- InputDevice
- Monitor
- Device
- Screen
- ServerLayout
- Module handles loading X server modules via Load.
- InputDevice configures the keyboard and mouse.
- Identifier is a label.
- Driver is the driver to be used for the device (ex.
kbd, mouse, Keyboard, evdev, etc.). - Option sets various options for the device (ex.
Device, Protocol, AutoRepeat, etc.). - Device is usually one of these:
- “/dev/input/mice”
- “/dev/input/mouse1”
- “/dev/usb/usbmouse”
- “/dev/ttyS0”
- “/dev/ttyS1”
- Protocol is the signal X can expect from
the mouse movements and button presses.- “Auto”
- “IMPS/2”
- “ExplorerPS/2”
- “PS/2”
- “Microsoft”
- “Logitech”
- InputDevice configures the keyboard and mouse.
- Monitor section can specify HorizSync, VertRefresh, and
Modeline of the monitor.- Identifier and ModelName can be anything you want.
- HorizSync is in kilohertz (kHz).
- VertRefresh is in hertz (Hz).
- Modeline can be acquired from
cvt <h-resolution> <v-resolution> <refreshRate>
. - A new modeline can be added with
xrandr --newmode <modeline>
. - Monitor name can be retrieved with `xrandr -q`.
- Device section typically defines the video card being used.
- Identifier, VendorName, and BoardName can be anything
you want. - Driver can be any of the modules that exist in
/usr/lib/xorg/modules/drivers/. VideoRam
isn’t necessary to define, but it’s the
amount of RAM in kilobytes.
- Identifier, VendorName, and BoardName can be anything
- Screen section defines the combination of monitor and
video cards being used.- Identifier can be anything.
- Device must match the Identifier from the Device section.
- Monitor must match the Identifier from the Monitor section.
- DefaultDepth is the default SubSection to use based on color depth (32 bit is the greatest depth possible).
- SubSection “Display” defines a display option X may use.
- Depth is the color depth in bits.
- Modes is the modeline (generated by `cvt`)
- EndSubSection completes a subsection.
- ServerLayout section links all the other sections together.
- Identifier can be anything you want.
- Screen is the Identifier(s) in the Screen section.
- InputDevice is the Identifier(s) in the InputDevice
section.
- Files section is used to add fonts and font paths.
- FontPath will define a path to look for fonts.
Fonts
- Font paths can be added in the
xorg.conf
file using the Files section, appended withxset fp+ </font/directory>
, or prepended withxset +fp </font/directory>
. - To have linux re-examine the font path, use
xset fp rehash
. - Available fonts may be checked using the
xfontsel
command. - Font servers can be added to the
xorg.conf
File section (ex.FontPath "tcp/test.com:7100"
). - Default fonts can be adjusted in KDE by typing
systemsettings
in a terminal.
Accessibility
- AccessX was the common method for enabling/editing accessibility options. It has been deprecated but is specifically mentioned on the exam.
- Sticky keys make modifier keys “stick” when pressed, and affect the next regular key to be pressed.
- Can be enabled on GNOME by pressing
shift
key five times in a row.
- Can be enabled on GNOME by pressing
- Toggle keys play a sound when the locking keys are pressed.
- Mouse keys enables the numpad to act as a mouse.
- Bounce/Debounce keys prevent accidentally pressing a single key multiple times.
- Slow keys require a key to be held longer than a set period of time for it to register a key press.
- Keyboard Repeat Rate determines how quickly a key repeats when held down.
- Time Out sets a time to stop accessibility options automatically.
- Simulated Mouse Clicks can simulate a mouse click whenever the cursor stops moving, or simulate a double click whenever the mouse button is pressed for an extended period.
- Mouse Gestures activate program options by moving your mouse in a specific pattern.
- Sticky keys make modifier keys “stick” when pressed, and affect the next regular key to be pressed.
- GNOME On-Screen Keyboard (GOK) was the onscreen option for GNOME desktop, but has been replaced with Caribou.
- Default fonts can be adjusted in KDE by typing
systemsettings
in a terminal. kmag
can be used to start the KMag on-screen magnifier.- Speech synthesizers for Linux include:
- Orca — integrated in GNOME 2.16+.
- Emacspeak — similar to Orca.
- The BRLTTY project provides a Linux daemon to redirect text-mode console output to a Braille display.
- Since kernel 2.6.26, direct support for Braille displays exists on Linux.
Cron Jobs
- Syntax is:
- Minute of hour (0-59)
- Hour of day (0-23)
- Day of month (1-31)
- Month of year (1-12)
- Day of week (0-7)
0
and7
are both Sunday.
- Note: Values may be separated by commas or divided by a number (ex.
*/15
or0,15,30,45
).
/etc/cron.allow
determines which users are allowed to create cron jobs./etc/cron.deny
blocks listed users from creating cron jobs.- System cron jobs are run from the
/etc/crontab
file.- Crontab syntax is:
moh hod dom moy dow user command
- Crontab syntax is:
- Scripts can be placed within the following directories to be automatically processed by the entries in the crontab file:
/etc/cron.hourly/
/etc/cron.daily/
/etc/cron.weekly/
/etc/cron.monthly/
- On Debian systems, any files within the
/etc/cron.d/
directory are treated as additional crontab files. - User cron jobs are stored in a file at
/var/spool/cron/crontabs/user
. - Use the
crontab
command to edit the jobs in the /var/spool/cron/crontabs/ directory.-u
specifies the user.-l
lists all current jobs.-e
edits the crontab file.-r
removes the current crontab.-ir
interactive prompts for removal
at
at
will execute commands at a specified time.- Do not directly pass a command to the
at
command.- First enter the
at
command with a specified time. - An interactive
at>
prompt will appear. - Enter all commands desired.
- Press
^d
to send the EOF input to complete the job submission.
- First enter the
- Accepts the following time strings:
now|hh am|hh pm + value minutes|hours|days|weeks
today
tomorrow
HHMM
HH:MM
MMDD[CC]YY
MM/DD/[CC]YY
DD.MM.[CC]YY
[CC]YY-MM-DD
- Examples:
at 4pm + 3 days
at 10am Jul 31
at 1am tomorrow
-m
send mail to the user when the job completes.-M
never mail the user.-f
read the job from a file.-t
run the job at a specific time.- [[CC]YY]MMDDhhmm[.ss]
-l
list all jobs queued.- Alias for
atq
.
- Alias for
-r
remove a job.- Alias for
atrm
.
- Alias for
-d
delete a job.- Alias for
atrm
.
- Alias for
- Do not directly pass a command to the
atq
queries and lists all jobs currently scheduled and their job IDs.atrm
removes jobs by ID.- Access to the
at
command can be restricted with/etc/at.allow
and/etc/at.deny
.
anacron
- Similar to cron but runs periodically when available, rather than at specific times. This makes it useful for systems that are not running continuously.
/var/spool/anacron
is where timestamps from anacron jobs are stored.- When
anacron
is executed, it reads a list of jobs from a configuration file at/etc/anacrontab
.- Each job specifies:
- Period in days
@daily
@weekly
@monthly
- numeric value
1-30
- Delay in minutes
- Unique job identifier name
- Shell commands
- Example:
1 5 cron.daily run-parts --report /etc/cron.daily
7 10 cron.weekly run-parts --report /etc/cron.weekly
@monthly 15 cron.monthly run-parts --report /etc/cron.monthly
- Period in days
-f
forces execution of jobs, regardless of timestamps.-u
updates the timestamps without running.-s
serialize jobs — a new job will not start until the previous one is finished.-n
now — run jobs immediately (implies-s
as well).-d
don’t fork to background — output informational messages to STDERR, as well as syslog.-q
quiet messages to STDERR when using-d
.-t
specify a specific anacrontab file instead of the default.-T
tests the anacrontab file for valid syntax.-S
specify the spooldir to store timestamps in. Useful when running anacron as a regular user.
- Each job specifies:
run-parts
- Executes scripts within a directory.
- Used often in crontab and anacrontab to execute scripts within the cron.daily, cron.weekly, cron.monthly, etc. directories.
Time
- Linux uses Coordinated Universal Time (UTC) internally.
- UTC is the time in Greenwich, England, uncorrect for daylight savings time.
Timezone
- Linux uses the
/etc/localtime
file for information about its local time zone./etc/localtime
is not a plain-text file, and is typically a symlink to a file in/usr/share/zoneinfo/
.- Example:
$ ll /etc/localtime
lrwxrwxrwx 1 root root 35 Jun 24 03:02 /etc/localtime -> /usr/share/zoneinfo/America/Phoenix
- Example:
- Debian based distributions also use
/etc/timezone
to store text-mode time zone data. - Redhat based distributions also use
/etc/sysconfig/clock
to store text-mode time zone data. - A user can set their individual timezone using the TZ environment variable.
export TZ=:/usr/share/zoneinfo/timezone
- std offset can be used in place of
:/usr/share/zoneinfo
.- When daylight savings is not in effect.
std offset
- Ex.
MST+3
- When daylight savings is in effect:
- std offset dst[offset],start[/time],end[/time]
- Ex.
MST+3EST,M1.19.0/12,M4.20.0/12
- When daylight savings is not in effect.
Locale
- A locale is a way of specifying the machine’s/user’s language, country, and other information for the purpose of customizing displays.
- Locales take the syntax of:
[language[_territory][.codeset][@modifier]]
- language is typically a two or three-letter code (
en
,fr
,ja
, etc.) - territory is typically a two letter code (
US
,FR
,JP
, etc.). - codeset is often
UTF-8
,ASCII
, etc. - modifier is a locale-specific code that modifies how it works.
- language is typically a two or three-letter code (
- Locales take the syntax of:
- The
locale
command can be used to view your current locale.LC_ALL
is kind of like a master override — if it is set, all otherLC_*
variables are overridden by it.LANG
will be used as a default for anyLC_*
variables that are not set.- Setting
LANG=C
prevents programs from passing their output through locale translations.
- Setting
locale -a
shows all available locales on the system.
- The
iconv
command can be used to convert between character sets.iconv -f encoding [-t encoding] [inputfile]...
-f
is the source encoding.-t
is the destination encoding.
- Ex.
iconv -f iso-8859-1 -t UTF-8 german-script.txt
hwclock
hwclock
is used to synchronize the hardware clock with the system clock.-r
/--show
will show the current hardware clock time:Thu 02 Aug 2018 01:46:09 AM MST -0.329414 seconds
-s
/--hctosys
will set system time from hardware clock.-w
/--systohc
will set the hardware clock from system time.
date
date
displays the current date and time.- Accepted datetime format is
MMDDhhmm[[CC]YY][.ss]]
-d
/--date=
sets the date and time.- Defaults to
now
if not used.
- Defaults to
-s
/--set=
sets time to provided value.-u
/--utc
/--universal
print or set time in Coordinated Universal Time (UTC).
- Output can be formatted with
date +"%format"
:%a
– abbreviated weekday name (Mon
)%A
– non-abbreviated weekday name (Monday
)%b
– abbreviated month name (Jan
)%B
– non-abbreviated month name (January
)%c
– locale’s date and time (Thu Aug 2 00:10:29 2018
)%C
– century (20
)%d
– day of month (01
)%D
– date; same as%m/%d/%y
(8/2/18
)%e
– day of month with space padding; same as%_d
(01
)%F
– full date; same as%Y-%m-%d
(2018-8-2
)%H
– hour (00 - 23
)%I
– hour (01 - 12
)%j
– day of year (001 - 366
)%k
– hour with space padding; same as%_H
(21
)%l
– hour with space padding; same as%_I
(09
)%m
– month (01 - 12
)%M
– minute (00 - 59
)%n
– newline%N
– nanoseconds%p
– locale’s equivalent ofAM/PM
%P
– same as%p
, but lowercase%q
– quarter of year (1 - 4
)%r
– locale’s 12 hour clock (12:16:43 AM
)%R
– 24 hour clock; same as%H:%M
(00:16
)%s
– seconds since January 1st, 1970 UTC%S
– second (00 - 60
)%t
– tab%T
– time; same as %H:%M:%S (00:23:53
)%u
– day of week (1 - 7
);1
is Monday%U
– week number of year, starting on Sunday (00 - 53
)%w
– day of week (0 - 6
);0
is Sunday%W
– week number of year, starting on Monday (00 - 53
)%x
– locale’s date representation (8/2/18
)%X
– locale’s time representation (00:19:43
)%y
– last two digits of year (00 - 99
)%Y
– year%z
– +hhmm numeric time zone (-0400
)%Z
– time zone abbreviation (MST
)- Example:
date +"%A %B %d, %Y - %I:%M:%S %p"
Thursday August 02, 2018 – 12:30:45 AM
NTP
- The NTP daemon is responsible for querying NTP servers listed in
/etc/ntp.conf
.- Example:
server 0.centos.pool.ntp.org iburst
server 1.centos.pool.ntp.org iburst
server 2.centos.pool.ntp.org iburst
server 3.centos.pool.ntp.org iburst
- Example:
- The
ntpdate
command synchronizes time with the NTP servers but is deprecated in favor ofntpd -gq
.- Note:
ntpd
must be stopped in order forntpd -gq
to work:ntpd: time slew -0.011339s
- Note:
- The
ntp.drift
file is responsible for adjusting the system’s clock as clock drift occurs, and is typically stored in/var/lib/ntp/
or/etc/
. - The
ntpq
command opens an interactive mode for ntpd, with anntpq>
prompt.ntpq> peers
shows details about the NTP servers in use.refid
is the server to which each system is synchronized.st
is the stratum number of the server.- Note:
ntpq -p
/ntpq --peers
functions the same without being in an interactive prompt.
ssh
ssh-add
is used to add an RSA/DSA key to the list maintained by ssh-agent (ex. ssh-add ~/.ssh/id_rsa).- Enabled port tunneling with ‘
AllowTcpForwarding yes
‘.
gpg
- Generated keys are stored in
~/.gnupg
.
Printing
- Ghostscript translates PostScript into forms that can be understood by your printer.
- The print queue is managed by the Common Unix Printing System (CUPS).
- Users can submit print jobs using
lpr
. - Typically a print queue is located in
/var/spool/cups
. lpq -a
to display all pending print jobs on local and remote printers.
- qmail and Postfix are modular servers.
newaliases
command converts the aliases file to a binary format.
logs
logrotate
can be used to manage the size of log files.logger
is the command used to record to the system log.- Start syslogd with the
-r
option to enable acceptance of remote machine logs.
bash
/etc/profile
is the global configuration file for the bash
shell.
Network Addresses
- IP addresses can be broken into a network address and a computer address based on a netmask / subnet mask.
- Network address is a block of IP addresses that are used by one physical network.
- Computer address identifies a particular computer within that network.
- IPv4 addresses.
- 32 bits (4 bytes), binary.
- Represented as four groups of decimal numbers separated by dots
(ex.192.168.1.1
). - Classes are address ranges determined by a binary value of the leftmost digit.
00000001 - 01111111
=1 - 127
— Class A10000000 - 10111111
=128 - 191
— Class B11000000 - 11011111
=192 - 223
— Class C11100000 - 11101111
=224 - 239
— Class D11110000 - 11110111
=240 - 255
— Class E- If it starts with a
0
= Class A,1
= Class B,11
= Class C,111
= Class D,1111
= Class E
- Reserved private address spaces / RFC 1918 addresses are:
- Class A —
10.0.0.0 - 10.255.255.255
- Class B —
172.16.0.0 - 172.31.255.255
- Class C —
192.168.0.0 - 192.168.255.255
- Class A —
- Network Address Translation (NAT) routers can substitute their own IP address on outgoing packets from machines within a reserved private address space; effectively allowing any number of computers to hide behind a single IP address.
- Address Resolution Protocol (ARP) can be used to convert between MAC and IPv4 addresses.
- IPv6 addresses.
- 128 bits (16 byte), hexadecimal.
- Represented as eight groups of 4-digit hexadecimal values separated by colons
(ex.2001:4860:4860:0000:0000:0000:0000:8888
). - Two types of network addresses:
- Link-Local
- Nonroutable — can only be used for local network connectivity.
fe80:0000:0000:0000:
is the standard for IPv6 interfaces.
- Global
- Uses a network address advertised by a router on the local network.
- Link-Local
- Neighbor Discovery Protocol (NDP) can be used to convert between MAC and IPv6 addresses.
- Netmasks / subnet masks are binary numbers that identify which portion of an IP address is a network address and which part is a computer address.
1
= part of the network address.0
= part of the computer address.- They can be represented using dotted quad notation or Classless Inter-Domain Routing (CIDR) notation:
- Dotted Quad:
255.255.255.0
255
=11111111
— all eight bits are the network address.0
=00000000
— all eight bits belong to a computer address.
- CIDR:
192.168.1.1/24
- The number after the forward slash represents the number of bits belonging to the network address.
- To convert from
192.168.1.100/27
CIDR to dotted quad netmask:27
represents the number of bits with a value of1
, starting from the left-most digit:11111111 11111111 11111111 11100000
- Convert the binary values of each byte to decimal values:
11111111
= 128+64+32+16+8+4+2+1 =255
11100000
= 128+64+32 =224
- Put all of the decimal values in a dotted quad format:
255.255.255.224
- To convert from
255.255.192.0
dotted quad to CIDR:- Convert the decimal values to binary values:
255
=11111111
192
=11000000
- Math Tip
- Take
255
and subtract192
to get63
. - Since
63
is 1 less than64
, all bits below the 64th are1
(i.e.001111111
). - Subtract
11111111
(binary 255) by this value00111111
, to get11000000
.
- Take
- Math Tip
0
=00000000
- Place the binary values into one 32 bit string:
11111111 11111111 11000000 00000000
- Count the number of digits from the left with a value of
1
:18
- So the IP would be represented as
xxx.xxx.xxx.xxx/18
in CIDR notation.
- Convert the decimal values to binary values:
- Dotted Quad:
- Media Access Control (MAC) addresses represent unique hardware addresses.
- 48 bits (6 bytes), hexadecimal.
- A broadcast query is sent out to all computers on a local network and asks a machine with a given IP address to identify itself. If the machine is on the network it will respond with its hardware address, so the TCP/IP stack can direct traffic for that IP to the machine’s hardware address.
- Dynamic Host Configuration Protocol (DHCP).
ip
andifconfig
can both be used to add a new IPv6 address to a network interface.ifconfig promisc
configures the interface to run in promiscuous mode — receiving all packets from the network regardless of the packet’s intended destination.
Network Configuring
ifconfig
route
/etc/nsswitch.conf
Network Diagnostics
netstat
host
dig
netcat / nc
nmap
tracepath
traceroute / traceroute6
ping / ping6
/etc/services
- Provides a human-friendly mapping between internet services, their ports, and protocol types.
- Each line describes one service:
service-name port/protocol [aliases ...]
Ports & Services
- SNMP listens on port 162 by default.
User and Group Files
/etc/passwd
- Contains information about users, their IDs, and basic settings like home directory and default shell.
- One line for each user account, with seven fields separated by colons.
- Username
- Password
x
means the password is encrypted in the /etc/shadow file.
- UID
- GID
- Comment
- the user’s real name is generally stored here
- Home directory
- Default shell
- Examples:
root:x:0:0:root:/root:/bin/bash
jeff:x:1000:1000:jeff,,,:/home/jeff:/bin/bash
/etc/shadow
- Contains encrypted passwords and information related to password/account expirations.
- One line for each user account, with nine fields separated by colons.
- Username
- Encrypted password
*
means the account does not accept logins.!
means the account has been locked from logging in with a password.!!
means the password hasn’t been set yet.
- Last day the password changed (in days since January 1st, 1970).
- Min number of days to wait before a password change is allowed.
- Max number of days a password is valid for before a change is required.
- Password expiration occurs after this date.
- An expired password means the user must change their password to gain access again.
- Number of days to start showing warnings before the max date is reached.
- Number of inactive days allowed after password expiration.
- Account deactivation occurs after the inactive day is passed.
- A deactivated account requires a system admin to reinstate the account.
- Day when account expiration will occur (in days since January 1st, 1970).
- Reserved field that hasn’t been used for anything.
- Examples:
jeff:$9$eNcrYpt3D.23534e/ghlar2k.:17706:0:99999:7:::
sshd:*:17706:0:99999:7:::
/etc/group
- Contains information about groups, their ID, and their members.
- One line per group, with four fields separated by colons.
- Group name
- Password
x
means the password is encrypted in the/etc/gshadow
file.
- GID
- User list (comma separated)
- Examples:
jeff:x:1000:
sambashare:x:126:jeff
User & Group Commands
- The first 100 UID and GIDs are reserved for system use.
0
typically corresponds toroot
.
- The first normal user account is usually assigned a UID of
500
or1000
. - User and group numbering limits are set in the
/etc/login.defs
file.UID_MIN
andUID_MAX
defines the minimum and maximum UID value for an ordinary user.GID_MIN
andGID_MAX
work similarly for groups.
chage
- chage can set the password expiration information for a user.
-l
lists current account aging details.-d
/--lastday
sets the day that the password was last changed
(without actually changing the password).- Accepts a single number (representing the number of days since Jan 1st, 1970) or a value formatted in
YYYY-MM-DD
. 0
will force the user to change their password on the next login.
- Accepts a single number (representing the number of days since Jan 1st, 1970) or a value formatted in
-m
/--mindays
sets the number of days that must pass before a password can be changed.0
disables any waiting period.
-M
/--maxdays
sets the number of days before a password change is required.- Accepts a single value for the number of days.
-1
disables checking for password validity.
-W
/--warndays
sets when to start to displaying a warning message that a required password change is coming.-I
/--inactive
sets the number of days a password must be expired for the password to be marked inactive.- Accepts a single number.
-1
removes an account’s inactivity.
-E
/--expiredate
sets the account expiration date.- Accepts a single number or
YYYY-MM-DD
value. -1
removes the expiration date.
- Accepts a single number or
- If no options are provided to
chage
, it will interactively prompt for input to the various values it can set.
useradd / adduser (Debian)
- Doesn’t work as intended in Debian based distributions (because they’ve had a bug since forever and would rather you use a completely new command than get on board with standards… /rant), use
adduser
instead. - Creates new users or updates default new user details.
-D
/--defaults
use Default values for anything not explicitly specified in options.- Execute
useradd -D
without any other options to display the current defaults.GROUP=100
HOME=/home
INACTIVE=-1
EXPIRE=
SHELL=/bin/sh
SKEL=/etc/skel
CREATE_MAIL_SPOOL=no
- Execute
-d
/--home-dir
specify home directory.-e
/--expiredate
sets the expiration date of the account.YYYY-MM-DD
- Similar to
chage -E
-f
/--inactive
sets the number of days before making an account inactive after password expires.- Similar to
chage -I
- Similar to
-g
/--gid
group name or number for the user’s initial login group.- The group must already exist.
-G
/--groups
supplementary groups to add the user to.- Groups are separated by commas with no white space.
-m
/--create-home
creates the user’s home directory if it does not already exist.-M
/--no-create-home
explicitly specifies not to create the home directory for the user.- Overrides the
CREATE_HOME=yes
value in/etc/login.defs
, if set.
- Overrides the
-k
/--skel
specifies the skeleton directory to use.- The
-m
option must be used for this to work. - Without this option, it defaults to the
SKEL
variable value in/etc/default/useradd
.
- The
-K
/--key
sets UID_MIN, UID_MAX, UMASK, etc. KEY=VALUE option in the/etc/login.defs
file.-N
/--no-user-group
do not create a group with the same name as the user, but add the user to the group specified by the-g
option.-o
/--non-unique
allow creation of a user account with a duplicate UID- Must use the
-u
option to specify the UID to use.
- Must use the
-p
/--password
the encrypted password to use, as returned by thecrypt
command.- Not recommended to use due to plaintext password appearing in history.
-r
/--system
create a reserved system account.- No aging information in /etc/shadow, UID/GID are generated in reserved range.
-s
/--shell
specifies the user’s default shell. –- Default value is the SHELL variable in
/etc/default/useradd
.
- Default value is the SHELL variable in
-u
/--uid
specify the UID.-U
/--user-group
explicitly create a group with the same name as the user.
usermod
userdel
groupadd / addgroup (Debian)
groupmod
groupdel
newgrp
getent
getent
displays the contents of various Name Service Switch (NSS) libraries.- Supported libraries:
- ahosts
- ahostsv4
- ahostsv6
- aliases
- ethers
- group
- gshadow
- hosts
- initgroups
- netgroup
- networks
- passwd
- protocols
- rpc
- services
- shadow
- Supported libraries:
Sudoers
- Access to the
sudo
command is configured in the/etc/sudoers
file. visudo
is the recommended command to edit the/etc/sudoers
file — as it locks the file from other’s editing it at the same time.- Syntax for entries in the sudoers file:
username hostname = TAG: /command1, /command2, [...]
- Example:
ray rushmore = NOPASSWD: /bin/kill, /bin/ls, /usr/bin/lprm
- Tags:
PASSWD
/NOPASSWD
— require or not require the user to enter their password to usesudo
.EXEC
/NOEXEC
— allow or prevent executables from running further commands itself.- Example, shell escapes will be unavailable in
vi
withNOEXEC
.
- Example, shell escapes will be unavailable in
FOLLOW
/NOFOLLOW
— allow or prevent opening a symbolic link file.MAIL
/NOMAIL
— whether or not mail is sent when a user runs a command.SETENV
/NOSETENV
— use the values ofsetenv
or not on a per-command basis.
- Use of the
sudo
command is logged via syslog by default.
Preface
Generally it is recommended to forward X using SSH, as it provides an encrypted connection. However, on machines limited to a local network, tunneling through SSH results in a performance hit.
This article covers how to forward X without using SSH on Ubuntu 18.04.
Local machine = the machine you have access to and want to do work on.
Remote machine = the machine that will be running the applications.
Steps
- Enable X Server to listen via TCP on the local machine.
sudo vim /etc/X11/xinit/xserverrc
- Change:
exec /usr/bin/X -nolisten tcp "$@"
- To:
exec /usr/bin/X "$@"
- Change:
sudo vim /etc/gdm3/custom.conf
- Add
Enable=true
under the[xmdcp]
section. - Add
DisallowTCP=false
under[security]
section.
- Add
- Restart X on the local machine.
- There are several ways to accomplish this, here are a couple of easy ones:
sudo reboot
- Switch to a text mode and back to graphical mode:
sudo systemctl isolate multi-user.target
sudo systemctl isolate graphical.target
- There are several ways to accomplish this, here are a couple of easy ones:
- Add local hostname to hosts file on the remote machine.
sudo vim /etc/hosts
- Add:
ip_address hostname [aliases]
- Add:
- Add remote hostname to authorized xhosts on local machine.
xhost +hostname
- Export the DISPLAY environment variable on the remote machine to that of the local machine.
export DISPLAY=hostname:0.0
- Launch an X application via SSH or telnet when connected to the remote machine, and it should open on the local machine.
Example Screenshot
How To
By default, the kernel decides when to make the console go blank / black (usually 10 minutes / 600 seconds).
To check the current value:
$ cat /sys/module/kernel/parameters/consoleblank
To temporarily update the value:
$ setterm -blank <value>
Note: If the value is 0
, blanking will be disabled entirely.
To permanently update the value, use one of the following methods:
- Edit the Grub configuration files to include this kernel parameter:
consoleblank=0
- Create a startup script that contains:
setterm -blank <value>
CentOS 7
Changes to the kernel parameters can be made within the /etc/default/grub file
, within the GRUB_CMDLINE_LINUX
entry.
Example:
GRUB_CMDLINE_LINUX="[...] consoleblank=0"
To make this change effective:
# grub2-mkconfig -o /boot/grub2/grub.cfg
Note: If using EFI instead of MBR, use the following to make the change effective:
# grub2-mkconfig -o /boot/efi/EFI/centos/grub.cfg
CentOS 6
Changes to the kernel parameters can be made within the /etc/grub.conf file
, within the kernel
entry.
Example:
kernel [...] consoleblank=0
To make this change effective:
# grub-install <device/partition>
Note: Most of the time the device will be /dev/sda
but always double check.
Ubuntu
Changes to the kernel parameters can be made within the /etc/default/grub
file, within the GRUB_CMDLINE_LINUX_DEFAULT
entry.
Example:
GRUB_CMDLINE_LINUX_DEFAULT="[...] consoleblank=0"
To make this change effective:
# update-grub > /boot/grub/grub.cfg
Booting Linux and Editing Files
Exam Objectives
- 101.2 – Boot the system
- 101.3 – Change runlevels and shutdown or reboot system
- 102.2 – Install a boot manager
- 103.8 – Perform basic file editing operations using vi
Installing Boot Loaders
The machine’s boot process begins with a program called a boot loader.
Boot loaders work in different ways depending on the firmware used and the OS being booted.
The most used boot loader for Linux is the Grand Unified Boot Loader (GRUB).
GRUB is available in two versions:
- GRUB Legacy (versions 0 – 0.97)
- GRUB 2 (versions 1.9x – 2.xx)
An older Linux boot loader also exists, called the Linux Loader (LILO).
Boot Loader Principles
The computer’s firmware reads the boot loader into memory from the hard disk and executes it.
The boot loader is responsible for loading the Linux kernel into memory and starting it.
Note: Although the exam objectives only mention the Basic Input/Output System (BIOS) firmware, the Extensible Firmware Interface (EFI) and Unified EFI (UEFI) are becoming increasingly important.
BIOS Boot Loader Principles
The BIOS boot process varies depending on its many options.
The BIOS first selects a boot device to use (hard disk, USB stick, etc.).
If a hard disk is selected, the BIOS loads code from the Master Boot Record (MBR).
The MBR is located within the first sector (512 bytes) of a hard disk. This 512 bytes is broken up into:
- Bootloader assembly code – 446 bytes.
- Partition table for four (4) primary partitions – 64 bytes (16 bytes each).
- Sentinel value – 2 bytes (with a value of
0xAA55
if bootable).
The MBR contains the primary boot loader code.
The primary boot loader does one of two things:
- Examines the partition table, locates the partition that’s marked as bootable, and loads the boot sector from that partition to execute it.
- Locates an OS kernel, loads it, and executes it directly.
In the first instance, the boot sector contains a secondary boot loader, which ultimately locates an OS kernel to load and execute.
Linux’s most popular BIOS boot loaders (LILO and GRUB) can be installed in either the MBR or the boot sector of a boot partition.
Windows systems come with a boot loader that is installed directly to the MBR.
Note: Installing Windows alongside a Linux system will result in replacement of the MBR-based boot loader. To reactivate the Linux boot loader, Windows’ FDISK
utility can be used to mark the Linux partition as the boot partition.
On an MBR partitioning system, a primary partition must be used for storing a Linux partition’s boot sector. If the boot sector is located within a logical partition it can only be accessed via a separate boot loader in the MBR or a primary partition.
On disks that use the GUID Partition Table (GPT) partitioning system, GRUB stores part of itself within a special partition, known as the BIOS boot partition. On MBR disks, the equivalent code is stored in the sectors immediately following the MBR (which are officially unallocated in the MBR scheme).
Note: Occasionally a reference is made to the “superblock” when discussing BIOS boot loaders. The superblock is part of the filesystem; and describes basic filesystem features, such as the filesystem’s size and status. On BIOS-based computers, the superblock may hold a portion of the boot loader, and damage to it can cause boot problems. The debugfs
and dump2efs
commands can provide some superblock information.
EFI Boot Loader Principles
EFI is much more complex than the older BIOS.
Instead of relying on code stored within the boot sectors of a hard disk, EFI relies on boot loaders stored as files in a disk partition known as the EFI System Partition (ESP) — which uses the File Allocation Table (FAT) filesystem.
Within Linux, the ESP is typically mounted at /boot/efi
.
Inside of /boot/efi/EFI
are subdirectories named after the OS or boot loader being used (ex. ubuntu
, suse
, fedora
, etc.).
Those subdirectories contain boot loaders as .efi
files.
For example, /boot/efi/EFI/ubuntu/grub.efi
or /boot/efi/EFI/suse/elilo.efi
.
This configuration allows the option to store a separate boot loader for each OS that is installed on the machine.
EFI includes a boot manager to help select which boot loader to launch.
Note: The exam objectives use the terms boot loader and boot manager interchangeably. A boot loader loads a kernel into memory and passes control to it. A boot manager presents a menu of boot options. GRUB (and other programs) combine both functions, which may be the reason why many sources don’t differentiate between the two terms.
Boot loaders must be registered in order for EFI to use them. This can be done by either using a utility built into the firmware’s own user interface or by using a tool such as Linux’s efibootmgr
program.
Most x86-64
EFI implementations will use a boot loader called EFI/boot/bootx64.efi
on the ESP as a default if no others are registered. Removable disks typically store their boot loader using this name as well.
GRUB Legacy
GRUB is the default boot loader for most Linux distributions.
Configuring GRUB Legacy
/boot/grub/menu.lst
is the usual location for GRUB Legacy’s configuration file on a BIOS-based computer.
Some distributions (ex. Fedora, Red Hat, and Gentoo) use the filename grub.conf
in place of menu.lst
.
The GRUB configuration file can be broken into global and per-image sections.
Note: GRUB Legacy officially supports BIOS but not EFI. A heavily patched version, maintained by Fedora, provides support for EFI. If using this version of GRUB, its configuration file is located in the same directory on the ESP that houses the GRUB Legacy binary, such as /boot/efi/EFI/redhat
for a standard Fedora or Red Hat installation.
GRUB Nomenclature and Quirks
The following is an example GRUB configuration file:
# grub.conf/ menu.lst
#
# Global Options:
#
default=0
timeout=15
splashimage=/grub/bootimage.xpm.gz
#
# Kernel Image Options:
#
title Fedora (3.4.1)
root (hd0,0)
kernel /vmlinuz-3.4.1 ro root=/dev/sda5 mem=4096M
initrd /initrd-3.4.1
title Debian (3.4.2-experimental)
root (hd0,0)
kernel (hd0,0)/bzImage-3.4.2-experimental ro root=/dev/sda6
#
# Other operating systems
#
title Windows
rootnoverify (hd0,1)
chainloader +1
In the above example, Fedora exists on /dev/sda5
, Debian exists on /dev/sda6
, and Windows exists on /dev/sda2
. Debian and Fedora share a /boot
partition on /dev/sda1
, where the GRUB configuration resides.
GRUB doesn’t refer to disk drives by device filename the way Linux does. Instead, GRUB numbers drives (i.e. /dev/hda
or /dev/sda
becomes (hd0)
, and /dev/hdb
or /dev/sdb
becomes (hd1)
).
Note: GRUB also doesn’t distinguish between PATA, SATA, SCSI, and USB drives. On mixed systems, ATA drives are typically given the lowest drive numbers, but that is not guaranteed.
GRUB Legacy’s drive mappings can be found in the /boot/grub/device.map
file.
GRUB Legacy separates partition numbers from drive numbers with a comma. For example, (hd0,0)
for the first partition of the first hard disk (typically /dev/sda1
or /dev/hda1
in Linux), and (hd0,4)
for the first logical partition of the first hard disk (normally /dev/sda5
or /dev/hda5
).
Global GRUB Legacy Options
GRUB’s global section precedes its per-image configurations.
Common options in the global section:
Feature | Option | Description |
Default OS | default=<num> |
Specifies a default OS for GRUB to boot.
Note: Index starts at 0. |
Timeout |
|
The seconds GRUB will wait for user input before booting the default OS. |
Background Graphic |
|
Sets the Note: The file and path are relative to the GRUB root partition. If |
Global GRUB Legacy Per-Image Options
By convention, GRUB Legacy’s per-image options are often indented after the first line.
The options start with an identification followed by options that tell GRUB how to handle the image.
Common options in the per-image section:
Feature | Option | Description |
Title | title <label> |
The label to display on the boot loader menu.
|
GRUB Root | root <drive-nums> |
The location of GRUB Legacy’s root partition — which is the /boot partition if a separate partition is made for it.
ex. |
Kernel Specification | kernel <path> <options> |
The location of the Linux kernel, and any kernel options to be passed to it. The Note: Because the |
Initial RAM Disk | initrd <path> |
The <path> specifies the location of the initial RAM disk — which holds a minimal set of drivers, utilities, and configuration files that the kernel uses to mount its root filesystem before the kernel can fully access the hard disk.
Note: |
Non-Linux Root | rootnoverify <drive-nums> |
Similar to the root option, but GRUB Legacy will not try to access files on this partition.
This option is used to specify a boot partition for operating systems that GRUB Legacy can’t directly load a kernel for, such as Windows. ex. |
Chainloading | chainloader +<sector-num> |
Tells GRUB Legacy to pass control to another boot loader.
The |
Note: Chainloading on an EFI-enabled version of GRUB Legacy requires specifying the ESP as the root (typically root (hd0,0)
), and passing the name of an EFI boot loader file (ex. chainloader /EFI/Microsoft/boot/bootmgfw.efi
).
To add a kernel to GRUB:
- As
root
, openmenu.lst
orgrub.conf
in a text editor. - Copy a working configuration for a Linux kernel.
- Modify the
title
line with a unique name. - Modify the
kernel
line to point to the new kernel, and specify any kernel options. - Make appropriate changes to the
initrd
line (if adding, deleting, or changing aninitramfs
RAM disk). - Change the global
default
line to point to the new kernel (if desired). - Save changes and exit the text editor.
New kernel options in GRUB will appear in the menu after a reboot.
Installing GRUB Legacy
To install GRUB Legacy on a BIOS-based machine:
grub-install <device>
To install GRUB Legacy into the MBR (first sector of the first hard drive), <device>
can be set with either a Linux or GRUB style device identifier (/dev/sda
or '(hd0)'
).
To install GRUB Legacy into the boot sector of a partition instead, a partition identifier must be included with either the Linux or GRUB style device identifier (ex. /dev/sda1
or (hd0,0)
).
To install Fedora’s EFI-enabled version of GRUB Legacy, copy the grub.efi
file to a suitable directory in your ESP (ex. /boot/efi/EFI/redhat
), copy grub.conf
to the same location, and run the efibootmgr
utility to add the boot loader to the EFI’s list:
# efibootmgr -c -l [[backslash backslash]]EFI[[backslash backslash]]redhat[[backslash backslash]]grub.efi -L GRUB
The above command adds GRUB Legacy, stored in the ESP’s /EFI/redhat
directory, to the EFI’s boot loader list. Double backslashes ([[backslash backslash]]
) must be used instead of Linux style forward slashes (/
).
Note: If using Fedora’s grub-efi
RPM file, the grub.efi
file should be placed in this location by default.
Interacting with GRUB Legacy
GRUB Legacy will show a list of all of the operating systems that were specified with the title
option in the GRUB configuration file.
If the timeout expires, a default operating system will be booted.
To select an alternative to the default, use the arrow
keys to highlight the operating system desired and press the Enter
key.
To pass additional options to an operating system:
- Use the
arrow
keys to highlight the operating system. - Press
e
to edit the entry. - Use the
arrow
keys to highlight thekernel
option line. - Press
e
to edit the kernel options. - Edit the
kernel
line to add any options (such as1
to boot to single-user mode)2. GRUB Legacy passes the extra option to the kernel. - Press
Enter
to complete the edits. - Press
b
to start booting.
Note: Any changes can be made during step 5. For example, if a different init
program is desired, it can be changed by appending init=<program>
(ex. init=/bin/bash
) to the end of the kernel
line.
Note2: To get to single-user mode when booting Linux, 1
, S
, s
, or single
can be passed as an option to the kernel by the boot loader.
GRUB 2
The GRUB 2 configuration file is /boot/grub/grub.cfg
.
Note: Some distributions place the file in /boot/grub2
to allow simultaneous installations of GRUB Legacy and GRUB 2.
GRUB 2 adds features, such as:
- Support for loadable modules for specific filesystems and modes of operation.
- Conditional logic statements (enabling loading modules or displaying menu entries only if particular conditions are met).
The following is a GRUB 2 configuration file based on the previous example:
# grub.cfg
#
# Kernel Image Options:
#
menuentry "Fedora (3.4.1)" {
set root=(hd0,1)
linux /vmlinuz-3.4.1 ro root=/dev/sda5 mem=4096M
initrd /initrd-3.4.1
}
menuentry "Debian (3.4.2-experimental)" {
set root=(h0,1)
linux (hd0,1)/bzImage-3.4.2-experimental ro root=/dev/sda6
}
#
# Other operating systems
#
menuentry "Windows" {
set root=(hd0,2)
chainloader +1
}
Compared to GRUB Legacy, the important changes are:
title
changed tomenuentry
.- Menu titles are enclosed in quotes.
- Each entry has its options enclosed in curly braces (
{}
). set
is added before theroot
keyword, and an=
is needed to assign the root value to the partition specified.rootnoverify
has been eliminated,root
is used instead.- Partition numbers start from
1
rather than0
. However, a similar change is not implemented for disk numbers.
Note: GRUB 2 also supports a more complex partition identification scheme to specify the partition table type (ex. (hd0,gpt2)
for the second GPT partition, or (hd1,mbr3)
for the third MBR partition).
GRUB 2 makes use of a set of scripts and other tools to help automatically maintain the /boot/grub/grub.cfg
file.
Rather than edit the grub.cfg
file manually, files in /etc/grub.d/
and the /etc/default/grub
file should be edited. After making changes, the grub.cfg
file should be recreated explicitly with one of the following (depending on OS):
update-grub > /boot/grub/grub.cfg
grub-mkconfig > /boot/grub/grub.cfg
grub2-mkconfig > /boot/grub/grub.cfg
Note: The update-grub
, grub-mkconfig
, and grub2-mkconfig
scripts all output directly to STDOUT, which is why their output must be redirected to the /boot/grub/grub.cfg
file manually.
Files in /etc/grub.d/
control particular GRUB OS probers. These scripts scan the system for particular operating systems and kernel, and add GRUB entries to /boot/grub/grub.cfg
to support them.
Custom kernel entries can be added to the 40_custom
file — enabling support for locally compiled kernels or unusual operating systems that GRUB doesn’t automatically detect.
The /etc/default/grub
file controls the defaults created by the GRUB 2 configuration scripts.
To adjust the timeout:
GRUB_TIMEOUT=30
Note: A distribution designed to use GRUB 2, such as Ubuntu, will automatically run the configuration scripts after certain actions (ex. installation of a new kernel via the distribution’s package manager).
GRUB 2 is designed to work with both BIOS and EFI based machines.
Similar to GRUB Legacy, grub-install
is run after Linux is installed to set up GRUB correctly.
Note: On EFI-based machines, the GRUB 2 EFI binary file should be placed appropriately automatically. However, if there are problems, efibootmgr
can be used to fix them.
Alternative Boot Loaders
Although GRUB Legacy and GRUB 2 are the most dominant boot loaders for Linux (and the only ones covered on the exam), several other boot loaders are available:
Syslinux
The Syslinux Project (http://www.syslinux.org/) is a family of BIOS-based boot loaders, each of which is much smaller and more specialized than GRUB Legacy and GRUB 2.
The most notable member of this family is ISOLINUX, which is a boot loader for use on optical discs (which have unique boot requirements).
The EXTLINUX boot loader is another member of this family. It can boot Linux from an ex2, ext3, or ext4 filesystem.
LILO
The Linux Loader was the most common Linux boot loader in the 90s.
It works only on BIOS-based machines, and is quite limited and primitive by today’s standards.
If a Linux system uses LILO it will have a /etc/lilo.conf
configuration file present on the system.
The Linux Kernel
Since version 3.3.0, the Linux kernel itself has incorporated an EFI boot loader for x86 and x86-64 systems.
On an EFI-based machine, this feature enables the kernel to serve as its own boot loader, eliminating the need for a separate tool such as GRUB 2 or ELILO.
rEFIt
Technically a boot manager, and not a boot loader.
It presents an attractive graphical interface, which allows users to select operating systems using icons rather than text.
It’s popular on Intel-based Macs, but some builds can be used on UEFI-based PCs as well.
This program can be found at http://refit.sourceforge.net/, but has been abandoned since development stopped in 2010.
rEFInd
A fork of rEFIt, designed to be more useful on UEFI-based PCs with extended features.
It also provides features that are designed to work with the Linux kernel’s built-in EFI boot loader, to make it easier to pass options required to get the kernel to boot.
The homepage for the project is http://www.rodsbooks.com/refind/.
gummiboot
An open-source EFI boot manager that’s similar to rEFIt and rEFInd, but uses a text-mode interface with fewer options.
The project page is http://freedesktop.org/wiki/Software/gummiboot.
Secure Boot
Microsoft requires the use of a firmware feature called Secure Boot, which has an impact on Linux boot loaders.
With Secure Boot enabled, an EFI-based machine will launch a boot loader only if it has been cryptographically signed by a key whose counterpart is stored in the computer’s firmware.
The goal of Secure Boot is to make it harder for malware authors to take over a computer by placing malware programs early in the boot process.
The problem for Linux is use of Secure Boot requires one of the following:
- The signing of a Linux boot loader with Microsoft’s key (since it’s the only one guaranteed to be on most machines).
- The addition of a distribution-specific or locally generated key to the machine’s firmware.
- The disabling of Secure Boot.
Currently, both Fedora and Ubuntu can use Secure Boot.
Note: It may be necessary to generate a key, or disable Secure Boot, to boot an arbitrary Linux distribution or a custom-built kernel.
The Boot Process
Extracting Information About the Boot Process
The kernel ring buffer stores some Linux kernel and module log information in memory.
Linux displays messages destined for the kernel ring buffer during the boot sequence (those messages that scroll by way too fast to be read).
To inspect the information in the kernel ring buffer:
# dmesg
Note: Many Linux distributions store the kernel ring buffer in /var/log/dmesg
after the system boots.
Another important source for logging information is the system logger (syslogd
), which stores log files in /var/log
.
Some of the most important syslogd
files are:
/var/log/messages
/var/log/syslog
Note: Some Linux distributions also log boot-time information to other files. Debian uses a daemon called bootlogd
that logs any messages that go to /dev/console
to the /var/log/boot
file. Fedora and Red Hat use syslogd
services to log information to /var/log/boot.log
.
The Boot Process
The boot process of an x86 machine from its initial state to a working operating system is:
- The system is powered on, and a special hardware circuit causes the CPU to look at a predefined address and execute the code stored in that location — which is the firmware (BIOS or EFI).
- The firmware checks hardware, configures it, and looks for a boot loader.
- When the boot loader takes over, it loads a kernel or chainloads another boot loader.
- Once the Linux kernel takes over, it initializes devices, mounts the root partition, and executes the initial program for the system — giving it a process ID (PID) of
1
. By default, the initial program is/sbin/init
.
Loading Kernels and initramfs
When the kernel is being loaded it needs to load drivers to handle the hardware, but those drivers may not yet be accessible if the hard drive isn’t mounted yet.
To avoid this issue, most Linux distributions utilize an initramfs
file — which contains the necessary modules to access the hardware.
The boot loader mounts the initramfs
file into memory as a virtual root filesystem for the kernel to use during boot.
Once the kernel loads the necessary drivers, it unmounts the initramfs
filesystem and mounts the real root filesystem from the hard drive.
The Initialization Process
The first program that is started on a Linux machine (init
) is responsible for starting the initialization process.
The initialization process is ultimately responsible for starting all programs and services that a Linux system needs to provide for the system.
There are three popular initialization process methods used in Linux:
- Unix System V (SysV)
- Upstart
- systemd
The original Linux init
program was based on the Unix System V init
program, and became commonly referred to as SysV.
The SysV init
program uses a series of shell scripts, divided into separate runlevels, to determine what programs should run at what times.
Each program uses a separate shell script to start and stop the program.
The system administrator sets the runlevel at which the Linux system starts, which in turn determines which set of programs to run.
The system administrator can also change the runlevel at any time while the system is running.
The Upstart version of the init
program was developed as part of the Ubuntu distribution.
Upstart uses separate configuration files for each service, and each service configuration file sets the runlevel in which the service should start.
This method makes it so that there is just one service file that’s used for multiple runlevels.
The systemd program was developed by Red Hat, and also uses separate configuration files.
Using the SysV Initialization Process
The key to SysV’s initialization process is runlevels.
The init
program determines which service to start based on the current runlevel of the system.
Runlevel Functions
Runlevels are numbered from 0
to 6
, and each one is assigned a set of services that should be active for that runlevel.
Note: While most systems only allow runlevels 0
to 6
, some systems may have more. The /etc/inittab
file will define all runlevels on a system.
Runlevels 0
, 1
, and 6
are reserved for special purposes; and the remaining runlevels can be used for whatever purposes the Linux distribution decides:
Runlevel | Description |
0 |
Shuts down the system. |
1 (s , S , single ) |
Single-user mode. |
2 |
Multi-user mode on Debian (and derivatives). Graphical login screen with X running. Most other distributions do not define anything for this runlevel. |
3 |
Multi-user mode on Red Hat, Fedora, Mandriva, etc. Non-graphical (console) login screen. |
4 |
Undefined typically, and available for customization. |
5 |
Multi-user mode on Red Hat, Fedora, Mandriva, etc. Graphical login screen with X running. |
6 |
Reboots the system. |
Identifying the Services in a Runlevel
One way to affect what programs run when entering a new SysV runlevel is to add or delete entries in the /etc/inittab
file.
Basics of the /etc/inittab File
The entries within the /etc/inittab
file follow a simple format.
Each line consists of four colon-delimited fields:
<id>:<runlevels>:<action>:<process>
Field | Description |
Identification Code | The <id> field consists of a sequence of one to four characters that identifies its function. |
Applicable Runlevels | The <runlevels> field consists of a list of runlevels that applies for this entry (ex. 345 would apply to runlevels 3 , 4 , and 5 ). |
Action to Take |
Specific codes in the See Example codes:
|
Process to Run |
The Note: This field is omitted when using the |
The part of /etc/inittab
that tells init
how to handle each runlevel looks like:
l0:0:wait:/etc/init.d/rc 0
l1:0:wait:/etc/init.d/rc 1
l2:0:wait:/etc/init.d/rc 2
l3:0:wait:/etc/init.d/rc 3
l4:0:wait:/etc/init.d/rc 4
l5:0:wait:/etc/init.d/rc 5
l6:0:wait:/etc/init.d/rc 6
Each line begins with the letter l
, followed by the runlevel number.
These lines specify scripts or programs that are to be run when the specific runlevel is entered.
In the above example, all scripts are the same (/etc/init.d/rc
), but some distributions call specific programs for certain runlevels, such as shutdown
for runlevel 0
.
The SysV Startup Scripts
The /etc/init.d/rc
or /etc/rc.d/rc
script performs the crucial task of running all the scripts associated with the runlevel.
The runlevel-specific scripts are stored in one of the following locations:
/etc/init.d/rc?.d/
/etc/rc.d/rc?.d/
/etc/rc?.d/
The ?
represents the runlevel number.
When entering a runlevel, rc
passes the start
parameter to all of the scripts with names that begin with a capital S
, and it passes the stop
parameter to all of the scripts with names that begin with a capital K
.
These scripts are also numbered (ex. S10network
, K35smb
), and rc
executes the scripts in numeric order — allowing distributions to control the order in which scripts run.
The files in the SysV runlevel directories are actually symbolic links to the main scripts, which are typically stored in one of the following locations:
/etc/init.d/
/etc/rc.d/
/etc/rc.d/init.d/
These original SysV startup scripts do not have the leading S
or K
and number (ex. smb
instead of K35smb
).
Note: Services can also be started and stopped by hand. For example, /etc/init.d/smb start
will start the Samba server, and /etc/init.d/smb stop
will stop the Samba server. Other options such as restart
and status
can be used as well.
Managing Runlevel Services
The SysV startup scripts in the runlevel directories are symbolic links back to the original script.
This prevents the need to copy the same script into each runlevel directory, and allows the user to modify the original script in just one location.
By editing the link filenames, a user can modify which programs are active in a runlevel.
Various utilities are available to help manage these links:
chkconfig
update-rc.d
rc-update
chkconfig
To list the services and their applicable runlevels:
# chkconfig --list
The output will show each service’s runlevels with either an on
or off
state for each runlevel.
To check a specific service:
# chkconfig --list <service-name>
To modify the runlevels of a service:
# chkconfig --level <numbers> <service-name> <state>
<numbers>
is the runlevels desired.
<state>
is either on
, off
, or reset
— which sets the value to its default value.
If a new startup script has been added to the main SysV startup script directory, chkconfig
can be used to inspect the startup script for special comments that indicate default runlevels, and then add appropriate start and stop links in the runlevel directories:
# chkconfig --add <service-name>
Checking and Changing the Default Runlevel
On a SysV-based system, the default runlevel can be found by inspecting the /etc/inittab
file and looking for initdefault
.
An easy way to do this is with:
# grep :initdefault: /etc/inittab
id:3:initdefault:
To change the default runlevel for the next boot, edit the initdefault
line in /etc/inittab
.
Note: If a system lacks an /etc/inittab
file, one can be created manually that only has an initdefault
line to specify the desired default runlevel.
Determining the Current Runlevel
On a running system, the current runlevel can be found with:
# runlevel
The output will display either a number representing the system’s previous runlevel (ex. 5
), or the letter N
if no change has been made since boot time, followed by a number displaying the current runlevel.
An alternative option to finding the runlevel is:
# who -r
Changing Runlevels on a Running System
Changing runlevels on a running system can be done with the init
, telinit
, shutdown
, halt
, reboot
, and poweroff
commands.
Changing Runlevels with init or telinit
A user can have the system reread the /etc/inittab
file to implement any changes made, or to change to a new runlevel.
To change to a specific runlevel:
# init <runlevel>
For example, rebooting can be done with init 6
, and changing to single-user mode can be done with init 1
.
A variant of init
is telinit
.
telinit
works similarly to the way init
does, but it also takes a Q
/ q
option to reread the /etc/inittab
file and implement any changes it finds:
# telinit q
Note: telinit
is sometimes just a symbolic link to init
, and in practice, init
responds just like telinit
to the Q
/ q
options.
Changing Runlevels with shutdown
Rebooting or shutting down a machine with init
can have problems:
- The command is unintuitive for these actions.
- The action is immediate and provides no warning to other users.
The shutdown
command is preferred in this case:
# shutdown [<options>] <time> [<message>]
The most common options are:
Option | Description |
-r |
Reboot |
-H |
Halt (terminate operation but do not power off). |
-P |
Power off |
-c |
Cancel pending shutdown |
The <time>
parameter can set with:
now
hh:mm
(a time on a 24-hour clock)+<minutes>
The optional <message>
is placed within double quotes, and will display a message to all logged in users.
Note: The messages are sent using the wall
command behind the scenes. This command can be used manually by either piping output into it (ex. echo "this is a message" | wall
), or by entering the wall
command, followed by the text to display, and finally a ^d
character.
Once the desired time is reached, shutdown
will run init
to set the appropriate runlevel.
Note: If shutdown
is run without any options it will change runlevel to 1
(single-user mode).
Changing Runlevels with halt, reboot, and poweroff
halt
will terminate operation without powering down.
reboot
will restart the system.
poweroff
will terminate operation and power down.
Note: In most cases, reboot
and poweroff
are symbolic links to halt
.
Using the systemd Initialization Process
The systemd initialization process is becoming the preferred method in the Linux world; and is currently the default option for Red Hat, Fedora, CentOS, etc.
Instead of using many small initialization shell scripts, systemd uses one big program that uses individual configuration files for each service.
Units and Targets
Instead of using shell scripts and runlevels, the systemd method uses units and targets.
A systemd unit defines a service or action on the system
Each unit consists of a name, a type, and a configuration file.
There are eight different types of systemd units:
automount
device
mount
path
service
snapshot
socket
target
The systemd
program identifies units by their name and type using the format: name.type
.
The systemctl
command can be used to list the units currently loaded in a Linux system:
# systemctl list-units
The systemd method uses service-type units to manage the daemons on the Linux system.
The target-type units are important in grouping multiple units together, so that they can be started at the same time (ex. network.target
groups all units required to start the network interfaces for a system).
The systemd initialization process uses targets similarly to the way SysV uses runlevels.
Each target represents a different group of services that should be running on the system.
Instead of changing runlevels to alter what is running on a system, a user can change targets.
Note: To make the transition from SysV to systemd easier, there are targets that mimic the standard 0
to 6
SysV runlevels, called runlevell0.target
to runlevell6.target
.
Configuring Units
Each unit requires a configuration file that defines what program it starts and how it should start the program.
The systemd system stores unit configuration files in /lib/systemd/system/
.
This is an example configuration file for a sshd.service
file on CentOS 7:
[Unit]
Description=OpenSSH server daemon
Documentation=man:sshd(8) man:sshd_config(5)
After=network.target sshd-keygen.service
Wants=sshd-keygen.service
[Service]
Type=forking
PIDFile=/var/run/sshd.pid
EnvironmentFile=/etc/sysconfig/sshd
ExecStart=/usr/sbin/sshd $OPTIONS
ExecReload=/bin/kill -HUP $MAINPID
KillMode=process
Restart=on-failure
RestartSec=42s
[Install]
WantedBy=multi-user.target
Here is a brief breakdown of some of the lines in the above example file:
ExecStart
defines which program to start.
After
specifies what services should run before the sshd service starts.
WantedBy
defines what target level the system should be in to run the service.
Restart
determines what conditions need to be present to trigger reloading the program.
Target units also use configuration files — defining which service units to start.
This is an example of the graphical.target
configuration file on CentOS 7:
[Unit]
Description=Graphical Interface
Documentation=man:systemd.special(7)
Requires=multi-user.target
Wants=display-manager.service
Conflicts=rescue.service rescue.target
After=multi-user.target rescue.service rescue.target display-manager.service
AllowIsolate=yes
To breakdown the above example file:
After
determines which targets should be loaded first.
Requires
defines what targets are required for this target to start.
Conflicts
states which targets conflict with this target.
Wants
sets the required targets or services this target needs in order to run.
Setting the Default Target
The default target used when the system boots is defined in the default.target
file of the /etc/systemd/system/
directory.
The systemd
program looks for this file whenever it starts up.
Normally this file is a link to a standard target file in the /lib/systemd/system/
directory. For example:
[root@mg-ray-centos7 system]# ls -al default.target
lrwxrwxrwx. 1 root root 16 Dec 5 2016 default.target -> graphical.target
The systemctl Program
The systemctl
program is used to control services and targets within the systemd method.
systemctl
accepts several commands to define what action it will take:
Command | Description |
list-units |
Displays the current status of all configured units. |
default |
Changes the default target unit. |
isolate |
Starts the named unit and stops all others. |
start <name> |
Starts the named unit. |
stop <name> |
Stops the named unit. |
reload <name> |
The named unit reloads its configuration file. |
restart <name> |
Stops and starts the named unit. |
status <name/PID> |
Displays the status of the named unit. |
enable <name> |
Configures the unit to start on boot. |
disable <name> |
Prevents the unit from starting on boot. |
To change the target that is currently running, use the isolate
command:
# systemctl isolate rescue.target
# systemctl isolate graphical.target
Note: The systemd initialization process doesn’t use the standard Linux syslogd log filesystem. Instead, it uses its own log files that are not stored in text format. To view the systemd log files use journalctl
.
Boot Details
The systemd-analyze
command can be used to analyze how long each step of the boot process has taken:
$ systemd-analyze
To determine which services were loaded, and how long each individual service took to load:
$ systemd-analyze blame
Using the Upstart Initialization Process
Ubuntu and several other modern Linux distributions use an init
process called Upstart (http://upstart.ubuntu.com/).
Upstart provides SysV compatibility features; however, it also uses its own unique scripts and differs in some ways from SysV.
Upstart no longer uses a /etc/inittab
file, as it uses its own integrated set of startup scripts.
Upstart scripts also support starting and stopping services based on a wider variety of actions than SysV startup scripts. For example, Upstart can launch a service whenever a particular hardware device is attached.
Using Upstart-Native Methods
Upstart and its native scripts are located in the /etc/init/
(formerly /etc/event.d/
) directory — which replaces both the /etc/inittab
and runlevel-specific SysV startup script directory.
Note: Upstart is still under heavy development and its configuration file format is subject to change.
To change the runlevels in which a particular service runs, its configuration file will need to be edited.
Configuration files are typically found using the format /etc/init/<name>.conf
.
The start on
and stop on
lines within the configuration file determine when the service should be started and stopped.
To start or stop a service with Upstart, use the start
or stop
command (ex. start httpd
or stop smb
).
The initctl reload
command and option can be used to have Upstart reload its configuration files. This is useful before changing runlevels.
Using SysV Compatibility Methods
Because a large number of software packages still include SysV startup scripts, Upstart provides a compatibility mode.
Upstart can run SysV startup scripts in the usual locations (i.e. /etc/rc.d/rc?.d
, /etc/init.d/rc?.d
, /etc/rc?.d
, etc.)
This allows packages without Upstart configuration scripts to still start the way they used to on a SysV enabled system. Additionally, chkconfig
can be used to manage any SysV-based services.
Editing Files with vi
vi
was the first full-screen text editor written for Unix.
It is available by default with nearly every Linux distribution, and is often the only editor available on emergency boot systems.
It was designed to be small and simple, but it can be a bit unintuitive when coming from standard GUI text editors.
vi
uses three modes to operate. Once these modes are understood, using vi
becomes much easier.
Note: Many Linux distributions come with a variant of vi
called vim
(Vi IMproved). It supports more features than the original vi
, but their operation is largely the same.
Understanding vi Modes
Mode | Description |
Command |
Accepts commands, usually entered as single letters:
|
Ex |
Used to manipulate files (ex. saving, running external programs, etc.).
After running an ex-mode command, |
Insert |
Allows text to be entered.
Almost all keys are entered on screen, except the |
Note: The terminology for vi
modes can be inconsistent. For example, Command
mode is sometimes referred to as Normal
mode, and Insert
mode is sometimes called Edit
mode or Entry
mode. Ex
mode may also be just referred to as colon commands
instead of being called a mode.
Text-Editing and Saving
To open a file with vi
:
$ vi <file>
If tildes (~
) are present, they represent the end of a file; and are not blank lines.
The bottom line of the vi
editor window shows the status of the last command used.
Note: In vim
, the bottom line shows the status of the last command used, the current line and column number (<line>,<col>
), and the status of what is being displayed (Top
if the first line of the document is visible, Bot
if the last line of the document is visible, and All
if both the first and last line are visible).
Command
mode commands:
Command | Keys | Description |
Change Case | ~ |
Cycles through cases for the current character. |
Yank | yy
|
Yanks current line to buffer.
Yanks the current word to buffer. |
Paste Line | p P |
Pastes buffer to current line.
Pastes buffer before current line. |
Delete | dd
|
Deletes the current line. Deletes the current word. |
Change | cc
|
Changes the entire line. Changes a word. |
Undo | u |
Undo last change. |
Open Text | o |
Inserts a new line below the current one, and enters Insert mode. |
Insert Text | i a |
Changes to Insert mode at current position.
Appends a space to the end of the current position and changes to |
Search | /
|
Search forward.
Search behind. |
Go to Line | G<num> |
Go to a specific line number. |
Go to First Line | H |
Go to the first (home) line. |
Go to Last Line | L |
Go to the last line. |
Ex
mode commands:
Feature | Command | Description |
Edit New File | :e <file> |
Loads a new file.
Note: Only loads a new file if the existing one has been saved since its last change, or if using |
Include Existing File | :r <file> |
Includes the contents of an old file in an existing one. |
Execute External Command | :!<command> |
Executes the external command.
Ex. |
Regex Replace (Global) | :%s/original/replacement/g |
Replaces <original> with <replacement> throughout the file, starting on line <s> . |
Save | :w |
Writes / saves the file. |
Quit | :q |
Quits / exits the file. |
Save and Quit | :wq :ZZ |
Saves and quits the file. |
Booting Linux and Editing Files Essentials
- Describe how GRUB Legacy is configured and used.
- GRUB Legacy uses the
menu.lst
orgrub.conf
configuration file in/boot/grub/
. - This file contains global and per-image options.
- The
grub-install
program can be used to install this boot loader. - When GRUB boots, it presents a menu of OS options for selection using the arrow keys.
- GRUB Legacy uses the
- Describe how GRUB 2 is configured and used.
- GRUB 2 uses the
/boot/grub/grub.cfg
configuration file. - Instead of editing configuration files directly, automatic configuration scripts should be used.
- System-specific defaults can be set in
/etc/default/grub
and/etc/grub.d/
. - GRUB 2 can be installed using the
grub-install
program (same as GRUB Legacy).
- GRUB 2 uses the
- Describe the boot process.
- The CPU runs the firmware, firmware loads a boot loader, boot loader may chainload another boot loader, final boot loader loads a Linux kernel, kernel runs the initial system program
init
, andinit
starts the rest of the system services via startup scripts that are specific to the startup system (SysV, systemd, Upstart, etc.). - BIOS-based computers look for boot loaders in various boot sectors, include the MBR of the hard disk, or the boot sector of a disk partition.
- EFI-based machines look for boot loaders in files on the ESP.
- The CPU runs the firmware, firmware loads a boot loader, boot loader may chainload another boot loader, final boot loader loads a Linux kernel, kernel runs the initial system program
- Summarize where to look for boot-time log information.
- The
dmesg
command prints out logs from the kernel ring buffer, which holds boot-time and other kernel messages. - Other useful log information can be found in
/var/log/messages
and other files in/var/log/
.
- The
- Summarize the role of
/sbin/init
.- The
init
program is responsible for starting many programs and services on the Linux operating system.
- The
- Explain the SysV init system.
- The SysV init system uses a default runlevel specified with a line such as
id:3:initdefault:
in the/etc/inittab
file. - Commands such as
chkconfig
,update-rc.d
,ntsysv
, andsystemctl
can be used to change which services are started when switching to specific runlevels. - Runlevels
0
,1
, and6
are reserved for shutdown, single-user mode, and rebooting (respectively). - Runlevels
3
,4
, and5
are common runlevels on Red Hat-based distributions. - Runlevel
2
is the usual runlevel on Debian-based systems.
- The SysV init system uses a default runlevel specified with a line such as
- Describe how to change SysV init runlevels.
- The
init
program andtelinit
program can be used to change to other runlevels. - The
shutdown
,halt
,poweroff
, andreboot
commands are also useful to change runlevels for shutting off, halting, and rebooting a machine.
- The
- Explain the systemd init system.
- The systemd init system uses units and targets to control services.
- Targets are groups of services.
- The default target is specified by the
/etc/systemd/system/default.target
file, which is a symbolic link to a target file in the/lib/systemd/system/
directory.
- Describe how to change systemd init targets.
- The
systemctl
program can be used to start and stop services, as well as change the target level of the system.
- The
- Describe
vi
‘s three editing modes.Insert
mode allows the user to enter text.Command
mode is used to perform complex commands.Ex
mode is mostly used for saving files, but is also useful for some advanced features such as regular expression replacement and executing external commands.
Managing Files
Exam Objectives
- 103.3 – Perform basic file management
- 104.4 – Manage disk quotas
- 104.5 – Manage file permissions
- 104.6 – Create and change hard and symbolic links
- 104.7 – Find system files and place files in the correct location
Using File Management Commands
Unix-like systems, particularly Linux, treats almost everything as a file, including most hardware devices and various specialized interfaces.
Naming Files
Linux filenames can contain uppercase letters, lowercase letters, numbers, and most punctuation and control characters.
Filenames in Linux are case sensitive.
To avoid confusion, it is recommended to restrict any non-alphanumeric symbols in filenames to the period (.
), the hyphen (-
), and the underscore (_
).
Some programs create backup files that end in a tilde (~
).
Note: While filenames can contain spaces, they must be escaped on the command line with backslashes or by enclosing the entire filename in quotes (ex. “my picture.png
” or my\ picture.png
).
A few characters have special meaning and should never be used in filenames:
- asterisk (
*
) - question mark (
?
) - forward slash (
/
) — Note: cannot be used even with escaping. - backslash (
\
) - quotation mark (
"
)
The filename length depends on the filesystem in use. On ext2fs, ext3fs, ext4fs, XFS, Btrfs, and others, the limit is 255 characters in length.
Note: A single character requires 1 byte of storage. Therefore, the limit is often listed in bytes instead of characters. A 255-character file limit is often stated as a 255 byte limit.
Filenames beginning with a dot, often called “dot files” are hidden files; and they are generally used in a home directory for storing configuration files.
Note: If a FAT (File Allocation Table) filesystem is accessed using the msdos
filesystem type code it limits filenames to 8.3 style filenames. If the vfat
filesystem type code is used instead, Windows-style long filenames can be used. The umsdos
filesystem type code for Linux-style long filenames stopped being supported after the 2.6.11 kernel.
A filename that consists of a single dot (.
) refers to the current directory. A filename consisting of two dots (..
) refers to the parent directory.
Wildcard Expansion Rules
Wildcards can be used with many commands.
A wildcard is a symbol or set of symbols that stands for other characters.
Three classes of wildcards are common in Linux:
Wildcard | Matches | Example |
? |
Any single character | b??k would match: book , balk , buck , etc. |
* |
Any character or set of characters | b*k would match:book , buck , bk , backtrack , etc. |
[] |
Any single character or range of characters inside the square brackets | b[ae]k would match:bak andbek b[a-z]k would match:bak , bbk , bck , …, byk , and bzk |
Wildcards are implemented in the shell, and are passed to the command called with them. For example, calling ls b??k
would be the same as typing ls balk book buck
(assuming those three files existed in the current directory).
Wildcards expanding to form filenames is knows as file globbing, filename expansion, or simply globbing.
Understanding File Commands
The ls Command
The ls
command is short for “list”, and it displays the names of files within a directory:
ls [options] [files]
If the files
argument is omitted, ls
displays the contents of the current directory.
File globbing is often used with this command:
$ ls *.txt
myfile.txt backup.txt linux_notes.txt 1995.txt
By default, ls
creates a listing that is sorted alphabetically by filename.
Note: In the past, uppercase filenames appeared before lowercase letters. However, recent version of ls
sort in a case-insensitive manner.
One of the most common ls
options is -l
, which outputs a “long listing” — including the permissions, ownership, file size, file creation date, etc. in addition to the filenames.
The most commonly used options for ls
:
Feature | Option | Description |
Display All Files |
|
Displays all files, including hidden dot files. |
Long Listing | -l |
Displays file permissions, ownership, size, creation date, etc. |
Display File Type | -F |
Appends an indicator code to the end of the filename to identify its filetype:
|
Color Listing | --color |
Produces color-coded output to differentiate directories, symbolic links, files, etc. Note: No standardization exists for the colors used. |
Display Directory Names |
|
Lists only a directory’s name. Sometimes useful when file globbing for directories — as the files included in these directories are not displayed in the output. |
Recursive Listing | -R --recursive |
Displays the contents of a directory and the contents of any/all subdirectories within it. |
Note: The ls
command supports combining multiple options. For example, ls -al
instead of ls -a -l
.
The cp Command
The cp
command copies a file:
cp [options] <source> <destination>
The source
argument can be one or more files.
The destination
argument can be a directory when the source is one or more files.
When copying to a directory, cp
preserves the original filenames in the source
argument, unless new filenames are manually specified in the destination
argument.
Note: Placing a forward slash (/
) at the end of a directory is recommended — as this avoids accidentally copying a file to a new filename that’s a typo of the directory (ex. cp myfile.txt tmp/
would attempt to make a copy into the tmp/
directory, instead of copying the file to ./tmp
if the tmp/
directory doesn’t exist).
The most commonly used options for cp
:
Feature | Option | Description |
Force Overwrite |
-f |
Forces the system to overwrite any existing files without prompting. |
Use Interactive Mode |
|
Causes cp to ask before overwriting any existing files. |
Preserve Ownership and Permissions |
|
Preserves the ownership and permissions of the source file(s), instead of creating the copy with the ownership and permissions of the user that ran the |
Recursive Copy | -R |
Copies an entire directory and its subdirectories when the Note: Although |
Perform an Archive Copy |
|
Recursively copies files and links while preserving ownership. Unlike |
Perform an Update Copy | -u |
Copies only if the original is newer than the target, or if the target doesn’t exist. |
The mv Command
The mv
command is short for “move”, and is used for both moving files/directories and renaming them:
mv [options] <source> <destination>
The options for mv
are the same as cp
, except for --preserve
, --recursive
, and --archive
.
Note: If a move occurs on one low-level filesystem, Linux completes the action very quickly by rewriting directory entries; the file’s data is not read or rewritten. However, if the target directory is on another partition or disk, Linux must take more time to read the original file, rewrite it to the new location, and delete the original.
The rm Command
The rm
command stands for “remove”, and is used to delete a file or directory:
rm [options] <files>
All the options for cp
apply, with the exception of --preserve
, --archive
, and --update
.
Note: On rm
the -r
option is synonymous with -R
, unlike with the cp
command.
The touch Command
Linux-native filesystems maintain three time stamps for every file:
- Last file-modification time
- Last inode change time
- Last access time
Various programs rely on these time stamps. For example, the make
utility uses the time stamps to determine which source-code files must be recompiled if an object file already exists when compiling a program from source code.
The touch
command can be used to modify these time stamps:
touch [options] <files>
By default, touch
sets the modification and access times to the current time.
If a file passed to touch
doesn’t yet exist, it will create it.
The most commonly used options for touch
:
Feature | Option | Description |
Change Only the Access Time |
|
Changes the access time alone, not the modification time. |
Change Only the Modification Time | -m |
Changes the modification time alone, not the access time. |
Do Not Create File | -c |
Prevents |
Set the Time as Specified | -t <timestamp>
|
|
Archiving File Commands
A group of files can be collected into a single package file, called an archive.
Linux supports several archiving commands, the most prominent being tar
and cpio
.
The dd
command, although not technically an archiving command, is similar because it can copy an entire partition or disk into a file and vice versa.
Note: The zip format is supported on Linux via the zip
and unzip
commands.
Using tar
The tar
program is short for “tape archiver”, even though tapes are rarely used for storage these days:
tar [options] <archive> <files-to-archive>
Note: A hyphen (-
) is no longer put in front of tar
options.
Options consist of both commands and qualifiers.
Only one command is used at a time, and one or more qualifiers may be used with it.
tar
commands:
Command | Abbreviation | Description |
--create |
c | Creates an archive |
--concatenate |
A | Appends tar files to an archive |
--append |
r | Appends non-tar files to an archive |
--update |
u | Appends files that are newer than those in an archive |
--diff --compare |
d | Compares an archive to files on disk |
--list |
t |
Lists an archive’s contents |
--extract --get |
x |
Extracts files from an archive |
tar
qualifiers:
Qualifier | Abbrev. | Description |
--directory <dir> |
C |
Changes to the <dir> directory before performing operations. |
--file <[host:]file > |
f |
Uses the file called <file> on the machine called <host> as the archive file. |
--listed-incremental <file> |
g |
Performs an incremental backup or restore, using <file> as a list of previously archived files. |
--multi-volume |
M |
Creates or extracts a multi-volume archive. |
--preserve-permissions |
p |
Preserves all protection information. |
--absolute-paths |
P |
Retains the leading/ on filenames. |
--verbose |
v |
Lists all files read or extracted.
When used with |
--verify |
W |
Verifies after writing |
--gzip --ungzip |
z |
Compress with gzip |
--bzip2 |
j (older versions may use: I or y ) |
Compress with bzip2 |
--xz |
J |
Compress with xz |
The most commonly used commands are:
c
— create archivex
— extract archivet
— list archive
The most useful qualifiers are:
g
— perform incremental backupp
— keep permissionsz
— usegzip
compressionj
— usebzip2
compressionJ
— usexz
compressionv
— verbose output
Using cpio
The cpio
utility has three operating modes:
The most commonly used options for ls
:
Mode | Option | Description |
Copy-Out |
|
Creates an archive and copies files into it. |
Copy-In | -i |
Extracts data from an existing archive.
If a filename or pattern is provided as an argument, |
Copy-Pass | -p |
Combines copy-out and copy-in modes. |
Commonly used cpio
options:
Option | Abbrev. | Description |
--reset-access-time |
-a |
Resets the access time after reading a file so that it doesn’t appear to have been read. |
--append |
-A |
Appends data to an existing archive. |
--pattern-file=<filename> |
-E <filename> |
Uses the contents of <filename> as a list of files to be extracted in copy-in mode. |
--file=<filename> |
-F <filename> |
Uses <filename> as the cpio archive file.
If omitted, |
--format=<format> |
-H <format> |
Uses a specified format for the archive file. Common values for format:
|
-I <filename> |
Uses <filename> instead of standard input.
Note: Does not redirect output data like |
|
--no-absolute-filenames |
Extracts files relative to the current directory when in copy-in mode, even if filenames in the archive contain full directory paths. | |
-o <filename> |
Uses <filename> instead of standard output.
Note: Also does not redirect output data like |
|
--list |
-t |
Displays a table of contents for the input. |
--unconditional |
-u |
Replaces all files without first asking for verification. |
--verbose |
-v |
Displays filenames as they are added or extracted.
When combined with |
To use cpio
to archive a directory, a list of files must be passed using standard input (STDIN). One way to do this is by piping the STDOUT of the find
utility into the cpio
command:
$ find ./my-backups | cpio -o > ~/my-backup.cpio
The above file would be uncompressed, to compress the archive it could be further piped to gzip
or any other compression utility.
Using dd
The dd
utility is a low-level copying program. It can be used to archive an entire filesystem at a very low level:
# dd if=<file> of=<file>
The dd
utility can be used to create exact backups of entire partitions (including empty space).
If an empty file of a particular size is needed, the dd
utility can do that as well:
$ dd if=/dev/zero of=empty-file.img bs=1024 count=720
The bs
option is for block size, and count
is the length of the file (i.e. the above example creates a 1024 byte x 720 byte empty file).
Managing Links
A link in Linux gives a file multiple identities, and is similar to shortcuts in Windows and aliases in Mac OS.
A few reasons Linux uses links:
- Help make files more accessible.
- Give commands multiple names.
- Enable programs to access the same files when they look for the same files in different locations.
Two types of links exist:
- hard links
- symbolic links (soft links)
Hard links are made by creating two directory entries that point to the same inode / file.
Both filenames are equally valid and prominent; and neither is regarded as the “truer” filename over the other.
To delete the file, both hard links to the file must be deleted.
The filesystem must support hard links in order to use them; and all Linux-native filesystems support hard links.
Because of the way hard links are created, they must exist on a single low-level filesystem (i.e. hard links cannot be created across multiple mounted filesystems).
Symbolic links (soft links), are special file types.
A symbolic link is a separate file whose contents point to the linked-to file.
Because Linux knows how to access the linked-to file, accessing a symbolic link works just like accessing the original file in most respects.
Unlike hard links, symbolic links can point across low-level filesystems — as symbolic links are essentially files that contain filenames.
The lookup process for accessing the original file from the link consumes a tiny bit of time, so symbolic links are slower than hard links — but not enough that it would be noticed by anything other than very odd conditions or artificial tests.
The ln
command creates both types of links:
ln [options] <source> <link>
<source>
represents the original file, and <link>
is the name of the link to be created.
The options for ln
:
Feature | Option | Description |
Prompt Before Changes | -i --interactive |
Prompts before replacing existing files and/or links. |
Remove Target Files | -f --force |
Removes any existing links or files that have the target <link> name. |
Create Directory Hard Links | -d -F --directory |
Ordinarily, hard links cannot be created to directories.
The Note: In practice, this feature is unlikely to work because most filesystems don’t support it. |
Create a Symbolic Link | -s --symbolic |
Creates a symbolic link instead of a hard link. |
Note: by default, the ln
command will create a hard link.
To determine if a file has any hard links to it, check the link count number within the output of ls -l
:
$ ls -l /home/jeff/*.txt
-rwxr--r--. 3 jeff alchemists my-file.txt
In the above output, my-file.txt
has 3
hard links to the same inode / file.
To get the exact inode number that a file is hard linked to, use the -i
option with the ls
command:
$ ls -i /home/jeff/*.txt
519205 my-file.txt
In the above example, my-file.txt
‘s inode number is 519205
.
Unlike with hard links, symbolic links do not increase a file’s link count number.
Symbolic links can be identified with ls -l
:
$ ls -l /home/jeff/links/
-rw-rw-r--. 1 jeff alchemists a-normal-file.txt
lrwxrwxrwx. 1 jeff alchemists a-link-file -> linked-file.txt
Symbolic links show both an l
for the file type code, as well as an arrow ->
to show where the symbolic link points to.
Understanding Directory Commands
Using mkdir
The mkdir
command creates a new directory:
mkdir [options] <directory-names>
The options for mkdir
:
Feature | Option | Description |
Set Mode | -m <mode> --mode=<mode> |
Sets the permissions of a new directory to the desired octal values. |
Create Parent Directories | -p --parents |
Creates all necessary parent directories for the new directory, if they do not already exist. |
Using rmdir
The rmdir
command removes directories:
rmdir [options] <directory-names>
Note: rmdir
can only remove empty directories. If any files are present, it will generate an error.
The options for rmdir
:
Feature | Option | Description |
Ignore Failures on Non-Empty Directories |
--ignore-fail-on-non-empty |
Prevents error messages from being displayed when attempting to remove non-empty directories.
Note: use |
Delete Tree | -p --parents |
Deletes directory and all parents, recursively.
Note: directories must be empty. |
Managing File Ownership
Security for files is built on file ownership and file permissions.
Accessing File Ownership
Each file has an individual owner and a group that it is associated with.
$ ls -l example-dir/
-rwxrw-r--. 1 jeff alchemists my-file.txt
The owner of this file is jeff
, and the group of this file is alchemists
.
It is important to know that if an account is deleted, the account’s files do not get deleted.
Files left over from a removed user are known as “orphaned files“.
Because Linux uses numbers to represent users internally (rather than usernames), these numbers will be displayed in place of the username and group on orphaned files.
If a new user is assigned the same number as a removed user, they could access their orphaned files. As such, it is recommended to reassign ownership to an existing user, archive them, or delete them.
Changing a File’s Owner
The chown
command can be used to change a file’s owner and group:
chown [options] [<new-owner>][:<new-group>] <filenames>
Note: Linux’s chown
command accepts a dot (.
) in place of a colon (:
) to delimit the owner and group. However, the use of a dot has been deprecated, and the colon should be used instead.
Several options are available for the chown
command, but the most likely to be used is -R
/ --recursive
, which implements changes on an entire directory tree.
Note: Only the root
user can use the chown
command to change the ownership of files. However, ordinary users may use chown
to change the group of files that they own, as long as the user belongs to the target group as well.
Changing a File’s Group
The chgrp
command only changes a file’s group:
chgrp [options] <newgroup> <filenames>
There are several options for chgrp
but the most commonly used is -R
/ --recursive
, which updates the group for an entire directory tree.
Note: Ordinary users can only change the group to one that they belong to.
Controlling Access to Files
Understanding Permissions and Permission Bits
File permissions are set using permission bits.
The permissions of a file are easily viewed with ls -l
:
$ ls -l example-dir/
-rwxrw-r--. 1 jeff alchemists my-file.txt
The permission string is the first column of output (-rwxrw-r--
)
The first character of the permission string represents the file type code:
Code | Represents | Description |
- |
Normal data file | Text, executable programs, graphics, compressed data, etc. |
d |
Directory | Contains filenames and pointers to disk inodes. |
l |
Symbolic link | Contains the name of another file or directory. |
p |
Named pipe | Enables two running Linux programs to communicate with each other.
One opens the pipe for reading, and the other opens it for writing, enabling data to be transferred between the programs. |
s |
Socket | Similar to a named pipe, but permits network and bidirectional links. |
b |
Block device | A file that corresponds to a hardware device, where data is transferred in blocks of more than 1 byte to and from.
Disk devices (hard disks, flash drivers, CDs, etc.) are common block devices. |
c |
Character device | Similar to a block device, but used for devices such as parallel ports, RS-232 serial ports, and audio devices. |
The remaining nine characters in the permission string (rwxrw-r--
) can be broken into three groups of 3 characters each. The first group represents the owner, the second group represents the group, and the third group represents everyone else (often referred to as “other“).
$ ls -l example-dir/
-rwxrw-r--. 1 jeff alchemists my-file.txt
In the above output, the owner of this file (jeff
) has read, write, and execute permissions (rwx
).
The group of this file (alchemists
) has read and write permissions (rw
).
All other users, who are not jeff
and do not belong to the alchemists
group, would have only read permissions (r
).
Absence of a permission is denoted by a hyphen (-
).
Execute permissions allow the file to be executed as a program.
Because the permission bits in a permission string are binary, they can also be expressed as a single 9-bit number. This number is usually expressed in octal (base 8) form because a base-8 number is 3 bits in length.
The read, write, and execute permissions correspond to these bits:
4
– read permission2
– write permission1
– execute permission
Permission bits for a particular permission type are added together as a single digit. For example, read (4
), write (2
), and execute (1
) permissions would be represented as 7.
An example of common octal codes for permissions:
Octal Code | Permission String | Description |
777 |
rwxrwxrwx |
Read, write, and execute for all (owner, group, and other). |
755 |
rwxr-xr-x |
Read and execute for all. Read, write, and execute for owner. |
700 |
rwx------ |
Read, write, and execute only for owner. |
666 |
rw-rw-rw- |
Read and write for all. No execute permissions for any. |
644 |
rw-r--r-- |
Read for all. Read and write for owner. |
640 |
rw-r----- |
Read and write for owner. Read for group. No permissions for other. |
600 |
rw------- |
Read and write for owner. |
400 |
r-------- |
Read for owner. No permissions for group or other. |
Execute permissions are meaningless for most file types, such as device files. However, directories use the execute bit to allow its contents to be searched.
Note: symbolic links always have 777
(rwxrwxrwx
) permissions, regardless of the permissions of the file it links to. Attempting to change the link’s permissions will alter the permissions of the file it links to instead.
The root
user can read or write any file — even ones set to 000
permissions. However, the execute bit still needs to be set on a file to run it, even as root
.
Understanding Special Permission Bits
Set User ID (SUID)
The set user ID (SUID) option is used in conjunction with executable files.
This tells Linux to run the program with the permissions of whoever owns the file, rather than with the permissions of the user who runs the program.
SUID programs are identified by an s
in the owner’s execute bit position of the permission string (ex. rwsr-xr-x
).
If the SUID bit is set but execute permissions are not, the permission string will show a capital S
(ex. rwSr-xr-x
). In this case, SUID will not function.
Set Group ID (SGID)
The set group ID (SGID) option is similar to SUID, but it sets the running program’s group to the file’s group.
If SGID is set, the permission string will show an s
in the group’s execute bit (ex. rwxr-sr-x
).
If the execute bit is not set but SGID is, a capital S
will show in the group’s execute bit (ex. rwxr-Sr-x
) — making it benign.
Note: SGID is useful on directories. When the SGID bit is set on a directory, new files or subdirectories created in the original directory will inherit the group ownership of the directory, rather than being set to the user’s current default group.
Sticky Bit
The sticky bit is used to protect files from being deleted by those who do not own the files.
When the sticky bit is present on a directory, only the owner of the directory’s files (or root
) can delete them.
The sticky bit is identified as a t
in the execute bit of the other/world (ex. rwxr-xr-t
).
DAC, ACLs, and SELinux
The permissions covered so far fall under the discretionary access control (DAC) model.
The DAC model is considered inefficient for properly security a Linux system by security professionals.
An improved permission system, called an access control list (ACL) is a list of users or groups and the permissions they’re given.
Linux ACLs, like Linux owner, group, and other permissions, consist of three permission bits. Each bit is for read, write, and execute permissions.
The setfacl
command must be used to set an ACL, and the getfacl
command must be used to display ACLs for a file.
An even better security approach is a model called mandatory access control (MAC), and its subcategory, role-based access control (RBAC). These models are implemented by the SELinux utility — available on many Linux distributions.
SELinux is a very complex utility. It implements RBAC security using the Bell-LaPadula model and either type enforcement or multi-level security.
Changing a File’s Mode
A file’s permissions can be modified with the chmod
command:
chmod [options] [mode[,mode...]] <filename>
The chmod
command has similar options to chown
and chgrp
, including the -R
/ --recursive
option to apply changes to an entire directory tree.
The mode
of chmod
can be specified in two basic forms:
- A three-digit octal number.
- A symbolic mode.
Octal Mode
The octal numbers are the same as described earlier, and could be set like so:
$ chmod 644 my-file.txt
$ ls -l my-file.txt
-rw-r--r--. 1 jeff alchemists my-file.txt
In addition to using the three-digit octal mode, a fourth digit can be prepended to set SUID, SGID, and/or sticky bit permissions:
- 4 – SUID permission
- 2 – SGID permission
- 1 – Sticky bit permission
If this digit is omitted, Linux clears all three special permission bits (i.e. using chmod 644
is the same as chmod 0644
).
Note: Setting SGID requires root
privileges.
Symbolic Mode
The symbolic representation consists of there components:
- A code indicating the permission set to modify (i.e. the owner, the group, other, etc.).
- A symbol indicating whether to add, delete, or set the mode equal to a stated value.
- A code specifying what the permission should be.
The permission set codes used in symbolic mode:
Permission Set Code | Description |
u |
Owner / User |
g |
Group |
o |
Other / World |
a |
All (owner, group, and other) |
The change type codes used in symbolic mode:
Change Type Code | Description |
+ |
Add |
- |
Remove |
= |
Set equal to |
The permission to modify code used in symbolic mode:
Permission to Modify Code | Description |
r |
Read |
w |
Write |
x |
Execute |
X |
Execute (only if the file is a directory or already has execute permissions) |
s |
SUID or SGID |
t |
Sticky bit |
u |
Existing owner’s permissions |
g |
Existing group permissions |
o |
Existing other permissions |
Examples of symbolic permissions used with chmod
:
Command | Permissions (Before) | Permissions (After) |
chmod a+x |
rw-r--r-- |
rwxr-xr-x |
chmod ug=rw |
r-------- |
rw-rw---- |
chmod o-rwx |
rwxrwxr-x |
rwxrwx--- |
chmod g=u |
rw-r--r-- |
rw-rw-r-- |
chmod g-w,o-rw |
rw-rw-rw- |
rw-r----- |
A file’s owner and root
are the only users that may adjust a file’s permissions.
Setting the Default Mode and Group
When a user creates a file, that file has default ownership and permissions.
The default owner is set to the user who created the file, and the default group is set to the user’s primary group.
Default permissions are configurable via the user mask, which is set by the umask
command.
The umask
command takes an octal value as input, which represents the bits to be remove from 777
permissions on directories and 666
permissions for files when they are created.
Examples of umask
values and their effects:
umask | Files | Directories |
000 |
666 (rw-rw-rw-) |
777 (rwxrwxrwx) |
002 |
664 (rw-rw-r--) |
775 (rwxrwxr-x) |
022 |
644 (rw-r--r--) |
755 (rwxr-xr-x) |
027 |
640 (rw-r-----) |
750 (rwxr-x---) |
077 |
600 (rw-------) |
700 (rwx------) |
277 |
400 (r--------) |
500 (r-x------) |
Note: The umask isn’t a simple subtraction from the values of 777
or 666
, it is bit-wise removal.
Ordinary users can enter the umask
command to change the permissions on new files they create.
The root
user can modify the default settings for all users by modifying a system configuration file (typically /etc/profile
). However, these settings can be overridden at several other points before a file is actually created, such as by a user’s own configuration files.
Most Linux distributions ship with a default umask of 002
or 022
.
Entering the umask
command without any arguments will display the current umask setting:
$ umask
0022
The first digit represents the octal code for SUID, SGID, and the sticky bit.
To change the umask, enter a four-digit octal code:
$ umask 0002
$ umask
0002
To express the umask symbolically, use the -S
option:
$ umask -S
u=rwx,g=rwx,o=rx
The changes to umask are immediate. Any newly created files or directories will show the modification.
Similar to umask
, users can change their default group with newgrp
:
newgrp <groupname>
To use the newgrp
command, the user must be a member of the specified group.
Note: The -l
option can be used with the newgrp
command to reinitialize the environment as if the user had just logged back in.
Changing File Attributes
Some Linux-native filesystems support several attributes that can be adjusted with the chattr
command:
chattr <change><attribute-code>
The change symbols used with chattr
:
Change Symbol | Description |
+ |
Add |
- |
Remove |
= |
Set equal to (overwrites any that already exist) |
The attribute codes used with chattr
:
Attribute | Option | Description |
No Access Time Updates | A |
Linux won’t update the access time stamp when you access a file.
This can reduce disk input/output, which can be helpful for saving battery life on laptops. |
Append Only | a |
Disables write access to the file except for appending data.
Useful as a security feature to prevent accidental or malicious changes to files that record data (such as log files). |
Compressed | c |
The kernel will automatically compress data written to a file and uncompress it when it’s read back. |
Immutable | i |
Makes a file immutable.
The file cannot be deleted, links to it cannot be created, and the file cannot be renamed. |
Data Journaling | j |
The kernel will journal all data written to the file.
This improves recoverability of data written to the file after a system crash, but it can slow performance. Note: This flag has no effect on ext2 filesystems (because they do not use a journal). |
Secure Deletion | s |
When a file is deleted, the kernel zeros its data blocks, rather than simply setting its inode block as available for recycling. |
No Tail-Merging | t |
Prevents small data pieces from being pushed into empty spaces near the end of blocks.
This may be useful if non-kernel drivers will read the filesystem, such as those that are part of the Grand Unified Boot Loader (GRUB). |
Managing Disk Quotas
A single user can cause serious problems if they consume too much disk space.
To prevent these kinds of issues, Linux supports disk quotas.
Disk quotas limit how many files or how much disk space a single user may consume, and is enforced by the OS.
The Linux quota system supports quotas for both individuals and Linux groups.
Enabling Quota Support
Quotas require support in the kernel for the filesystem being used and various user-space utilities.
The following filesystems support quotas:
ext2fs, ext3fs, ext4fs, ReiserFS, JFS, and XFS.
Note: Quota support is missing for some filesystems in early 2.6.x kernels.
The Quota Support kernel option must be explicitly enabled when recompiling a kernel. However, most distributions ship with this support enabled.
Two general quota support systems are available for Linux:
- Quota v1 support system — first available through the 2.4.x kernels.
- Quota v2 support system — added with the 2.6.x kernel series.
The rest of this section is on the quota v2 support system, although the v1 system works similarly.
In addition to the kernel support, additional support tools are required to use quotas.
For the quota v2 system, the package of additional support tools is usually called quota
and it installs a number of utilities, configuration files, startup scripts, etc.
Each partition that quotas are desired on must have their /etc/fstab
entry edited similarly to:
/dev/sda1 /home ext4 usrquota,grpquota 1 1
The line above activates both user and group quota support for the /dev/sda1
partition, which is mounted at /home
. Other options may be added as well, depending upon preference.
Depending on the distribution, at this point it may be necessary to configure the quota
package’s system startup scripts to run when the system boots. On SysV enabled systems, this command would be:
chkconfig quota on
The startup script runs the quotaon
command, which activates quota support.
Note: The root
user can turn on quotas at any time by using the quotaon
command manually. Likewise, the root
user can turn off quotas at any time using the quotaoff
command.
Rebooting the system is one way to make configuration file changes take effect. However, a better option is to run the start script for the quota
tools and remount the filesystems that have quotas being enabled or disabled.
After relevant filesystems have been remounted, the quotacheck
command can be used to survey the filesystems and build current disk usage records.
Two files must be built to enable quotas:
aquota.user
aquota.group
To build these files:
quotacheck -cug
In the above command, the -c
option is for “create”, the -u
option is for “users”, and the -g
option is for groups.
Note: The quotacheck
command can also verify and update quota information on quota-enabled partitions. This command is normally run as part of the quota
package’s startup script, but it may be desirable to run it periodically via a cron job.
An example of building the quotas for users in the /home
directory:
# quotacheck -cu /home
Setting Quotas for Users
Quotas can be set using the edquota
command.
The edquota
command uses a text editor, such as the vi editor. However, it will use whatever editor is set for the EDITOR
environment variable.
The editor opens a temporary configuration file (/etc/quotatab
), which controls the specified user’s quotas.
When the editor is closed, edquota
uses the temporary configuration file to write the quota information to low-level disk data structures — which in turn control the kernel’s quota mechanisms.
An example of editing jeff
‘s quotas would be:
edquota jeff
The configuration file would contain something such as:
Disk quotas for user jeff (uid 519):
Filesystem blocks soft hard inodes soft hard
/dev/sda1 97119 1023565 1023565 1059 0 0
This temporary configuration file shows the number of disk blocks and inodes in use.
Each file or symbolic link consumes a single inode, so the inode limits are essentially file number limits.
Disk blocks can vary in size depending on the filesystem and filesystem creation options.
The blocks
and inodes
columns display how many blocks or inodes the user is actually consuming, and changing these values manually has zero effect.
The hard limits for blocks and inodes is the maximum number of blocks or inodes that the user may consume. The kernel will not permit a user to surpass these hard limits.
The soft limits are not as strict. Users may temporarily exceed a soft limit value, but the systems issues warnings when they do.
Soft limits also have a grace period. If the user exceeds their soft limits beyond the grace period, the kernel will treat it like a hard limit and refuse to allow the user to create more files.
The soft limit grace period can be set using the -t
option of edquota
:
edquota -t
Note: Grace periods are set on a per-filesystem basis rather than a per-user basis.
Setting the limit to 0
eliminates the use of quotas.
Each filesystem can have its quotas adjusted independently using the edquota
command, including their users and groups.
To edit quotas for a group, use the -g
option:
edquota -g <group-name>
To summarize the quota information about a filesystem use the repquota
command. For all filesystems, use the -a
option with repquota
.
The quota
command is similar. The -g
option displays group quotas, the -l
option omits NFS mounts, and the -q
option limits output to filesystems to only those above their limits.
Locating Files
The FHS
Linux’s placement of files is derived from over 40 years of Unix history.
The following sections describe the Linux directory layout standards, with an overview of where everything goes.
Comparing FSSTND with FHS
Unix has a long history, containing numerous splits and variants.
The first split was caused by the Berkeley Standard Distribution (BSD); which was initially a set of patches and extensions to AT&T’s original Unix code.
To prevent fractioning of the Linux community, the Filesystem Standard (FSSTND) was created in early 1994.
The FSSTND standardized several specific features:
- Programs reside in
/bin
and/usr/bin
. - Executable files shouldn’t reside in
/etc
. - Changeable files shouldn’t be placed in the
/usr
directory tree — allowing it to be mounted read-only.
There have been three major revisions of FSSTND:
- 1.0
- 1.1
- 1.2
The Filesystem Hierarchy Standard (FHS) was then created in 1995 to extend FSSTND and overcome the limitations that were becoming apparent with it.
Note: The FHS comes in numbered versions, such as v2.3. Although it’s not updated often, it is wise to check for FHS modifications at http://www.pathname.com/fhs/.
One important distinction made by FHS is between shareable files and unshareable files.
Shareable files, such as user data files and program binary files, may be reasonably shared between machines.
Note: Typically files are shared through an NFS server.
Unshareable files contain system-specific information, such as configuration files.
A second important distinction made by FHS is between static files and variable files.
Static files do not normally change except through direct intervention by the system admin.
Most program executables are examples of static files.
Variable files may be changed by users, automated scripts, servers, etc.
User’s home directories and mail queues are made of variable files.
The FHS tries to isolate each directory into one cell of a 2×2 grid of shareable / unshareable vs static / variable:
Shareable | Unshareable | |
Static | /usr /opt |
/etc /boot |
Variable | /home /var/mail |
/var/run /var/lock |
Some directories are mixed, but in those cases, the FHS tries to classify its subdirectories. For example, /var
is variable but it contains both shareable and unshareable subdirectories.
Important Directories and Their Contents
The most common directories defined by the FHS and/or convention:
Directory | Details |
/ |
The root filesystem or root directory.
All other directories branch from this directory. |
/boot |
Contains static and unshareable files related to the computer’s initial booting.
In this directory, GRUB or LILO configuration files can be found, along with other files necessary for the initial boot. It is usually recommended to store |
/etc |
Contains unshareable and static system configuration files.
These higher-level startup and configuration files control the various programs and services on the system. Systemd configuration files are stored in |
/bin |
Contains unshareable and static executable files, such as ls , cp , mv , rm , and mount .
These commands are accessible to all users and constitute the most important commands that ordinary users might use. |
/sbin |
Contains unshareable and static executable files typically run by only the system administrator, such as fdisk , e2fsck , etc. |
/lib |
Contains unshareable and static program libraries.
Program libraries consist of code that’s shared across many programs and stored in separate files to save disk space and RAM. The |
/usr |
Contains shareable and static programs.
This directory contains It can be mounted read-only on a separate partition if desired. |
/usr/local |
Contains subdirectories that mirror the organization of /usr , such as /usr/local/bin and /usr/local/lib .
This directory hosts files that a system administrator installs locally, such as packages that are compiled on it. The idea behind this directory is to have an area that is safe from automatic software upgrades when the OS is upgraded as a whole. Some admins split this directory off into its own partition to protect it from OS reinstallation procedures that might erase the parent partition. |
/usr/share/man |
Contains manual pages used by the man command.
Local manual pages are stored in the |
/usr/X11R6 |
Contains files related to the X Window System (abbreviated as X) — Linux’s GUI environment.
This directory was common several years ago, but most modern distributions have moved its contents to other directories, such as |
/opt |
Contains shareable and static ready-made packages that do not ship with the OS, such as word processors and games.
Some admins break it into a separate partition, or make it a symbolic link to a subdirectory of |
/home |
Contains shareable and variable files composing regular user’s data.
The |
/root |
Contains unshareable and variable files, which make up the home directory for the root user. |
/var |
Contains variable files and a mix of subdirectories that are shareable and unshareable.
Most of its contents are transient files of various types — system log files, print spool files, mail, news, etc. Many admins put |
/tmp |
Contains temporary files often created by many programs during normal operation.
Most distributions have routines that clean out this directory periodically, and some even wipe the directory clean at bootup. Some admins put A similar directory exists as part of the |
/mnt |
Contains shareable and a mix of variable and static files.
Linux mounts removable-media devices on Some older distributions create subdirectories within |
/media |
An optional part of the FHS.
It is similar to Many modern distributions use |
/dev |
Contains a large number of files that function as hardware interfaces — as Linux treats most hardware devices as if they were files, and the OS must have a location in its filesystem where these device files reside.
A user may access the device hardware by reading from and writing to the associated device files, if they have sufficient privileges. The Linux kernel supports a device filesystem that enables |
/proc |
Contains a virtual filesystem that’s created on the fly by Linux to provide access to certain types of hardware information that isn’t accessible via /dev .
For example, |
The directories that are recommended to have their own partition are:
/boot
/home
/opt
/tmp
/usr
/usr/local
/var
The directories that should not be on their own partitions are:
/bin
/dev
/etc
/lib
/sbin
Note: Some Linux distributions deviate from the FHS.
Using find
The find
utility uses a brute-force approach to finding files.
The program finds files by searching through the specified directory tree, checking filenames, file creation dates, etc. to locate the files that match a specified criteria.
The syntax for find
is:
find [path...] [expression...]
One or more paths
can be specified that find
will search through.
The expression
option is a way of specifying what is being searched for.
The most commonly used options for find
:
Feature | Option | Details |
Search by Filename | -name <pattern> |
<pattern> can be a ordinary filename, or enclosed within quotes to use wildcards. |
Search by Permission Mode | -perm <mode> |
<mode> may be expressed either symbolically or in octal form.
If If |
Search by File Size | -size <n> |
<n> is specified in 512-byte blocks, but this can be changed by trailing the value with a letter code, such as c for bytes or k for kilobytes. |
Search by Group | -gid <GID> -group <name> |
<GID> is the group ID.
|
Search by User ID | -uid <UID> -user <name> |
<UID> is the user ID.
|
Restrict Search Depth | -maxdepth <level> |
<level> is a digit representing the number of subdirectory levels to search within. |
Note: Ordinary users may use find
, but if the user lacks permissions to list a directory’s contents, find
will return that directory’s name and a Permission denied
error.
Using locate
The locate
utility is similar to find
, but with two major exceptions:
- It is far less sophisticated in its search options.
- It works from a database that it maintains.
Most distributions include a cron job that calls utilities to update the locate
database. For this reason, locate
may not find recent files, or it may return the names of files that no longer exist.
The locate
database can be updated with the updatedb
command — which is configured via the /etc/updatedb.conf
file.
The syntax for locate
is:
locate <search-string>
The <search-string>
can be an entire filename or a partial filename.
Note: Some distributions use slocate
instead of locate
— as the slocate
command includes security features to prevent users from seeing the names of files in directories they shouldn’t have access to. On many systems that use slocate
, locate
is just a link to slocate
.
Using whereis
The whereis
command searches for files in a restricted set of locations, such as standard binary file directories, library directories, and man
page directories.
Generally the whereis
command is used to quickly find program executables and related files like documentation or configuration files.
To use this command, type the name of the program to be found. For example:
$ whereis ls
ls: /bin/ls /usr/share/man/man1p/ls.1p.gz
/usr/share/man/man1/ls.1.gz
Using which
The which utility only searches directories defined within the PATH
environment variable, and lists the complete path to the first match it finds:
$ which xterm
/usr/bin/xterm
To get all matches, use the -a
option.
Managing Files Essentials
- Describe commands used to copy, move, and rename files in Linux.
- The
cp
command copies files, as incp first second
to create a copy offirst
calledsecond
. - The
mv
command does double duty as a file-moving and file-renaming command.
- The
- Summarize Linux’s directory-manipulation commands.
- The
mkdir
command creates a new directory, andrmdir
deletes empty directories. - Many of the file-manipulation commands, such as
mv
anrm
can be used with the-R
/-r
option on directories.
- The
- Explain the difference between hard and symbolic links.
- Hard links are duplicate directory entries that both point to the same inode and hence to the same file.
- Symbolic links are special files that point to another file or directory by name.
- Hard links must reside on a single filesystem, but symbolic links may point across filesystems.
- Summarize the common Linux archiving programs.
- The
tar
andcpio
programs are both file-based archiving tools that create archives of files using ordinary file access commands. - The
dd
program is a file-copy program; however, when it’s fed a partition device file, it copies the entire partition on a very low-level basis — which is useful for creating low-level backups of Linux or non-Linux filesystems.
- The
- Explain the difference between compression utilities.
- The
gzip
,bzip2
, andxz
utilities are compression tools, which reduce a file’s size via compression algorithms. - These utilities are often used in conjunction with the
tar
command. gzip
is the oldest compression tool and provides the least compression.bzip2
provides slightly improved file compression overgzip
.xz
is the newest compression tool and provides the best compression.
- The
- Describe Linux’s file ownership system.
- Every file has an owner and a group, identified by number.
- File permissions can be assigned independently to the file’s owner, the file’s group, and to all other users.
- Explain Linux’s file permissions system.
- Linux provides independent read, write, and execute permissions for the file’s owner, group, and everyone else (other); resulting in nine main permission bits.
- Special permission bits are also available, which enable you to launch program files with modified account features, or alter the rules Linux uses to control who may delete files.
- Summarize the commands Linux uses to modify permissions.
- The
chmod
command is Linux’s main tool for setting permissions. - Permissions can be specified using either an octal (base 8) mode or a symbolic notation.
- The
chown
andchgrp
commands can be used to change the file’s owner and group, respectively. - The
chown
command can change both a file’s owner and group if run byroot
).
- The
- Describe the prerequisites of using Linux’s disk quota system.
- Linux’s disk quota system requires support in the Linux kernel for the filesystem on which quotas are to be used.
- The
quotaon
command must also be run, typically from a startup script, to enable disk quotas.
- Explain how quotas are set.
- Individual user quotas can be edited using the
edquota
command (ex.edquota jeff
). - This command opens an editor on an editable text file that describes the user’s quotas.
- Individual user quotas can be edited using the
- Summarize how Linux’s standard directories are structured.
- Linux’s directory tree begins with the root (
/
) directory, which holds mostly other directories. - Specific directories may hold specific types of information, such as user files in
/home
and configuration files in/etc
. - Some of these directories and their subdirectories may be separate partitions, which helps isolate data in the event of filesystem corruption or disk space issues.
- Linux’s directory tree begins with the root (
- Describe the major file-location commands in Linux.
- The
find
command locates files by brute force, searching through the directory tree for files that match the specified criteria. - The
locate
(orslocate
) command searches a database of files in publicly accessible directories. - The
whereis
command searches a handful of important directories. - The
which
command searches only path directories.
- The
A new technology is coming to browsers via CSS grids.
Presentation
This presentation does a fairly decent job at covering the important details (skip to 12:42):
Notes
- Grid support is available in all major modern browsers.
- Grid relies only on CSS and HTML, no JavaScript or anything else is needed.
- Grids cut down on a lot of superfluous HTML and CSS (ex. Bootstrap classes, nests of divs, etc.).
- Grids make it easier to arrange and rearrange content within a document.
- Grids are defined by simply adding the declaration “
display: grid;
” to a CSS selector.- Example:
.content {
display: grid;
}
- Example:
- Grids can be divided into columns with the property “
grid-template-columns
“, and rows with the property “grid-template-rows
“.- Columns and rows support the new “fraction” (fr) value, in addition to em, px, %, etc.
- Example:
.content {
display: grid;
grid-template-columns: 2fr 1fr 2fr;
grid-template-rows: auto 1fr 4fr;
}
- Example:
- Columns and rows support the new “fraction” (fr) value, in addition to em, px, %, etc.
- Grid columns/rows begin with a value of
1
at the top left, and increment in value going to down and to the right. - Placement of content can be done manually, by specifying number values within the “
grid-column
” and “grid-row
” properties.- The number values are delimited by a forward slash (
/
).- Example:
.header {
grid-column: 1/4;
grid-row: 2/3;
}
- Example:
- The number values are delimited by a forward slash (
- Rather than memorize column and row numbers, grids can also use named template areas via the “
grid-template-areas
” property.- Example:
.content {
display: grid;
grid-template-columns: 2fr 1fr 2fr;
grid-template-rows: auto 1fr 4fr;
grid-template-areas:
"header header header"
"main main main"
"article article sidebar"
"footer footer footer"
}
- Example:
- Content can be placed within grid template areas via the “
grid-area
” property.- Example:
header {
grid-area: header;
}
#main-content {
grid-area: main;
}
.article {
grid-area: article;
}
.sidebar {
grid-area:sidebar;
}
footer {
grid-area: footer;
}
- Example:
- Child elements do not inherit grids; allowing for nested grids that are unique.
@supports (display: grid;) { [...] }
can be used to check if the browser supports grid.@media screen and (min-width: <value>) { [...] }
can be used in conjunction with grid to make dynamic and responsive layouts.
Additional Resources
- https://developer.mozilla.org/en-US/docs/Web/CSS/CSS_Grid_Layout
- https://gridbyexample.com/examples/
- https://www.w3.org/TR/css-grid-1/
Configuring Hardware
Exam Objectives
- 101.1 – Determine and configure hardware settings
- 102.1 – Design hard disk layout
- 104.1 – Create partitions and filesystems
- 104.2 – Maintain the integrity of filesystems
- 104.3 – Control mounting and unmounting of filesystems
Configuring the Firmware and Core Hardware
Firmware is the lowest level software that runs on a computer. A computer’s firmware begins the boot process and configures certain hardware devices.
Key components managed by the firmware (and Linux, once it’s booted) include interrupts, I/O addresses, DMA addresses, the real-time clock, and Advanced Technology Attachment (ATA) hard disk interfaces.
Understanding the Role of the Firmware
Many types of firmware are installed on the various hardware devices found inside a computer, but the most important firmware is on the motherboard.
In the past, most x86 and x86_64 based computers had a firmware known as the Basic Input/Output System (BIOS). Since 2011, however, Extensible Firmware Interface (EFI) and it’s successor, Unified EFI (UEFI), has become the standard.
Note: While most x86 and x86_64 computers use a BIOS or EFI, some computers may use other software in place of these types of firmware. For example, old PowerPC-based Apple computers use OpenFirmware.
Despite the fact that EFI isn’t a BIOS, most manufacturers refer to it by that name in their documentation. Additionally, the the exam objectives refer to the BIOS, but not EFI.
The motherboard’s firmware resides in electronically erasable programmable read-only memory (EEPROM), aka flash memory.
When a computer is turned on, the firmware performs a power-on self-test (POST), initializes hardware to a known operational state, and loads the boot loader from the boot device (typically the first hard disk), and passes control onto the boot loader — which in turn loads the operating system.
Most BIOSs and EFIs provide an interactive interface to configure them — typically found by pressing the Delete key or a Function key during the boot sequence.
Note: Many computers prevent booting if a keyboard is unplugged. To disable this, look for a firmware option called Halt On or similar with the BIOS or EFI.
Once Linux boots, it uses its own drivers to access the computer’s hardware.
Note: Although the Linux kernel uses the BIOS to collect information about the hardware of a machine, once Linux is running, it doesn’t use BIOS services for I/O. As of the 3.5.0 kernel, Linux takes advantages of a few EFI features.
IRQs
An interrupt request (IRQ), or interrupt, is a signal sent to the CPU instructing it to suspend its current activity and handle some external event, such as keyboard input.
On the x86 platform, 16 IRQs are available — numbered 0
to 15
. Newer systems, including x86_64 systems, have an even greater number of IRQs.
IRQs and their common uses:
Command | Typical Use | Notes |
0 |
System Timer | Reserved for internal use. |
1 |
Keyboard | Reserved for keyboard use only. |
2 |
Cascade for IRQs 8 — 15 |
The original x86 IRQ-handling circuit can manage just 8 IRQs; two sets of these are tied together to handle 16 IRQs, but IRQ 2 must be used to handle IRQs 8 — 15 |
3 |
Second RS-232 serial port ( COM2: in Windows) |
May also be shared by a fourth RS-232 serial port. |
4 |
First RS-232 serial port ( COM1: in Windows) |
May also be shared by a third RS-232 serial port. |
5 |
Sound card or second parallel port ( LPT2: in Windows) |
|
6 |
Floppy disk controller | Reserved for the first floppy disk controller. |
7 |
First parallel port ( LPT1: in Windows) |
|
8 |
Real-time clock | Reserved for system clock use only. |
9 |
ACPI system control interrupt | Used by Intel chipsets for the Advanced Configuration and Power Interface (ACPI) used for power management. |
10 |
Open interrupt | |
11 |
Open interrupt | |
12 |
PS/2 mouse | |
13 |
Math coprocessor | Reserved for internal use. |
14 |
Primary ATA controller | The controller for ATA devices such as hard drives; traditionally /dev/hda and /dev/hdb under Linux. |
15 |
Secondary ATA controller | The controller for additional ATA devices; traditionally /dev/hdc and /dev/hdd under Linux. |
Note: Most modern distributions treat Serial ATA disks as SCSI disks, which changes their device identifiers from /dev/hdx
to /dev/sdx
.
The original Industry Standard Architecture (ISA) bus design (which has become rare on computers since 2001) makes sharing an interrupt between two devices tricky. Therefore, it is ideal that every ISA device should have it’s own IRQ.
The more recent Peripheral Component Interconnect (PCI) bus makes sharing interrupts a bit easier, so PCI devices frequently end up sharing an IRQ.
Once a Linux system is running, you can explore what IRQs are being used for various purposes by examining the contents of the /proc/interrupts
file:
$ cat /proc/interrupts
Example from CentOS 6.9:
Note: The /proc
filesystem is a virtual filesystem — it refers to kernel data that’s convenient to represent using a filesystem, rather than actual files on a hard disk.
The above example output shows the IRQ number in the first column. The next two columns show each CPU core and the number of interrupts each has received for that particular IRQ. The column after them reports the type of interrupt, followed by the name of the device that is located at that IRQ.
Note: The /proc/interrupts
file lists IRQs that are in use by Linux, but Linux doesn’t begin using an IRQ until the relevant driver is loaded. This may not happen until you attempt to use the hardware. As such, the /proc/interrupts
list may not show all of the interrupts that are configured on your system.
Although IRQ conflicts are rare on modern hardware, they still do occasionally happen. When this occurs, you must reconfigure one or more devices to use different IRQs.
I/O Addresses
I/O addresses (aka I/O ports) are unique locations in memory that are reserved for communications between the CPU and specific physical hardware devices.
Like IRQs, I/O addresses are commonly associated with specific devices, and they should not ordinarily be shared.
Common Linux devices, along with their typical IRQ number and I/O addresses:
Linux Device | Typical IRQ | I/O Address | Windows Name |
/dev/ttyS0 |
4 |
0x03f8 |
COM1 |
/dev/ttyS1 |
3 |
0x02f8 |
COM2 |
/dev/ttyS2 |
4 |
0x03e8 |
COM3 |
/dev/ttyS3 |
3 |
0x02e8 |
COM4 |
/dev/lp0 |
7 |
0x0378 - 0x037f |
LPT1 |
/dev/lp1 |
5 |
0x0278 - 0x027f |
LPT2 |
/dev/fd0 |
6 |
0x03f0 - 0x03f7 |
A: |
/dev/fd1 |
6 |
0x0370 - 0x0377 |
B: |
Note: Although the use is deprecated, older systems sometimes use /dev/cuax
(where x
is a number 0
or greater) to indicate an RS-232 serial device. Thus, /dev/ttyS0
and /dev/cua0
refer to the same physical device.
Once a Linux system is running, you can explore what I/O addresses the computer is using by examining the contents of the /proc/ioports
file:
$ cat /proc/ioports
jeff@mg-rex-mint ~ $ cat /proc/ioports
0000-0cf7 : PCI Bus 0000:00
0000-001f : dma1
0020-0021 : pic1
0040-0043 : timer0
0050-0053 : timer1
0060-0060 : keyboard
0061-0061 : PNP0800:00
0064-0064 : keyboard
0070-0071 : rtc0
0080-008f : dma page reg
[...truncated...]
DMA Addresses
Direct memory addressing (DMA) is an alternative method of communication to I/O ports. Rather than have the CPU mediate the transfer of data between a device and memory, DMA permits the device to transfer data directly, without the CPU’s attention.
To learn what DMA channels your system uses:
$ cat /proc/dma
jeff@mg-rex-mint ~ $ cat /proc/dma
4: cascade
The above output indicates that DMA channel 4 is in use. As with IRQs and I/O ports, DMA addresses should not be shared normally.
Boot Disks and Geometry Settings
BIOS
The BIOS boot process begins with the computer reading a boot sector (typically the first sector) from a disk and then executing the code contained within it.
This limits boot options for BIOS-based computers to only selecting the order in which various boot devices (hard disks, optical disks, USB devices, network boot, etc.) are examined for a boot sector.
EFI
Under EFI, the boot process involves the computer reading a boot loader file from a filesystem on a special partition, known as the EFI System Partition (ESP). This file can take a special default name or it can be registered in the computer’s NVRAM.
This allows EFI computers to have an extended range of boot options, involving both default boot loader files from various devices and multiple boot loaders on the computer’s hard disks.
Note: Many EFI implementations support a BIOS compatibility mode, and so they can boot media intended for BIOS-based computers.
Booting Options
Some viruses are transmitted by BIOS boot sectors. As such, it’s a good idea not to make booting from removable media the first priority; it’s better to make the first hard disk (or boot loader on a hard disk’s ESP, in the case of EFI) the only boot device.
Note: The Windows A:
floppy disk is /dev/fd0
under Linux.
In most cases, the firmware detects and configures hard disks and CD/DVD drives correctly. In rare circumstances, you must tell a BIOS-based computer about the hard disk’s cylinder / head / sector (CHS) geometry.
Cylinder / Head / Sector (CHS) Geometry
The CHS geometry is a holdover from the early days of the x86 architecture. A traditional hard disk layout consist of a fixed number of read/write heads that can move across the disk surfaces / platters. As the disk spins, each head marks out a circular track on its platter. These tracks collectively make up a cylinder. Each track is broken down into a series of sectors.
Any sector on a hard disk can be uniquely identified by three numbers: a cylinder number, a head number, and a sector number.
The x86 BIOS was designed to use the three number CHS identification code — requiring the BIOS to know how many cylinders, heads, and sectors the disk has. Most modern hard disks relay this information to the BIOS automatically, but for compatibility with the earliest hard disks, BIOSs still enable you to set these values manually.
Note: The BIOS will detect only certain types of disks. Of particular importance, SCIS disks and SATA disks won’t appear in the main BIOS disk-detection screen. These disks are handled by supplementary firmware associated with the controllers for these devices. Some BIOSs do provide explicit options to add SCSI devices into the boot sequence, which allows you to give priority to either ATA or SCSI devices. For BIOSs without these options, SCSI disks are generally given less priority than ATA disks.
The CHS geometry presented to the BIOS of a hard disks is a convenient lie — as most modern disks squeeze more sectors onto the outer tracks than the inner ones for greater storage capacity.
Plain CHS geometry also tops out at 504 MiB, due to the limits on the numbers in the BIOS and in the ATA hard disk interface.
Note: Hard drive sizes use the more accurate mebibyte (MiB) size instead of the standard megabyte (MB). In general use, most people will say megabyte when actually referencing the size of a mebibyte (likewise for gigabyte and gibibyte). It’s 1000 MB to 1 GB, whereas it’s 1024 MiB to 1 GiB.
Various patches, such as CHS geometry translation, can be used to expand the limit to about 8 GiB. However, the preference these days is to use logical/linear block addressing (LBA) mode.
In LBA mode, a single unique number is assigned to each sector on the disk, and the disk’s firmware is smart enough to read from the correct head and cylinder when given this sector number.
Modern BIOSs typically provide an option to use LBA mode, CHS translation mode, or possibly some other modes with large disks. EFI uses LBA mode exclusively, and doesn’t use CHS addressing at all (except for BIOS compatibility mode).
Coldplug and Hotplug Devices
Hotplug devices can be attached and detached when the computer is turned on (i.e. “hot”). Coldplug devices must be attached and detached when the computer is in an off state (i.e. “cold”).
Note: Attempting to attach or detach a coldplug device when the computer is running can damage the device or the computer.
Traditionally, components that are internal to the computer, such as CPU, memory, PCI cards, and hard disks, have been coldplug devices. A hotplug variant of PCI does exist, but it’s mainly on servers and other systems that can’t afford downtime required to install or remove a device. Hotplug SATA devices are also available.
Modern external devices, such as Ethernet, USB, and IEEE-1394 devices, are hotplug. These devices rely on specialized Linux software to detect the changes to the system as they’re attached and detached. Several utilities help with managing hotplug devices:
Sysfs
The sysfs virtual filesystem, mounted at /sys
, exports information about devices so that user-space utilities can access the information.
Note: A user space program is one that runs as an ordinary program, whether it runs as an ordinary user or as root
. This contrasts with kernel space code, which runs as part of the kernel. Typically only the kernel (and hence kernel-space code) can communicate directly with hardware. User-space programs are ultimately the users of hardware, though. Traditionally the /dev
filesystem has provided the main means of interface between user space programs and hardware.
HAL Daemon
The Hardware Abstraction Layer (HAL) Daemon, or hald
, is a user-space program that runs at all times and provides other user-space programs with information about available hardware.
D-Bus
The Desktop Bus (D-Bus) daemon provides a further abstraction of hardware information access. D-Bus enables processes to communicate with each other as well as to register to be notified of events, both by other processes and by hardware (such as the availability of a new USB device).
udev
Traditionally, Linux has created device nodes as conventional files in the /dev
directory tree. The existence of hotplug devices and various other issues, however, have motivated the creation of udev
— a virtual filesystem, mounted at /dev
, which creates dynamic device files as drivers are loaded and unloaded.
udev
can be configured through files located at /etc/udev
, but the standard configuration is usually sufficient for common hardware.
Older external devices, such as parallel and RS-232 ports, are officially coldplug in nature. When RS-232 or parallel port devices are hotplugged, they typically aren’t registered by tools such as udev
and hald
. The OS handles the ports to which these devices connect; so it’s up to user space programs, such as terminal programs and/or the printing system, to know how to communicate with the external devices.
Configuring Expansion Cards
Many hardware devices require configuration — the IRQ, I/O port, and DMA addresses used by the device must be set. In the past, such things were set using physical jumpers. Presently, most devices can be configured via software.
Configuring PCI Cards
The PCI bus, which is the standard expansion bus for most internal devices, was designed with Plug-and-Play (PnP) style configuration in mind, thus automatic configuration of PCI devices is the rule rather than the exception.
In general, PCI devices configure themselves automatically, and there is no need to make any changes. However, it is possible to tweak how PCI devices are detected in several ways:
- The Linux kernel has several options that affect how it detects PCI devices. These can be found in the kernel configuration screens under Bus Options. Most users can rely on the options in their distributions’ default kernel to work properly; but if the kernel was recompiled by yourself, and you are experiencing problems with device detection, these options may need to be adjusted.
- Most firmware implementations have PCI options that change the way PCI resources are allocated. Adjusting these options may help if strange hardware problems occur with PCI devices.
- Some Linux drivers support options that cause them to configure the relevant hardware to use particular resources. Details of these options can often be found in the drivers’ documentation files. These options must be passed to the kernel using a boot loader or kernel module options.
- The
setpci
utility can be used to query and adjust PCI devices’ configurations directly. This tool can be useful if you know enough about the hardware to fine-tune its low-level configuration; but it’s not often used to tweak the hardware’s basic IRQ, I/O port, or DMA options.
To check how PCI devices are currently configured, the lspci
command can be used to display all of the information about the PCI busses on your system and all of the devices connect to those busses.
Common lspci
options:
Option | Description |
-v |
Increases verbosity of output. This option can be doubled ( -vv ) or tripled (-vvv ) to produce even more output. |
-n |
Displays information in numeric codes rather than translating the codes to manufacturer and device names. |
-nn |
Displays both the manufacturer and devices names along with their associated numer codes. |
-x |
Displays the PCI configuration space for each device as a hexadecimal dump. This is an extremely advanced option. Tripling ( -xxx ) or quadrupling (-xxxx ) this option displays information about more devices. |
-b |
Shows IRQ numbers and other data as seen by devices rather than as seen by the kernel. |
-t |
Displays a tree view, depicting the relationship between devices. |
-s [[[[domain]:]bus]:][slot][.[func]] |
Displays only devices that match the listed specification. This can be used to trim the results of the output. |
-d [vendor]:[device] |
Shows data on the specified device. |
-i <file> |
Uses the specified file to map vendor and device IDs to names. (The default is /usr/share/misc/pci.ids ). |
-m |
Dumps data in a machine-readable form intended for use by scripts. A single -m uses a backward-compatible format, whereas doubling (-mm ) uses a newer format. |
-D |
Displays PCI domain numbers. These numbers normally aren’t displayed. |
-M |
Performs a scan in bus-mapping mode, which can reveal devices hidden behind a misconfigured PCI bridge. This is an advanced option that can be used only by root . |
--version |
Displays version information. |
Learning about Kernel Modules
Kernel drivers, many of which come in the form of kernel modules, handle hardware in Linux.
Kernel modules are stand-alone driver files, typically stored in the /lib/modules
directory tree, that can be loaded to provide access to hardware and unloaded to disable such access. Typically, Linux loads the modules it needs when it boots, but you may need to load additional modules yourself.
The lsmod
command can be used to display the modules that are currently loaded:
$ lsmod
Example output:
[...truncated...]
The above output has several columns:
- The first column is labeled
module
and represents the name of module currently loaded. To learn more about these modules, use themodinfo
command. - The
Size
column shows how much memory is consumed by the module. - The
Used By
column has a number to represent how many other modules or processes are using that module, followed by a list of those modules/processes. If the number is0
it is not currently in use.
Note: The lsmod
command displays information only about kernel modules, not about drivers that are compiled directly into the Linux kernel. For this reason, a module may need to be loaded on one system but not on another to use the same hardware, because the second system may compile the relevant driver directly into the kernel.
To find out more details about a particular module, use the modinfo
command:
$ modinfo <module-name>
Loading Kernel Modules
Linux enables you to load kernel modules with two programs:
insmod
modprobe
The insmod
program inserts a single module into the kernel. This process requires that all dependencies for this module be loaded beforehand.
The modprobe
program accomplishes the same actions, but loads the dependencies automatically.
Note: In practice, you may not need to use insmod
or modprobe
to load modules because Linux can load them automatically. This ability relies on the kernel’s module autoloader feature, which must be compiled into the kernel, and on various configuration files, which are also required for modprobe
and some other tools. Using insmod
and modprobe
can be useful for testing new modules or for working around problems with the autoloader, though.
The insmod
command accepts a module filename:
# insmod /lib/modules/3.0.19/kernel/drivers/bluetooth/bluetooth.ko
The modprobe
command accepts a module name instead of a filename:
# modprobe bluetooth
Note: modprobe
relies on a configuration file at /etc/modprobe.conf
or multiple configuration files within /etc/modprobe.d/
to use module names instead of filenames.
There are several options/features for modprobe
:
Feature | Option | Description |
Be Verbose |
|
Tells modprobe to display extra information about its operations.Typically, this includes a summary of every insmod operation it performs. |
Change Configuration Files | -C <filename> |
Change the configuration file or directory. |
Perform a Dry Run | -n --dry-run |
Causes modprobe to perform checks and all other operations except the actual module insertions.This option can be used in conjunction with -v to see what modprobe would do without actually loading the module. |
Remove Modules | -r --remove |
Reverses modprobe ‘s usual effect. It removes the module and any on which it depends (unless those dependencies are in use by other modules). |
Force Loading | -f --force |
Force the module loading, even if the kernel version doesn’t match what the module expects. This can occassionally be required when using third-party binary-only modules. |
Show Dependencies | --show-depends |
Shows all modules on which a specific module depends (i.e. module dependencies). Note: This option doesn’t install any of the modules, it only provides information. |
Show Available Modules | -l --list |
Displays a list of available options whose names match the wildcard specified. For example: Note: If no wildcard is provided, all available modules are displayed. Additionally, this option does not actually install any modules. |
Consult man modprobe
for additional options.
Viewing Loaded Module Options
A loaded module has its options/parameters available at:
/sys/module/<module-name>/parameters/<parameter-name>
Removing Kernel Modules
In most cases, modules can be loaded indefinitely; the only harm that a module does when it’s loaded but not used is consume a small amount of memory.
Reasons for removing a loaded module can include: reclaiming a tiny amount of memory, unloading an old module so that an updated replacement can be loaded, and removing a module that is suspected to be unreliable.
The rmmod
command can be used to unload a kernel module by name:
# rmmod bluetooth
There are several options/features for rmmod
:
Feature | Option | Description |
Be Verbose |
|
Causes rmmod to display extra information about its operations. |
Force Removal | -f --force |
Forces module removal, even if the module is marked as being in use. This option has no effect unless the CONFIG_MODULE_FORCE_UNLOAD kernel option is enabled. |
Wait Until Unused | -w --wait |
Causes rmmod to wait for the module to become unused. Once the module is no longer being used, rmmod unloads the module.Note: rmmod doesn’t return anything until it unloads a module, which can make it look like it’s not doing anything. |
Consult man rmmod
for additional options.
Like insmod
, rmmod
operates on a single module. If an attempt is made to unload a module that’s in use or depended on by other modules, an error message will be displayed. If other modules depend on the module, rmmod
lists those modules — making it easier to decide whether to unload them or not.
To unload an entire module stack (a module and all of its dependencies) use the modprobe
command with it’s -r
option.
Configuring USB Devices
USB Basics
USB is a protocol and hardware port for transferring data to and from devices. It allows for many more (and varied) devices per interface port than either ATA or SCSI, and it gives better speed than RS-232 serial and parallel ports.
- The USB 1.0 and 1.1 specification allow for up to 127 devices and 12Mbps of data transfer.
- USB 2.0 allows for up to 480Mbps of data transfer.
- USB 3.0 supports a theoretical maximum speed of 4.8Gbps, although 3.2Gbps is more likely its top speed in practice. In addition, it also uses a different physical connector than 1.0, 1.1, and 2.0 connectors. USB 3.0 connectors can accept 2.0, 1.1, and 1.0 devices however.
Note: Data transfer speeds may be expressed in bits per second (bps) or multiples thereof, such as megabits per second (Mbps) or gigabits per second (Gbps). Or they can be expressed in bytes per second (Bps) or multiples thereof, such as megabytes per second (MBps). In most cases, there are 8 bits per bytes, so multiplying or dividing by 8 may be necessary to compare devices using different measurements.
Most computers ship with several USB ports. Each port can handle one device itself, but a USB hub can also be used to connect several devices to each port.
Linux USB Drivers
Several different USB controllers are available, with names such as UHCI, OHCI, EHCI, and R8A66597.
Modern Linux distributions ship with the drivers for the common USB controllers enabled, so the USB ports should be activated automatically when the computer is booted.
The UHCI and OHCI controllers handle USB 1.x devices, but most other controllers can handle USB 2.0 devices. A kernel of 2.6.31 or greater is required to use USB 3.0 hardware.
Note: These basic USB controllers merely provide a means to access the actual USB hardware and address the devices in a low-level manner. Additional software (either drivers or specialized software packages) will be needed to make practical use of the devices.
The lsusb
utility can be used to learn more about USB devices:
$ lsusb
Example output:
The above output shows seven USB busses are detected (001
– 007
). Only the fifth bus (005
) shows devices attached — a Logitech mouse and keyboard. These devices have a vendor ID of 046d
and product IDs of c007
and c31c
, respectively.
Note: The IDs for each device can be used to look up what device they are. This is especially helpful if they have a vague description.
There are several options for lsusb
:
Feature | Option | Description |
Be Verbose |
|
Produces extended information about each device. |
Restrict Bus and Device Number | -s [[bus]:][devnum] |
Restricts the output to the specified bus and device number. |
Restrict Vendor and Product | -d [vendor]:[product] |
Limits the output to a particular vendor and product.vendor and product are the codes just after the ID on each line of the basic output. |
Display Device by Filename | -D <filename> |
Displays information about the device that’s accessible via <filename> , which should be a file in the /proc/bus/usb directory tree.This directory provides a low-level interface to USB devices. |
Tree View | -t |
Displays the device list as a tree. This makes it easier to see which devices are connected to which controllers. |
Version | -V --version |
Displays the version of the lsusb utility. |
Note: Early Linux USB implementations required separate drivers for every USB device. Many of these drivers remain in the kernel, and some software relies on them. For instance, USB disk storage devices use USB storage drivers that interface with Linux’s SCSI support, making USB hard disks, removable disks, and so on look like SCSI devices.
Linux provides a USB filesystem that in turn provides access to USB devices in a generic manner. This filesystem appears as part of the /proc
virtual filesystem.
In particular, USB device information is accessible from /proc/bus/usb
. Subdirectories of /proc/bus/usb
are given numbered names based on the USB controllers instead of the computer, as in /proc/bus/usb/001
for the first USB controller.
USB Manager Applications
USB can be challenging for OSs because it was designed as a hot-pluggable technology. The Linux kernel wasn’t originally designed with this sort of activity in mind, so the kernel relies on external utilities to help manage matters. Two tools in particular are used for managing USB devices: usbmgr
and hotplug
.
Note: While these tools are not commonly installed by default in Linux distributions, they can come in handy when working with USB devices.
The usbmgr
package (located at http://freecode.com/projects/usbmgr) is a program that runs in the background to detect changes on the USB bus. When it detects changes, it loads or unloads the kernel modules that are required to handle the devices. This package uses configuration files in /etc/usbmgr
to handle specific devices and uses /etc/usbmgr/usbmgr.conf
to control the overall configuration.
With a shift from in-kernel device-specific USB drivers to the USB device filesystem (/proc/bus/usb
), usbmgr
has been declining in importance.
Instead of usbmgr
, most distributions rely on the Hotplug package (http://linux-hotplug.sourceforge.net), which relies on kernel support added with the 2.4.x kernel series.
The Hotplug system uses files stored in /etc/hotplug
to control the configuration of specific USB devices. In particular, /etc/hotplug/usb.usermap
contains a database of USB device IDs and pointers to scripts in /etc/hotplug/usb
that run when devices are plugged in or unplugged. These scripts might change permissions on USB device files so that ordinary users can access USB hardware, run commands to detect new USB disk devices, or otherwise prepare the system for a new (or newly removed) USB device.
Configuring Hard Disks
Three different hard disk interfaces are common on modern computers:
- Parallel Advanced Technology Attachment (PATA), aka ATA
- Serial Advanced Technology Attachment (SATA)
- Small Computer System Interface (SCSI)
In addition, external USB and IEEE-1394 drives are available, as are external variant of SATA and SCSI drives. Each has its own method of low-level configuration.
Configuring PATA Disks
As the name implies, PATA disks use a parallel interface, meaning that several bits of data are transferred over the cable at once. Because of this, PATA cables are wide — supporting a total of either 40 or 80 lines, depending on the variety of PATA.
PATA cables allow for up to two devices to be connected to a motherboard or plug-in PATA controller.
PATA disks must be configured as either a master or slave device. This can be done via jumpers on the disks themselves. Typically, the master device sits at the end of the cable, and the slave device resides on the middle connector. However, all modern PATA disks also support an option called cable select. When set to this option, the drive attempts to configure itself automatically based on its position on the PATA cable.
For best performance, disks should be placed on separate controllers rather than configured as a master and slave on a single controller, because each PATA controller has a limited throughput that may be exceeded by two drives.
In Linux, PATA disks have traditionally been identified as /dev/hda
, /dev/hdb
, and so on, with /dev/hba
being the master drive on the first controller, /dev/hdb
being the slave drive on the first controller, etc.
Because of the traditional naming conventions, gaps can occur in the numbering scheme (i.e. if two master drives are on their own controllers, /dev/hda
and /dev/hdc
will show up but not /dev/hdb
).
Partitions are identified by numbers after the main device name, as in /dev/hda1
, /dev/hda2
, etc.
These disk naming rules also apply to optical media; and most Linux distributions also create a link to the optical drive under the name /dev/cdrom
or /dev/dvd
.
Note: Most modern Linux distributions favor newer PATA drivers that treat PATA disks as if they were SCSI disks. As such, PATA disks will follow the naming conventions of SCSI disks instead.
Configuring SATA Disks
As the word serial implies, SATA is a serial bus — only one bit of data can be transferred at a time. SATA transfers more bits per unit of time on its data line, making SATA faster than PATA (1.5 – 6.0Gbps for SATA vs. 128 – 1,064Mbps for PATA).
Most Linux SATA drivers treat SATA disks as if they were SCSI disks. Some older drivers treat SATA disks like PATA disks, so they may use PATA names in rare circumstances.
Configuring SCSI Disks
There are many types of SCSI definitions, which use a variety of different cables and operate at various speeds.
SCSI is traditionally a parallel bus, like PATA, but the latest variant, Serial Attached SCSI (SAS), is a serial bus like SATA.
SCSI supports up to 8 or 16 devices per bus, depending on the variety. One of these devices is the SCSI host adapter, which is either built into the motherboard or comes as a plug-in card. In practice, the number of devices that can be attached to a SCSI bus is more restricted because of cable-length limits, which varies from one SCSI variety to another.
Each device has its own SCSI ID number, typically assigned via a jumper on the device. Each device must have its own unique ID.
SCSI IDs are not used to identify the corresponding device file on a Linux system.
- Hard drives follow the naming convention
/dev/sdx
(where x is a letter froma
up). - SCSI tapes are named
/dev/stx
and/dev/nstx
(where x is a number from0
up). - SCSI CD-ROMs and DVD-ROMs are named
/dev/scdx
or/dev/srx
(where x is a number from0
up).
SCSI device numbering (or lettering) is usually assigned in increasing order based on the SCSI ID. For example, if one hard disk has a SCSI ID of 2 and another hard disk has a SCSI ID of 4, they will be assigned to /dev/sda
and /dev/sdb
, respectively.
If a new SCSI disk is added with a lower ID, it will bump up the device letter.
Note: The mapping of Linux device identifiers to SCSI devices depends in part on the design of the SCSI host adapters. Some host adapters result in assignments starting from SCSI ID 7
and work down to 0
, with Wide SCSI device numbering starting at ID 14
down through 8
.
Another complication is when there are multiple SCSI host adapters on one machine. In this case, Linux assigns device filenames to all of the disks on the first adapter, followed by all of those on the second adapter. Depending on where the drivers for the SCSI host adapters are found (compiled directly into the kernel or loaded as modules) and how they’re loaded (for modular drivers), it may not be possible to control which adapter takes precedence.
Note: Remember that some non-SCSI devices, such as USB disk devices and SATA disks, are mapped onto the Linux SCSI subsystem. This can cause a true SCSI hard disk to be assigned a higher device ID than expected.
The SCSI bus is logically one-dimensional — that is, every device on the bus falls along a single line. This bus must not fork or branch in any way. Each end of the SCSI bus must be terminated. This refers to the presence of a special resistor pack that prevents signals from bouncing back and forth along the SCSI chain. Consult with a SCSI host adapter and SCSI device manual to learn how to properly terminate them.
Configuring External Disks
External disks come in several varieties, the most common of which are USB, IEEE-1394, and SCSI (SCSI has long supported external disks directly, and many SCSI host adapters have both internal and external connectors).
Linux treats external USB and IEEE-1394 disks just like SCSI devices, from a software point of view. Typically, a device can be plugged in, a /dev/sdx
device node will appear, and it can be used the same way a SCSI disk can be.
Note: External drives are easily removed, and this can be a great convenience; however, external drives should never be unplugged until they’ve been unmounted in Linux using the umount
command.
Designing a Hard Disk Layout
Whether a system uses PATA, SATA, or SCSI disks, a disk layout must be designed for Linux.
Why Partition?
Partitioning provides a variety of advantages, including:
Multiple-OS Support
Partitioning keeps the data for different OSs separate — allowing many OSs to easily coexist on the same hard disk.
Filesystem Choice
Different filesystems — data structures designed to hold all of the files on a partition — can be used on each partition if desired.
Disk Space Management
By partitioning a disk, certain sets of files can be locked into a fixed space. For example, if users are restricted to storing files on one or two partitions, they can fill those partitions without causing problems on other partitions, such as system partitions. This feature can help keep your system from crashing if space runs out.
Disk Error Protection
Disks sometimes develop problems. These problems can be the result of bad hardware or errors that creep into the filesystems. Splitting a disk into partitions provides some protection against such problems.
Security
You can use different security-related mount options on different partitions. For instance, a partition that holds critical systems files might be mounted in read-only mode, preventing users from writing to that partition.
Backup
Some backup tools work best on whole partitions. By keeping partitions small, backups can be made easier than they would be if the partitions were large.
Understanding Partitioning Systems
Partitions are defined by data structures that are written to specified parts of the hard disk.
Several competing systems for defining partitions exist. On x86 and x86_64 hardware, the most common method up until 2010 had been the Master Boot Record (MBR) partitioning system. It was called this because it stores its data in the first sector of the disks, known as the MBR.
The MBR system is limited in the number of partitions it supports, and partition placement cannot exceed 2 tebibytes when using the nearly universal sector size of 512 bytes.
The successor to MBR is the GUID Partitioning Table (GPT) partitioning system, which has much higher limits and certain other advantages.
Note: Still more partitioning systems exist. For instance, Macintoshes that use PowerPC CPUs generally employ the Apple Partitioning MAP (APM), and many Unix variants employ Berkeley Standard Distribution (BSD) disk labels.
MBR Partitions
The original x86 partitioning scheme allowed for only four partitions.
As hard disks increased in size, and the need for more partitions became apparent, this original scheme was extended while retaining backwards compatibility. The new scheme uses three partitioning:
- Primary partitions – which are the same as the original partition types.
- Extended partitions – which are a special type of primary partition that serve as placeholders for logical partitions.
- Logical partitions – which reside within an extended partition.
Because logical partitions reside within a single extended partition, all logical partitions must be contiguous.
The MBR partitioning system uses up to four primary partitions, one of which can be an extended partition that contains logical partitions.
Many OSs, such as Windows, and FreeBSD, must boot from primary partitions. Because of this, most hard disks include at least one primary partition. Linux is not limited like this, and can be booted from a disk containing no primary partitions.
The primary partitions have numbers in the range of 1-4
, whereas logical partitions are numbered 5
and up. Gaps can appear in the numbering of MBR primary partitions; however, such gaps cannot exist in the numbering of logical partitions.
In addition to holding the partition table, the MBR data structure holds the primary BIOS boot loader — the first disk-loaded code that the CPU executes when a BIOS-based computer boots.
Because the MBR exists only in the first sector of the disk, it’s vulnerable to damage. Accidental erasure of the MBR will make the disk unusable unless a backup was made previously.
Note: The MBR partitions can be backed up with sfdisk -d /dev/sda > sda-backup.txt
. The backup file can then be copied to a removable disk or another computer for safekeeping. To restore a backup: sfdisk -f /dev/sda < sda-backup.txt
.
Note2: Another option to backup the MBR is with dd if=/dev/sda of=/root/sda.mbr count=1 bs=512
. This uses the dd
command to make a full backup of the first 512 bytes. Restoring the MBR would just involve swapping the if
and of
values (i.e. dd if=/root/sda.mbr of=/dev/sda
).
MBR partitions have type codes, which are 1-byte (two-digit hexadecimal) numbers, to help identify their purpose.
Common type codes include:
0x0c
(FAT)0x05
(old type of extended partition)0x07
(NTFS)0x0f
(newer type of extended partition)0x82
(Linux swap)0x83
(Linux filesystem)
GPT Partitions
GPT is part of Intel’s EFI specification, but GPT can be used on computers that don’t use EFI.
GPT employs a protective MBR, which is a legal MBR definition that makes GPT-unaware utilities think that the disks holds a single MBR partition that spans the entire disk. Additional data structures define the true GPT partitions. These data structures are duplicated, with one copy at the start of the disk and another at its end. This provides redundancy that can help in data recovery should an accident damage one of the two sets of data structures.
GPT does away with the primary/extended/logical distinction of MBR. Up to 128 partitions can be defined by default (with the limit able to be raised, if necessary). Gaps can occur in the partition numbering, however, GPT partitions are usually numbered consecutively starting with 1
.
GPT’s main drawback is that support for it is relatively immature. The fdisk
utility doesn’t work with GPT disks, although alternatives to fdisk
are available. Some version of the GRUB boot loader also don’t support it.
Like MBR, GPT supports partition type codes; however, GPT type codes are 16-byte GUID values. Disk partitioning tools typically translate these codes into short descriptions, such as “Linux swap”.
Confusingly, most Linux installations use the same type code for their filesystems that Windows uses for its filesystems, although a Linux-only code is available and gaining popularity among Linux distributions.
An Alternative to Partitions: LVM
An alternative to partitions for some functions is logical volume management (LVM).
To use LVM, one or more partitions are set aside and assigned MBR partition type codes of 0x8e
(or an equivalent on GPT disks). Then a series of utilities, such as pvcreate
, vgcreate
, lvcreate
, and lvscan
, are used to manage the partitions (known as physical volumes in this scheme). These physical volumes can be merged into volume groups; and logical volumes can also be made within the volume groups. Ultimately these logical volumes are assigned names in the /dev/mapper
directory for access, such as /dev/mapper/myvolume-home
.
The biggest advantage to LVM is that it grants the ability to resize logical volumes easily, without worrying about the positions or sizes of the surrounding partitions.
It’s easiest to configure a system with at least one filesystem (dedicated to /boot
, or perhaps the root filesystem containing /boot
) in its own conventional partition, reserving LVM for /home
, /usr
, and other filesystems.
LVM is most likely to be useful for creating an installation with many specialized filesystems while retaining the option of resizing those filesystems in the future, or if a filesystem larger than any single hard disk is necessary.
Mount Points
Once a disk is partitioned, an OS must have some way to access the data on the partitions.
In Windows, assigning a drive letter, such as C: or D:, to each partition does this (Windows uses partition type codes to decide which partitions get drive letters and which to ignore). Linux doesn’t use drive letters. Instead, Linux uses a unified directory tree.
Each partition is mounted at a mount point in the directory tree.
A mount point is a directory that’s used as a way to access the filesystem on the partition, and mounting the filesystem is the process of linking the filesystem to the mount point.
Partitions are mounted just about anywhere in the Linux directory tree, including in directories on the root partition as well as directories on mounted partitions.
Common Partitions and Filesystem Layouts
Note: The typical sizes for many of the following partitions can vary greatly depending on how the system is used.
Common partitions and their uses:
Partition (Mount Point) | Typical Size | Use |
Swap (not mounted) |
1 – 2x the system RAM size | Serves as an adjunct to system RAM. It is slow but enables the computer to run more or larger programs, and allows for hibernation mode from the power menu. |
/home |
200 MiB – 3 TiB (or more) |
Holds user’s data files. Isolating it on a separate partition preserves user data during a system upgrade. Size depends on the number of users and their data storage needs. |
/boot |
100 – 500 MiB |
Holds critical boot files. Creating it as a separate partition lets you circumvent limitations on older BIOSs and boot loaders, which often can’t boot a kernel from a point above a value between 504 MiB and 2 TiB. |
/usr |
500 MiB – 25 GiB |
Holds most Linux program and data files. Changes implemented in 2012 are making it harder to create a separate /usr partition in many distributions. |
/usr/local |
100 MiB – 3 GiB |
Holds Linux program and data files that are unique to this installation, particularly those that you compile yourself. |
/opt |
100 MiB – 5 GiB |
Holds Linux program and data files that are associated with third-party packages, especially commercial ones. |
/var |
100 MiB – 3 TiB (or more) |
Holds miscellaneous files associated with the day-to-day functioning of a computer. These files are often transient in nature. Most often split off as a separate partition when the system functions as a server that uses the /var directory for server-related files like mail queues. |
/tmp |
100 MiB – 20 GiB |
Holds temporary files created by ordinary users. |
/mnt |
N/A | Not a separate partition; rather, it or its subdirectories are used as mount points for removal media like CDs and DVDs. |
/media |
N/A | Holds subdirectories that may be used as mount points for removable media, much like /mnt or its subdirectories. |
Some directories — /etc
, /bin
, /sbin
, /lib
, and /dev
— should never be placed on separate partitions. These directories host critical system configuration files or files without which a Linux system cannot function. For instance, /etc
contains /etc/fstab
, the file that specifies what partitions correspond to what directories, and /bin
contains the mount
utility that’s used to mount partitions on directories.
Note: The 2.4.x and newer kernels include support for a dedicated /dev
filesystem, which obviates the need for files in a disk-based /dev
directory; so, in some sense, /dev
can reside on a separate filesystem, although not a separate partition. The udev
utility controls the /dev
filesystem in recent version of Linux.
Creating Partitions and Filesystems
Partitioning involves two tasks:
- Creating the partitions.
- Preparing the partitions to be used.
Partitioning a Disk
The traditional Linux tool for MBR disk partitioning is called fdisk
. This tool’s name is short for fixed disk.
Although fdisk
is the traditional tool, several others exist. One of these in GNU Parted, which can handle several different partition table types, not just the MBR that fdisk
can handle.
Note: If you prefer fdisk
to GNU Parted, but must use GPT, there is GPT fdisk (http://www.rodsbooks.com/gdisk/). This package’s gdisk
program works much like fdisk
but on GPT disks.
Using fdisk
To use Linux’s fdisk
, type the command name followed by the name of the disk device to be partitioned:
# fdisk /dev/hda
Command (m for help):
At the interactive prompt, there are several options:
Effect | Option | Description |
Display the Current Partition Table |
|
Displays the current partition table. |
Create a Partition | n |
Results in a series of prompts for information about the partition to be created — whether it should be a primary, extended, or logical partition; the partition’s starting cylinder; the partition’s ending cylinder or size; etc. A partition’s size can be specified with a plus sign, number, and suffix (ex. +20G ).Note: Failure to align partitions properly can result in severe performance degradation. For more information see: http://www.ibm.com/developerworks/library/l-linux-4kb-sector-disks/index.html |
Delete a Partition | d |
If more than one partition exists, the program will ask for the partition number to be deleted. |
Change a Partition’s Type | t |
Prompts for a partition number and type code for a partition.fdisk assigns a type code of 0x83 by default. If a swap partition or some other partition type is desired, this option can be used.Note: Typing L during the prompt will list available partition types. |
List Partition Types | l |
Lists the most common partition type codes. |
Mark a Partition Bootable | a |
Sets a bootable flag on the partition. Some OSs, such as Windows, rely on such bootable flags in order to boot. |
Get Help | m ? |
Provides a summary of fdisk commands. |
Exit | q w |
q exits without saving any changes.w exists after writing the changes to disk. |
Using gdisk
To work with a GPT-formatted hard drive, the gdisk
utility will need to be using instead of fdisk
.
On the surface, gdisk
works nearly identical to fdisk
.
To display existing partitions, use the print
command:
$ gdisk /dev/sda
Command (? for help): print
Remember that GPT format doesn’t use primary, extended, or logical partitions — all partitions are the same.
The Code
column shows the 16-byte GUID value for the GPT partition, indicating the type of partition.
The 8200
code is the proper code for a Linux swap area, and 8300
is the code commonly used for Linux partitions. 0700
is a Windows partition code, which is sometimes used even in Linux distributions instead of 8300
.
Using GNU Parted
GNU Parted (http://www.gnu.org/software/parted/) is a partitioning tool that works with MBR, GPT, APM, and BSD disk labels, and other disk types.
Although GNU Parted isn’t covered on the exam, knowing a bit about it can be handy.
To start GNU Parted:
$ parted /dev/sda
At the parted prompt, ?
can be entered for a help menu. To display the current partition table use the print
command. To create a GPT disk, use the mklabel
command. To create a new partition, use the mkpart
command.
Note: Some more advanced partition capabilities appear in GUI tools, such as the GNOME Partition Editor (http://gparted.sourceforge.net), aka GParted.
Preparing a Partition for Use
Once a partition is created, it must be prepared for use. This process is often called “making a filesystem” or “formatting a partition”. It involves writing low-level data structures to disk.
Note: The word formatting is somewhat ambiguous. It can refer either to low-level formatting, which creates a structure of sectors and tracks on the disk media, or high-level formatting, which creates a filesystem. Hard disks are low-level formatted at the factory and should never need to be low-level formatted again.
Common Filesystem Types
Ext2fs
The Second Extended File System (ex2fs or ext2) is the traditional Linux-native filesystem.
The ext2 filesystem type code is ext2
.
Ext3fs
The Third Extended File System (ext3fs or ext3) is basically ext2fs with a journal added.
The ext3 filesystem type code is ext3
.
Ext4fs
The Fourth Extended File System (ext4fs or ext4) adds extensions intended to improve performance, the ability to work with very large disks (over 16 TiB, which is the limit for ext2 and ext3), and the ability to work with very large files (>2 TiB).
The ext4 filesystem type code is ext4
.
ReiserFS
A journaling filesystem designed from scratch for Linux. It’s particularly good at handling large numbers of small files because ReiserFS uses various tricks to squeeze the ends of the files into each other’s unused space.
The type code for this filesystem is reiserfs
.
JFS
IBM developed the Journaled File System (JFS) for its AIX OS on mainframe systems and later reimplemented it on its attempt at a workstation OS, called OS/2. After the demise of OS/2, the OS/2 version of JFS was subsequently donated to Linux.
The type code for JFS is jfs
.
XFS
Silicon Graphics (SGI) created its Extents File System (XFS) for its IRIX OS, and like IBM, later donated the code to Linux.
The type code for XFS is xfs
.
Btrfs
Pronounced as “butter eff ess” or “bee tree eff ess”) is an advanced filesystem with features inspired by those of Sun’s Zettabyte File System (ZFS). Like ext4fs, JFS, and XFS, Btrfs is a fast performer, and is able to handle very large disks and files.
In addition to Linux-native filesystems, additional filesystems may need to be dealt with from time to time, including:
FAT
The File Allocation Table (FAT) filesystem is old and primitive — but ubiquitous. Every major OS understands FAT, making it an excellent filesystem for exchanging data on removable disks.
Two major orthogonal variants of FAT exist: they vary in the size of the FAT data structure, after which the filesystem is named (12-, 15- or 32-bit pointers), and have variants that support long filenames. Linux automatically detects the FAT size.
The original FAT filenames are limited to eight characters with an optional three-character extension (8.3 filenames). To use the original FAT filenames, use the Linux filesystem type code of msdos
.
To use Windows-style long filenames, use the type code of vfat
. A Linux-only long filename system also exists with a type code of umsdos
, and supports additional Linux features.
NTFS
The New Technology File System (NTFS) is the preferred filesystem for Windows NT and beyond.
As of the 2.6.x kernel series, Linux can reliably read NTFS and can overwrite existing files, but the Linux kernel can’t write new files to an NTFS partition. There are separate drivers outside of the kernel that can be used in Linux to create new files on an NTFS filesystem — the most popular of which is the NTFS-3G driver.
HFS and HFS+
Apple has long used the Hierarchical File System (HFS) with its Mac Os; and Linux provides full read/write support for HFS.
HFS+ is an extended version of HFS that better supports large hard disks and many Unix-like features.
Linux 2.6.x and newer kernels provide limited HFS+ support, but write support works only with the HFS+ journal disabled.
ISO-9660
The standard filesystem for CD-ROMs has long been ISO-9660.
This filesystem comes in several levels:
- Level 1 – Similar to the original FAT in that it supports only 8.3 filenames.
- Levels 2 & 3 – Adds support for longer 32-character filenames.
Linux supports ISO-9660 using its iso9660
filesystem type code.
Linux’s ISO-9660 support also works with the Rock Ridge extensions, which are a series of extensions to ISO-9660 to enable it to support Unix-style long filenames, permissions, symbolic links, and so on. Similarly, Joliet provides support for long filenames as implement for Windows. If a disc includes Rock Ridge or Joliet extensions, Linux will automatically detect and use them.
UDF
The Universal Disc Format (UDF) is the next-generation filesystem for optical discs. It’s commonly used on DVD-ROMs and recordable optical discs. Linux supports it, but read/write UDF support is still in its infancy.
Note: ISO-9660 and other optical disc filesystems are created with special tools intended for this purpose. Specifically, mkisofs
creates an ISO-9660 filesystem (optionally with Rock Ridge, Joliet, HFS, and UDF components added) while cdrecord
writes this image to a black CD-R. The growisofs
program combines both functions but only works on recordable DVD media.
Creating a Filesystem
Linux filesystem tools have filenames in the form of mkfs.fstype
, where fstype
is the filesystem type code. These tools can also be called from a front-end tool called mkfs
; where the filesystem type code is passed after the -t
option:
# mkfs -t ext3 /dev/sda2
Note: For ext2 and ext3 filesystems, the mke2fs
program is often used instead of mkfs
. The mke2fs
program is just another name for mkfs.ext2
.
The -c
option is supported by several filesystems, and causes the tool to perform a bad-block check — every sector in the partition is checked to be sure it can reliably hold data. If it can’t, the sector is marked as bad and isn’t used.
The -m <percent>
option can be used to specify a reserved-space percentage. This leaves additional space for root
on the filesystem; preventing ordinary users from completely filling the disk and preventing the creation of new files. The default value is 5%
if the -m
option is not passed with a value.
Linux distributions also provide tools for various non-Linux filesystems. The most important of these may be for FAT. The main tool for this task is called mkdosfs
, but it’s often linked to the mkfs.msdos
and mkfs.vfat
names as well.
This program can automatically adjust the size of the FAT data structure to 12, 16, or 32 bits depending on the device size. To override this option, the -F <fat-size>
option can be used (where <fat-size>
is the size in bits — 12
, 16
, or 32
).
No special options are required to create a FAT filesystem that can handle Windows-style (VFAT) long filenames; the OS creates these.
Creating Swap Space
Linux can use a swap partition, which is a partition that Linux treats as an extension of memory; or a swap file, which is a file that works in the same way. Both are examples swap space.
Linux uses the MBR partition type code of 0x82
to identify swap space, but as with other partitions, this code is mostly a convenience to keep other OSs from trying to access Linux swap partitions.
Linux uses /etc/fstab
to define which partitions to use as swap space.
Note: Solaris for x86 also uses an MBR partition type code of 0x82
to refer to a Solaris partition. In order to prevent issues when dual-booting between Solaris and Linux, it may be necessary to use Linux’s fdisk
to change the partition type codes temporarily to keep Linux from trying to use a Solaris partition as swap space, or to keep Solaris from trying to interpret Linux swap space as a data partition.
In order to prepare swap space, use the mkswap
command:
# mkswap /dev/sda3
To use the swap space temporarily, activate it with the swapon
command:
# swapon /dev/sda3
To activate swap space permanently, create an entry for it in the /etc/fstab
file.
Maintaining Filesystem Health
Filesystems can become “sick” in a variety of ways. They can become overloaded with too much data, they can be tuned inappropriately for the system’s use, or they can become corrupted because of buggy drivers, buggy utilities, or hardware errors.
Note: Many of Linux’s filesystem maintenance tools should be run when the filesystem is not mounted. Changes made by maintenance utilities while the filesystem is mounted can confuse the kernel’s filesystem drivers, resulting in data corruption.
Tuning Filesystems
Filesystems are basically just big data structures — they’re a means of storing data on disk in an indexed method that makes it easy to locate the data at a later time.
Some filesystems include tools that provide options that affect performance. For example, ext2/3/4 provides these tools for tuning their filesystems:dumpe2fs
, tune2fs
, and debugfs
. The first tool provides information about the filesystem, and the other two provide the ability to change tuning options.
Obtaining Filesystem Information
A lot of information about an ext2 or ext3 filesystem can be gathered from the dumpe2fs
command:
dumpe2fs [options] <device>
<device>
is the filesystem device file, such as /dev/sdb9
.
The -h
option can be used to omit information about group descriptors (which are useful in very advanced filesystem debugging but not for basic filesystem tuning).
The information displayed from dumpe2fs
can be immediately understood but some parts may be puzzling. For example, Inode count
is a count of the number of inodes supported by the filesystem. Each inode contains information for one file; and because Linux treats everything as a file (including directories), the inode count is effectively the limit to the number of files, directories, etc. that can be stored on the filesystem.
dumpe2fs
can be safely run on a mounted filesystem.
Most other filesystems lack an equivalent to dumpe2fs
, but XFS provides a similar application with xfs_info
:
# xfs_info /dev/sda5
In addition to using the partition name, xfs_info
can accept the mount point as well:
# xfs_info /home
Another XFS tool is xfs_metadump
, which copies the filesystem’s metadata (filenames, file sizes, etc.) to a file:
# xfs_metadump /dev/sda5 ~/dumpfile
This dump file is intended for debugging purposes if the filesystem is behaving strangely, and can be sent to XFS developers for study.
Adjusting Tunable Filesystem Parameters
tune2fs
can be used to change many of the filesystem parameters reported by dumpe2fs
:
tune2fs [options] <device>
There are many options that tune2fs
supports:
Effect | Option | Description |
Adjust the Maximum Mount Count | -c <num-mounts> |
Ext2fs, ext3fs, and ext4fs require a periodic disk check with fsck . The disk check is designed to prevent errors from creeping onto the disk undetected. This option can be used to change the number of times the disk can be mounted without a disk check.<num-mounts> is the number of mounts. |
Set the Mount Count | -C <mount-num> |
Sets the number of times the disk has been mounted to |
Adjust the Time between Checks | -i <interval> |
Periodic disk checks are required based on time as well as the number of mounts. <interval> is a number with the character d , w , or m appended — representing days, weeks, or months, respectively.ex. -i 2w for two weeks. |
Add a Journal | -j |
Adds a journal to the filesystem (effectively converting ext2 to ext3). |
Set the Reserved Blocks | -m <percent> |
Sets the percentage of disk space reserved for use by root . The default value is 5% , even when this option is not called explicitly. Note: Reserved space can also be set using a value in blocks with the -r option. |
Note: tune2fs
should not be used to adjust a mounted filesystem. To adjust a key mounted filesystem, such as the root (/
) filesystem, it may be necessary to boot up an emergency disk system — such as Parted Magic (http://partedmagic.com), or a distributions’ install disc.
In XFS, the xfs_admin
command is roughly equivalent to tune2fs
. Some of it’s options include:
Effect | Option | Description |
Use Version 2 Journal Format | -j |
Enables version 2 log (journal) format, which can improve performance in some situations. |
Obtain the Filesystem Label and UUID | -l -u |
A filesystem’s label (name) can be acquired with the -l option; and its universally unique identifier (UUID) can be acquired with the -u option.Note: The blkid command can display the label and UUID of any partition’s filesystem, not just an XFS partition. |
Set the Filesystem Label and UUID | -L <label> -U <uuid> |
Sets a filesystem’s label or UUID. The label is at most 12 characters in length. The word generate can be used for the UUID value to create a new UUID. |
An example of using xfs_admin
would be:
# xfs_admin -L game_data /dev/sda5
This would set the name of the filesystem on /dev/sda5
to game_data.
Interactively Debugging a Filesystem
A filesystem’s features can be interactively modified using the debugfs
command:
# debugfs /dev/sdb2
debugfs:
There are several subcommands that can be used at this prompt:
At the interactive prompt, there are several options:
Effect | Subcommand | Description |
Display Filesystem Superblock Information | show_super_stats |
Produces superblock information, similar to what dumpe2fs displays. |
Display Inode Information | stat <filename> |
Displays the inode data on a file or directory. |
Undelete a File | undelete <inode> <name> |
Undeletes a file where <inode> is the inode number of the deleted file and <name> is the filename to recover it as. |
Extract a File | write <internal-file> <external-file> |
Extracts a file from the filesystem being manipulated to the main Linux system. Note: This subcommand can be useful if a filesystem is badly damaged and a critical file needs to be extracted without mounting the filesystem. |
Manipulate Files | cd , ln , rm , etc. |
Most shell commands work as subcommands for debugfs . |
Get Help | list_requests lr help ? |
Produces a summary of available commands. |
Exit | quit |
Exits from the program. |
Note: Although debugfs
is a useful tool, it’s potentially dangerous. Do not use it on a mounted filesystem, and do not use it unless you must.
Be aware that the exam does cover debugfs
. For more information, consult man debugfs
.
The closest XFS equivalent for debugfs
is xfs_db
. However, this tool is only intended for XFS experts to use.
Maintaining a Journal
Ext2fs suffers from a major limitation: after a power failure, a system crash, or another uncontrolled shutdown, the filesystem could be in an inconsistent state. The only way to mount the filesystem safely so that you’re sure its data structures are valid is to perform a full disk check on it.
The solution to this problem is to change to a journaling filesystem. Such a filesystem maintains a journal, which is a data structure that describes pending operations. Prior to writing data to the disk’s main data structures, Linux describes what it’s about to do in the journal. When the operations are complete, their entries are removed from the journal.
In the event of a crash or power failure, the system can examine the journal and check only those structures described within it. If inconsistencies are found, the system can roll back or complete the changes, returning the disk to a consistent state without having to check every data structure in the filesystem.
Five journaling filesystems are common on Linux:
- ext3fs
- ext4fs
- ReiserFS
- XFS
- JFS
A journal can be added to an ext2 filesystem to convert it into an ext3 filesystem (via the -j
option on tune2fs
.
Note: Although using tune2fs
on a mounted filesystem is generally inadvisable, it’s safe to use it’s -j
option on a mounted filesystem. The result is a file called .journal
that holds the journal. If you add a journal to an unmounted filesystem, the journal file will be invisible.
To use a journal, the filesystem must be mounted with the correct filesystem type code — ext3
rather than ext2
for ext3fs or ext4
for ext4fs.
The journal, like other filesystem features, has its own set of parameters. These can be set with the -J
option of tune2fs
. In particular, the size=<journal-size>
and device=<external-journal>
suboptions enable the ability to set the journal’s size and the device on which it’s stored. By default, the system creates a journal that’s the right size for the filesystem, and stores the journal on the filesystem itself.
Checking Filesystems
Bugs, power failures, and mechanical problems can all cause the data structures on a filesystem to become corrupted.
Linux includes tools for verifying a filesystem’s integrity and for correcting any problems that may exist. The main tool for this is fsck
. This program is actually a front end to other tools, such as e2fsck
(aka fsck.ext2
, fsck.ext3
, and fsck.ext4
) or XFS’s xfs_check
and xfs_repair
. The syntax for fsck
is:
fsck [-sACVRTNP) [-t <fstype>] [--] [<fsck-options>] <filesystems>
Common parameters of fsck
:
Effect | Option | Description |
Check All Files | -A |
Check all of the filesystems marked to be check in /etc/fstab .This option is normally used in system startup scripts. |
Indicate Progress | -C |
Displays a text-mode progress indicator of the check progress. Most check programs don’t support this feature, but e2fsck does. |
Show Verbose Output | -V |
Produces verbose output of the check process. |
No Action | -N |
Displays what it would normally do without actually doing it (i.e. a dry run). |
Set the Filesystem Type | -t <fstype> |
Force the type. Used in conjunction with -A , this causes the program to check only the specified filesystem types, even if others are marked to be checked. Note: If <fstype> is prefixed with no , then all filesystems except the specified type are checked. |
Filesystem-Specific Options | -- -a -- -p -- -r -- -f |
Filesystem check programs for specific filesystems often have their own options. The double dash (-- ) option passes these options to the underlying check program.-a or -p performs an automatic check.-r performs an interactive check.-f forces a full filesystem check even if the filesystem initially appeared to be clean. |
Note: Run fsck
only on filesystems that are not currently mounted or that are mounted in read-only mode. Changes written to disk during normal read/write operations can confuse fsck
and result in filesystem corruption.
Linux runs fsck
automatically at startup on partitions that are marked for this in /etc/fstab
.
The normal behavior of e2fsck
causes it to perform just a quick cursory examination of a partition if it’s been unmounted cleanly. However, e2fsck
forces a check if the disk has gone longer than a certain amount of time without checks (normally six months) or if the filesystem has been mounted more than a certain number of times since the last check (normally 20). These options can be changed using tune2fs
.
Journaling filesystems do away with full filesystem checks at system startup even if the system wasn’t shut down correctly. However, if odd behavior is encountered with a journaling filesystem, it is recommended to unmount it and perform a filesystem check.
Some Linux distributions do odd things with some journaling filesystem check programs. For instance, Mandriva uses a symbolic link from /sbin/fsck.reiserfs
to /bin/true
. This configuration speeds system boot times should ReiserFS partitions be marked for automatic checks, but can be confusing if you need to check the filesystem manually. If this is the case, run /sbin/reiserfsck
to do the job. Similarly, /sbin/fsck.xfs
is usually nothing but a script that advises the user to run xfs_check
or xfs_repair
.
Monitoring Disk Use
The df
and du
programs can summarize disk use on a partition-by-partition and directory-by-directory basis, respectively.
Monitoring Disk Use by Partition
df [options] [files]
Without any options or files passed to df, it will provide a summary of disk space used on all of a system’s partitions.
Several options exist for df
:
Effect | Option | Description |
Include All Filesystems | -a --all |
Includes pseudo-filesystems with a size of 0 in the output. Such filesystems include /proc , /sys , /proc/bus/usb , etc. |
Use Scaled Units (Power 2) |
-h --human-readable |
Scale and label units in kibibytes (KiB), mebibytes (MiB), gibibytes (GiB), etc. |
Use Scaled Units (Power 10) |
-H --si |
Scale and label units in kilobytes (KB), megabytes, (MB), gigabytes (GB), etc. Note: -k /--kilobytes and -m/--megabytes options also output in their respective units. |
Summarize Inodes | -i --inodes |
By default, df summarizes used and available disk space. This option changes the output to used and available inodes. Note: This option works well on ext2, ext3, ext4, XFS, and some other filesystems with a fixed number of inodes when the filesystem is created. Other filesystems, such as ReiserFS and Btrfs, create inodes dynamically and render this option meaningless. |
Local Filesystems Only | -l --local |
Omit network filesystems. |
Display Filesystem Type | -T --print-type |
Adds filesystem type to the information displayed. |
Limit by Filesystem Type | -t <fstype> --type=<fstype>
|
Displays information about filesystems of a specified type, or excludes filesystems of a specified type, from the report. |
Monitoring Disk Use by Directory
du [options] [directories]
This command searches specified directories and reports how much disk space each is consuming. This search is recursive, so it will display the information for the desired directory and all of its subdirectories.
Several options exist for du
:
Effect | Option | Description |
Summarize Files and Directories | -a --all |
By default, du reports on the space used by the files in directories but not the space used by individual files. This option causes du to output that information. |
Compute a Grand Total | -c --total |
Adds a grand total to the end of the output. |
Use Scaled Units (Power 2) |
-h --human-readable |
Scale and label units in kibibytes (KiB), mebibytes (MiB), gibibytes (GiB), etc. |
Use Scaled Units (Power 10) |
-H --si |
Scale and label units in kilobytes (KB), megabytes, (MB), gigabytes (GB), etc. Note: -k /--kilobytes and -m/--megabytes options also output in their respective units. |
Count Hard Links | -l --count-links |
Normally, du counts files that appear multiple times as hard links only once. This reflects true disk space used, but sometimes it may be desireable to count each link independently. This option does just that. |
Limit Depth | --max-depth=<num> |
Limits the report to <num> levels.Note: The subdirectories’ contents are counted even if they aren’t reported. |
Summarize | -s --summarize |
Limits the report to the files and directories specified on the command line. Note: This is equivalent to --max-depth=0 . |
Limit to One Filesystem | -x --one-file-system |
Limits the report to the current filesystem. If another filesystem is mounted within the same tree being summarized, its contents are not included in the report. |
Mounting and Unmounting Filesystems
Filesystems are most often used by being mounted — that is, associated with a directory.
Mounting a filesystem can be accomplished on a one-time basis by using the mount
tool (and then unmounted with the umount
tool). Or a filesystem can be mounted persistently across reboots by editing the /etc/fstab
file.
Temporarily Mounting or Unmounting Filesystems
Syntax and Parameters for mount
mount [-alrsvw] [-t <fstype>] [-o <options>] [<device>] [<mountpoint>]
Common parameters of mount
:
Effect | Parameter | Description |
Mount All Filesystems | -a |
Mount all filesystems listed in /etc/fstab . |
Mount Read-Only | -r |
Mount the filesystem in read-only mode. |
Show Verbose Output | -v |
Produce verbose output to provide comments on operations as they occur. |
Mount Read/Write | -w |
Attempt to mount the filesystem for both read and write operations. This is the default option for most filesystems. Note: -o rw has the same effect. |
Specify the Filesystem Type | -t <fstype> |
Specifies the type of the filesystem by type code:
If this parameter is omitted, Linux will attempt to auto-detect the filesystem type. |
Mount by Label or UUID | -L <label> -U <uuid> |
Mounts the filesystem with the specified label or UUID, respectively. |
Additional Filesystem Options | -o <options> |
Passes additional filesystem specific options. |
Ordinarily, only root
may issue a mount
command; however, if /etc/fstab
specifies the user
, users
, or owner
option, an ordinary user may mount a filesystem using a simplified syntax in which only the device or mount point is specified, but not both. For example, a user may type mount /mnt/cdrom
to mount a CD-ROM if /etc/fstab
specifies /mnt/cdrom
as its mount point and uses the user
, users
, or owner
option.
Note: Most Linux distributions ship with auto-mounter support, which causes the OS to mount removable media automatically when they’re inserted. To eject the disk, the user will need to unmount the filesystem using the umount
command.
When Linux mounts a filesystem, it ordinarily records this fact in /etc/mtab
.
The /etc/mtab
file has a format similar to that of /etc/fstab
and is stored in /etc
, but it’s not a configuration file that should be edited.
Options for mount
Important filesystem options for the mount
command:
Option | Supported Filesystems | Description |
defaults |
All | Uses the default options for the filesystem. This is used primarily in the /etc/fstab file to ensure that a value for an options column is provided. |
loop |
All | Allows the mounting of a file as if it were a disk partition. Ex. mount -t vfat -o loop image.img /mnt/image mounts the file as if it were a disk. |
auto noauto |
All | Sets whether or not the filesystem is mounted at boot time or when root issues the mount -a command.The default is auto , but noauto is appropriate for removable media. This is used in /etc/fstab . |
user nouser |
All |
Sets whether or not ordinary users can mount the filesystem. |
users |
All | Similar to user , except any user may unmount the filesystem once it has been mounted. |
owner |
All | Similar to user , except the user must own the device file.Note: Some distributions, such as Red Hat, assign ownership of some device files (such as /dev/fd0 for the floppy disk) to the console user, making this a helpful option. |
remount |
All | Changes one or more mount options without explicitly unmounting a partition. Often used to enable or disable write access to a partition. |
ro |
All | Specifies a read-only mount of the filesystem. The default option for filesystems without write support (or bad write support). |
rw |
All read/write filesystems | Specifies a read/write mount of the filesystem. The default option for filesystems that have write support. |
uid=<value> |
Most filesystems that do not support Unix-style permissions (ex. vfat , hpfs , ntfs , and hfs ). |
Sets the owner of all files. Note: Check Linux user IDs in the /etc/passwd file. |
gid=<value> |
Same as above | Sets the group of all files. Note: Check Linux group IDs in the /etc/group file. |
umask=<value> |
Same as above | Sets the umask for the permissions on files.<value> is interpreted in binary as bits to be removed from permissions on files. For example, umask=027 yields permissions of 750 or -rwxr-x--- .Note: When used in conjunction with uid=<value> and gid=<value> , this option lets you control who can access files on FAT, HPFS, and other foreign filesystems. |
fmask=<value> |
Same as above | Sets the umask for files only, not directories. |
conv=<code> |
Most filesystems used on Microsoft and Apple (ex. msdos , umsdos , vfat , hpfs , and hfs ). |
If
The default value is |
norock |
iso9660 |
Disables Rock Ridge extensions for ISO-9660 CD-ROMs. |
nojoliet |
iso9660 |
Disables Joliet extensions for ISO-9660 CD-ROMs. |
Documentation for options that are supported by various filesystems may appear in /usr/src/linux/Documentation/filesystems
or /usr/src/linux/fs/<fsname>
, where <fsname>
is the name of the filesystem.
Using umount
umount [-afnrv] [-t <fstype>] [<device> | <mountpoint>]
Common parameters of umount
:
Effect | Parameter | Description |
Unmount All | -a |
Attempts to unmount all of the partitions listed in /etc/mtab . |
Force Unmount | -f |
Force an unmount operation that might otherwise fail. |
Fall Back to Read-Only | -r |
Remount as read-only mode if the filesystem cannot be unmounted. |
Unmount Filesystem by Type | -t <fstype> |
Unmount only partitions matching the specified filesystem type code. |
As with mount
, normal users can not ordinarily use umount
. The exception to this is if the partition or device is listed in /etc/fstab
and specifies the user
, users
, or owner
option.
Note: Be cautious when unplugging USB disk-like devices. Linux caches accesses to most filesystems, which means that data may not be written to the disk until some time after a write command. Because of this, it is possible to corrupt a disk by ejecting or unplugging it, even when the drive isn’t active. Always issue a umount
command before ejecting a mounted disk. Another way to write the cache to disk is to use the sync
command, but because this command does not fully unmount a filesystem, it is not a substitute for umount
.
Permanently Mounting Filesystems
The /etc/fstab
file consists of a series of lines that contain six fields each; the fields are separated by one or more spaces or tabs. A line that begins with a hash mark (#
) is a comment and is ignored.
The meaning of each field is as follows:
Device
These are usually device filenames that reference hard disks, USB drives, etc. Most distributions now specify partitions by their labels or UUIDs:
LABEL=/home
UUID=1234abcde-123a-5432-9876-5678fde123b2
It is also possible to be a network drive or a share on Windows or a Samba server:
server:/home
//winsrv/shr
Mount Point
This is where the partition or disk will be mounted in the unified Linux filesystem.
This should usually be an empty directory in another filesystem, but the root filesystem (/
) and swap space (swap
) are exceptions.
Filesystem Type
The type code of the filesystem
A type code of auto
lets the kernel auto-detect the filesystem type.
Mount Options
Most filesystems support several mount options, which modify how the kernel treats the filesystem.
Multiple options may be specified in a comma separated value (CSV) list. For example:
uid=500,umask=0
Ordinarily, most SMB/CIFS shares require a username and password as a means of access control. Although the username=<name>
and password=<pass>
options can be used for smbfs
or cifs
, these options are undesirable, particularly in /etc/fstab
, because anyone can read this file to see the password. A better alternative is to use the credentials=<file>
option, which points to a file that holds the username and password, such as:
username=jeff
password=DontHackMeBro
Backup Operation
Contains a 1
if the dump
utility should back up a partition, and 0
if it should not.
If the dump
backup program is never used, this option is essentially meaningless.
Filesystem Check Order
At boot, Linux suse the fsck
program to check filesystem integrity. The final column specifies the order in which this check occurs. A 0
means that fsck
should not check a filesystem.
The root partition should have a value of 1
, and all others should be 2
.
Some filesystems, like ReiserFS, shouldn’t be checked.
Hardware and Hard Disk Configuration Essentials
- Summarize BIOS and EFI essentials:
- The BIOS and EFI provide two important functions: they configure the hardware built into the motherboard and the hardware on many types of plug-in cards, and they begin the computer’s boot process — passing control on to the boot loader in the MBR or EFI partition of GPT-formatted disks.
- The BIOS is being retired in favor of EFI.
- Describe what files contain important hardware information:
- There are many files under the
/proc
filesystem. Familiarize yourself with:/proc/ioports
,/proc/interrupts
,/proc/dma
,/proc/bus/usb
, and others.
- There are many files under the
- Explain Linux’s model for managing USB hardware:
- Linux uses drivers for USB controllers. These drivers in turn are used by some device-specific drivers and by programs that access USB hardware via entries in the
/proc/bus/usb
directory tree.
- Linux uses drivers for USB controllers. These drivers in turn are used by some device-specific drivers and by programs that access USB hardware via entries in the
- Summarize how to obtain information about PCI and USB devices:
- The
lspci
andlsusb
programs return information about PCI and USB devices, respectively. Various manufacturers and their products’ configuration options can be learned by using these commands.
- The
- Identify common disk types and their features:
- PATA disks were the most common type on PCs until about 2005. Since then, SATA disks, have gained substantial popularity.
- SCSI disks have long been considered the top-tier disks, but their high price has kept them out of inexpensive commodity PCs.
- Describe the purpose of disk partitions:
- Disk partitions break the disk into a handful of distinct parts. Each partition can be used by a different OS, can contain a different filesystem, and is isolated from other partitions. These features improve security and safety and can greatly simplify running a multi-OS system.
- Summarize important Linux disk partitions:
- The most important Linux disk partition is the root (
/
) partition, which is at the base of the Linux directory tree. - Other important partitions include a swap partition,
/home
for home directories,/usr
for program files,/var
for transient system files,/tmp
for temporary user files,/boot
for the kernel and other critical boot files, etc.
- The most important Linux disk partition is the root (
- Describe commands that help you monitor disk use:
- The
df
command provides a one-line summary of each mounted filesystem’s size, available space, free space, and percentage of space used. - The
du
command adds up the disk space used by all of the files in a specified directory tree and presents a summary by directory and subdirectory.
- The
- Summarize the tools that can help keep a filesystem healthy:
- The
fsck
program is a front end to filesystem-specific tools suche2fsck
andfsck.jfs
. By whatever name, these programs examine a filesystem’s major data structures for internal consistency and can correct minor errors.
- The
- Explain how filesystems are mounted in Linux:
- The
mount
command ties a filesystem to a Linux directory; once the filesystem is mounted, its files can be accessed as part of the mount directory. - The
/etc/fstab
file describes permanent mappings of filesystems to mount points; when the system boots, it automatically mounts the described filesystems unless they use thenoauto
option (which is common for removable disks).
- The
Package Managers, Libraries, and Processes
Exam Objectives
- 102.3 – Manage shared libraries
- 102.4 – Use Debian package management
- 102.5 – Use RPM and Yum package management
- 103.5 – Create, monitor, and kill processes
- 103.6 – Modify process execution priorities
Package Managers
Two major package management tools exist for Linux:
- RPM Package Manager (RPM)
- Debian package manager
Their package files, file databases, and details of operation differ — making them incompatible with one another.
Package Concepts
Any one program may rely on several other programs or libraries to operate, and these other programs or libraries may also rely on even more programs or libraries as well.
The Linux kernel is the foundation that all programs rely on.
Linux package management tools help to keep track of installed software, and help to install or upgrade new software.
Packages
Packages are collections of files which can be installed on a computer.
Typically a package is a single file that expands to many more files upon installation.
Each package contains additional information about itself that is useful for package management systems.
Installed File Database
Package systems maintain a database of installed files.
The database includes information about every file installed via the package system, the name of the package to which each of those files belongs, and associated additional information.
Dependencies
Packaging systems also maintain dependency information — a list of requirements packages have for each other.
Checksums
Package systems maintain checksums and assorted ancillary information about files; which is used to verify the validity of installed software.
These checksums are intended to help spot:
- Disk errors
- Accidental overwriting of files
- Other non-sinister problems
Note: Because intruders could install altered software through a package system, checksums are of limited use for detecting intrusions.
Upgrades and Uninstallation
By tracking files and dependencies, package systems can easily upgrade or uninstall packages.
Binary Package Creation
The RPM and Debian package systems both provide tools to help create binary packages from source code.
This has advantages over compiling software from source, because you can use a package management system to track dependencies, attend to individual files, etc.
Note: If the developers of a package didn’t provide explicit support for a peculiar CPU you are using, this feature can be used to install software on it.
Using RPM
The most popular package manager for Linux is the RPM Package Manager (RPM).
RPM Distributions
Red Hat developed RPM for its own distribution, but released the software under the General Public License (GPL) so that others are free to use it in their own Linux distributions.
Red Hat is largely comprised of three distributions:
- Fedora – The testbed for new developments.
- Red Hat Enterprise Linux (RHEL) – The for-pay enterprise distribution with support.
- CentOS (Community Enterprise OS) – The free version of RHEL essentially.
Mandriva (formerly Mandrake) and Yellow Dog are based on Red Hat, so they use RPMs.
SUSE uses RPMs as well, but is not as similar to Red Hat.
RPM Conventions
RPM supports any CPU architecture.
For the most part, source RPMs are transportable across architectures — the same source RPM can be used to build packages for x86, AMD64, PowerPC, ARM, SPARC, etc.
Some programs are composed of architecture-independent scripts and need no recompilation to run on other CPUs.
The naming convention for RPM packages is as follows:
packagename-a.b.c-x.arch.rpm
packagename
is the name of the package.
a.b.c
is the version number. It’s not required to be three numbers separated by dots, but that’s the most common form.
x
is the build number / release number. This number represents minor changes made by the package maintainer, not by the program author. These changes may represent altered startup scripts or configuration files, changed file locations, added documentation, or patches appended to the original program to fix bugs or to make the program more compatible with the target Linux distribution.
arch
is a code for the package’s architecture. The i386
architecture code represents a file compiled for any x86 CPU from 80386 onward. Pentium and newer may use i586
or i686
. PowerPC uses ppc
. x86-64 platforms use x86_64
. Scripts, documentation, and other CPU-independent packages generally use the noarch
architecture code.
Note: The information in the filename of an RPM package is retained within the package. This can be helpfulif you must rename an RPM package and need to know it’s original filename details.
Compatibility
Compatibility issues between RPM packages and certain RPM distributions can crop up from time to time for the following reasons:
- Distributions may use different versions of the RPM utilities.
- An RPM package designed for one distribution may have dependencies that are unmet in another distribution.
- An RPM package may be built to depend on a package of a particular name (such as samba-client depending on samba-common) and the distribution in use has named the package differently (ex. samba-com). Note: This objection can be overridden by using the
--nodeps
switch but the package may not work once installed. - Even when a dependency appears to be met, different distributions may include slightly different files in their packages.
RPM meta-packagers, such as the “Yellow Dog Updater, Modified” (YUM), can simplify locating and installing packages designed for your distribution.
The rpm
Command Set
The main RPM utility program:
rpm [operation] [options] [package-files|package-names]
Common rpm
operations:
Operation | Description |
-i |
Installs a package. Note: System must not contain a package of the same name. |
-U |
Installs a new package or upgrades an existing one. |
-F |
Upgrades a packages only if an earlier version already exists. |
-q |
Queries a package — finds whether a package is installed, what files it contains, etc. |
-V |
Verifies a package — checks that its files are present and unchanged since installation. |
-e |
Uninstalls a package. |
-b |
Builds a binary package, given source code and configuration files. Note: Moved to the rpmbuild command as of RPM version 4.2. |
--rebuild |
Builds a binary package, given a source RPM file. Note: Moved to the rpmbuild command as of RPM version 4.2. |
--rebuilddb |
Rebuilds the RPM database to fix errors. |
Common rpm
options:
Option | Compatible w/ Operations | Description |
--root <dir> |
any |
Modifies the Linux system with a root directory at <dir> . |
--force |
-i, -U, -F |
Forces installation of a package even when it means overwriting existing files or packages. |
-h --hash |
-i, -U, -F |
Displays hash marks (# ) to indicate progress of the operation. |
-v |
-i, -U, -F |
Used in conjunction with -h to produce a uniform number of hash marks for each package. |
--nodeps |
|
Prevents dependency checks. |
--test |
|
Checks for dependencies, conflicts, and other problems without installing the package. |
--prefix <path> |
-i, -U, -F |
Sets the installation directory to <path> . |
-a --all |
-q, -V |
Queries or verifies all packages. |
-f <file> --file <file> |
-q, -V |
Queries or verifies the package that owns <file> . |
-p <package-file> |
-q |
Queries the uninstalled RPM <package-file> . |
-i |
-q |
Displays package information, including the package maintainer, a short description, etc. |
-R --requires |
-q |
Displays the packages and files on which this package depends. |
-l --list |
-q |
Lists the files contained in the package. |
The rpm
command can be used with one or more packages, separated by spaces.
Installing multiple packages with a single command is recommended — as it ensure dependent packages are installed first.
Some operations require a filename, while others require a package name:
-i, -U, -F
, and therebuild
operations require package filenames.-q, -V,
and-e
require a package name.-p
can be used to modify-q
to use a package filename.
Using the -U
operation is recommended — as it enables the installation of a package without having to manually uninstall the old one first:
# rpm -Uvh samba-4.1.9-4.fc20.x86_64.rpm
The -qi
operations can be combined to verify that a package is installed; and displays information such as when and where the binary package was built.
Extracting Data from RPMs
RPM files are actually modified cpio
archives.
The rpm2cpio
program can be used to convert .rpm files to .cpio files:
$ rpm2cpio samba-4.1.9-4.fc20.src.rpm > samba-4.1.9-4.fc20.src.cpio
The cpio
program can be used to extract .cpio archived files:
$ cpio -i --make-directories < samba-4.1.9-4.fc20.src.cpio
Note: The -i
option is for extraction, and the --make-directories
option is used to create directories.
An alternative option is to pipe the two commands together without creating an intermediary file:
$ rpm2cpio samba-4.1.9-4.fc20.src.rpm | cpio -i --make-directories
When extracting binary packages, the output is likely to be a series of subdirectories that mimic the layout of the Linux root directory (i.e. /
, /etc
, /usr
, etc.).
When extracting a source package, the output is likely to be a source code tarball, a .spec file (which holds information that RPM uses to build the package), and some patch files.
Another option for extracting data from RPMs is alien
. It can convert an RPM into a Debian package or a tarball.
Using Yum
Yum is one of several meta-packagers — which allows the installation of packages and its dependencies easily using a single command line:
yum [options] [command] [package...]
Yum does this by searching repositories — Internet sites that host RPM files for a particular distribution.
Yum originated from the Yellow Dog Linux distribution, and was later adopted by Red Hat distributions (RHEL, CentOS, Fedora, etc.) and other RPM-based distributions.
Note: Not all RPM-based distributions use Yum. SUSE and Mandriva both use their own meta-packager. Debian-based distributions typically use the Advanced Package Tools (APT).
Common yum
commands:
Command | Description |
install | Installs one or more packages by package name, and also installs dependencies of the specified packages. |
update | Updates the specified packages to the latest version. If no packages are specified, yum updates every installed package. |
check-update |
Checks to see if any updates are available. If they are, yum displays their names, versions, and repository area (ex. updates or extras ). |
upgrade | Works like update with the --obsoletes flag set. |
remove erase |
Deletes a package from the system; similar to rpm -e , but yum also removes depended-on packages. |
list | Displays information about a package, such as the installed version and whether an update is available. |
provides whatprovides |
Displays information about packages that provide a specified program or feature. |
search | Searches package names, summaries, packagers, and descriptions for a specified keyword. |
info | Displays information about a package, similar to rpm -qi . |
clean |
Cleans up the Yum cache directory. Running this command from time to time is advisable, lest downloaded packages chew up too much disk space. |
shell |
Enters the Yum shell mode, which allows multiple Yum commands to be entered one after another. |
resolvedep |
Displays packages matching the specified dependency. |
localinstall |
Installs the specified local RPM files, using your Yum repositories to resolve dependencies. |
localupdate |
Updates the system using the specified local RPM files, using your Yum repositories to resolve dependencies. |
deplist |
Displays dependencies of the specified package. |
Yum is only as good as its repositories, and cannot install software that’s not stored in those repositories.
To download a package without installing it, the yumdownloader
command can be used.
GUI frontends do exist for Yum, such as yumex
and kyum
.
RPM and Yum Configuration Files
The main RPM configuration file is /usr/lib/rpm/rpmrc
.
This file should not be edited directly, instead a /etc/rpmrc
(to make global changes) or a ~/.rpmrc
(to make per-user changes) file should be created.
These files set a variety of options, mostly related to the CPU optimizations used when compiling source packages. For example, to optimize code for a particular CPU model, the appropriate compiler options can be provided with the optflags
line:
optflags: athlon -O2 -g -march=i686
Note: The previous line tells RPM to pass the -O2 -g -march-i686
options to the compiler whenever it’s building for the athlon
platform.
Most default rmprc
files include a series of buildarchtranslate
lines that cause rpmbuild
(or rpm
for older version of RPM) to use one set of optimizations for a whole family of CPUs. For x86 systems, these lines typically look like:
buildarchtranslate: athlon: i386
buildarchtranslate: i686: i386
buildarchtranslate: i586: i386
buildarchtranslate: i486: i386
buildarchtranslate: i386: i386
These lines tell RPM to translate the athlon
, i686
, i568
, i486
, and i386
CPU codes to use the i386
optimizations. This effectively defeats the purpose of any CPU-specific optimizations created on the optflags
line, but it guarantees that the RPMs built will be maximally portable. To change this, the line for CPU type must be altered (which can be found with uname -p
). For example, to prevent this on an Athlon-based system, enter the following line:
buildarchtranslate: athlon: athlon
The previous line will give a slight performance boost on Athlon systems, but at the cost of reducing portability.
Yum is configured via the /etc/yum.conf
file, with additional configuration files in the /etc/yum.repos.d/
directory.
The yum.conf
file holds basic options, such as the directory where Yum downloads RPMs and where Yum stores its logs.
The /etc/yum.repos.d/
directory can hold several files, each of which describes a Yum repository.
New repositories can be downloaded as RPMs that can be installed via the rpm
command.
Several popular Yum repositories exist:
Name | Description |
Livna | Hosts multimedia tools, such as additional codes and video drivers. http://rpm.livna.org/ |
KDE Red Hat | Contains improved KDE RPMs for those that favor KDE over GNOME (GNU Network Object Model Environment). http://kde-redhat.sourceforge.net/ |
Fresh RPMs | Provides additional RPMs focused on multimedia applications and drivers. http://freshrpms.net/ |
Note: Many additional Yum repositories exist. A web search for “yum repository” will reveal many other repositories.
RPM Compared to Other Package Formats
When compared to Debian packages, the greatest strength of RPMs is their ubiquity. Many software packages are available in RPM form from the developer and/or their distribution maintainers.
RPMs made for one Linux distribution can often be used for another distribution, but sometimes this can lead to a mismatch of conflicting packages.
Note: To find RPMs for a specific program, RPMFind (http://rpmfind.net/) can be extremely helpful. Likewise, Fresh RPMs (http://freshrpms.net/) can be helpfulfor finding RPMs as well.
Using Debian Packages
Debian packages require knowing how to use the dpkg
, dselect
, and apt-get
commands.
Debian Distributions and Conventions
Debian, Ubuntu, Linux Mint, and Xandros use the Debian package manager. As such, most packages that work with Debian will likely work with other Debian-based systems.
Although Debian doesn’t emphasis the use of GUI configuration tools, its derivatives tend to be more GUI-centric, which makes them more appealing to Linux novices.
Like RPM, the Debian package format is neutral with respect to both OS and CPU type.
Attempts to use the Debian package system and software library on top of non-Linux kernels have been largely abandoned, with the exception of kFreeBSD (http://www.debian.org/ports/kfreebsd-gnu/).
The original Debian distribution has been ported to many different CPUs, including x86
, x86-64
, IA-64
, ARM
, PowerPC
, Alpha
, 680x0
, MIPS
, and SPARC
.
Debian packages follow a similar naming convention as RPMs, but packages sometimes omit codes in the filename to specify a package’s architecture, particularly on x86 packages. For example, a filename ending in i386.deb
indicates an x86 binary, powerpc.deb
is a PowerPC binary, and all.deb
indicates a CPU-independent packages (such as documentation or scripts).
There is no code for Debian source packages because they consist of several separate files.
The dpkg
Command Set
Debian packages are incompatible with RPM packages, but the principles of their operation are the same.
The dpkg
command can be used to install a Debian package:
dpkg [options] [action] [package-files | package-name]
Common dpkg
actions:
Action | Description |
-i ––install |
Installs a package. |
––configure | Reconfigures an installed package: runs the post-installation script to set site-specific options. |
-r |
Removes a package but leaves its configuration files intact. |
-P ––purge |
Removes a package (including its configuration files). |
––get-selections | Displays currently installed packages. |
-p ––print-avail |
Displays information about an installed package. |
-I ––info |
Displays information about an uninstalled package file. |
-l <pattern> ––list <pattern> |
Lists all installed packages whose names match <pattern> . |
-L ––listfiles |
Lists the files associated with a package. |
-S <pattern> |
Locates packages that own the files specified by <pattern> . |
-C |
Searches for partially installed packages and suggests what to do with them. |
Common dpkg
options:
Option | Compatible w/ Actions | Description |
--root=<dir> |
any |
Modifies the Linux system with a root directory at <dir> . |
-B --auto-deconfigure |
-r |
Disables packages that rely on one that is being removed. |
--force-things |
assorted |
Overrides defaults that would ordinarily cause dpkg to abort. |
--ignore-depends=<package> |
-i , -r |
Ignores dependency information for the specified package. |
--no-act |
-i , -r |
Checks for dependencies, conflicts, and other problems without actually installing or removing the package. |
--recursive |
-i |
Installs all packages that match the package-name wildcard in the specified directory and all subdirectories. |
-G |
-i |
Doesn’t install the package if a newer version of the same package is already installed. |
-E --skip-same-version |
-i |
Doesn’t install the package if the same version of the package is already installed. |
Note: dpkg
expects a package name or a package filename depending on the command. For instance, --install
/ -i
and --info
/ -I
both require a package filename, but other commands take the shorter package name. An example of this would be installing a Samba package:
# dpkg -i samba_4.1.6+dfsg-1ubuntu2.1404.3_amd64.deb
Before upgrading a package, the old package may need to be removed first. To do this, use the -r
option with dpkg
:
# dpkg -r samba
To find information about an installed package, use the -p
option:
# dpkg -p samba
Debian-based systems often use a pair of somewhat higher-level utilities (apt-get
and dselect
) to handle package installation and removal. However, dpkg
is often more convenient when you’re manipulating just one or two packages.
Because dpkg
can take package filenames as input, it’s the preferred method of installing a package that was downloaded from an unusual source or created by yourself.
Using apt-cache
The APT suite of tools includes a program, apt-cache
, that’s intended solely to provide information about the Debian package database (known in Debian terminology as the package
cache
).
Common features of apt-cache
:
Feature | Description and Subcommands |
Display Package Information | Using the showpkg subcommand (ex. apt-cache showpkg samba ) displays information about the package.Note: The information displayed is different from dpkg ‘s informational actions. |
Display Package Statistics | Passing the stats subcommand (ex. apt-cache stats ) reveals how many packages are installed, how many dependencies are recorded, and various other statistics. |
Find Unmet Dependencies | Using apt-cache unmet may help if a program reports missing libraries or files. This subcommand returns information about unmet dependencies, which may help to track down the source of missing-file problems. |
Display Dependencies |
The The |
Local All Packages | The pkgnames subcommand displays the names of all the packages installed on the system.If a second parameter is provided with this subcommand it will display only the packages that begin with the specified string (ex. apt-cache pkgnames sa ). |
Several apt-cache
subcommands are intended for package maintainers and debugging serious package database problems rather than day-to-day system administration. Consult the man
page for apt-cache
for more information.
Using apt-get
APT, and it’s apt-get
utility, is Debian’s equivalent to Yum on certain RPM-based distributions.
Debian-based systems include a file, /etc/apt/sources.list
, that specifies locations where important packages can be obtained.
Note: Do not add a site to /etc/apt/sources.list
unless it can be trusted. The apt-get
utility does automatic and semi-automatic upgrades. If unreliable or vulnerable programs exist in a network source added to the sources list, your system will become vulnerable after upgrading via apt-get
.
Although APT is most strongly associate with Debian systems, a port for RPM-based systems is also available (see: http://apt4rpm.sourceforge.net/).
The apt-get
utility works by obtaining information about available packages from the sources listed in /etc/apt/sources.list
and uses that information to upgrade or install packages:
apt-get [options] [command] [package-names]
Common apt-get
options:
Option | Compatible w/ Commands | Description |
-d --download-only |
upgrade , dselect-upgrade , install , source |
Downloads package files but doesn’t install them. |
-f --fix-broken |
install ,remove |
Attempts to fix a system where dependencies are unsatisfied. |
-m --ignore-missing --fix-missing |
upgrade , dselect-upgrade , install , remove ,source |
Ignores all package files that can’t be retrieved (because of network errors, missing files, etc.). |
-q --quiet |
any |
Omits some progress indicator information. May be doubled (for instance -qq ) to produce even less progress information. |
-s --simulate |
any |
Performs a simulation of the action without actually modifying, installing, or removing files. |
-y --yes --assume-yes |
any |
Produces a “yes” response to any yes/no prompt during the installation script. |
-b --compile --build |
source |
Compiles a source package after retrieving it. |
--no-upgrade |
install |
Causes apt-get to not upgrade a package if an older version is already installed. |
Common apt-get
commands:
Command | Description |
update |
Obtains updated information about packages available from the installation sources listed in /etc/apt/sources.list . |
upgrade |
Upgrades all installed packages to the newest versions available, based on locally stored information about available packages. |
dselect-upgrade |
Performs any changes in package status (installation, removal, etc.) left undone after running dselect . |
dist-upgrade |
Similar to upgrade but performs “smart” conflict resolution to avoid upgrading a package if doing so would break a dependency. |
install |
Installs a package by package name (not by package filename), obtaining the package from the source that contains the most up-to-date version. |
remove |
Removes a specified package by package name. |
source |
Retrieves the newest available source package file by package filename, using information about available packages and installation archives listed in /etc/apt/sources.list . |
check |
Checks the package database for consistency and broken package installations. |
clean |
Performs housekeeping to help clear out information about retrieved files from the Debian package database.
Note: If |
autoclean |
Similar to clean , but removes information only about packages that can no longer be downloaded. |
In most cases, no options will be used with apt-get
, just a single command and possibly one or more package names. For example, keeping the system up-to-date with any new packages:
# apt-get update
# apt-get dist-upgrade
Using dselect
, aptitude
, and Synaptic
The dselect
program is a high-level text-mode package browser that uses the APT archives defined in /etc/apt/sources.list
.
aptitude
is another text-based Debian package manager; which combines the interactive features of dselect
with the command-line options of apt-get
.
In interactive mode, aptitude
is similar to dselect
, but aptitude
adds menus accessed by pressing Ctrl+T
.
Searching for packages with aptitude
can be performed with aptitude
search
:
$ aptitude search samba
Features of aptitude
on command line and interactive mode:
Feature | Subcommand | Description |
Update Package Lists | update |
U pdates package lists from the APT repositories. |
Install Software | install <package> |
Installs packages matching <package> .Note: <package> can end with a hyphen to indicate removal instead (ex. aptitude install zsh- would remove zsh). |
Upgrade Software | full-upgrade safe-upgrade |
Both options upgrade all installed packages, but safe-upgrade is more conservative about removing packages or installing new ones. |
Search for Packages | search |
Searches the database for packages matching the specified name. The result is a list of packages, one per line, with a summary code for each package’s install status, name, and description. |
Clean Up the Database | autoclean clean |
autoclean removes already-downloaded packages than are no longer available, and clean removes all downloaded packages. |
Obtain Help | help |
Displays a list of all options for aptitude . |
A tool that is similar to dselect
and aptitude
is the GUI X-based program, Synaptic.
Reconfiguring Packages
Debian packages often provide more-extensive initial setup options than their RPM counterparts. Frequently, the install script included in the package asks a handful of questions. These questions help the package system set up a standardized configuration that is customized for the machine.
To revert to initial standard configuration, the dpkg-reconfigure
program can be used:
# dpkg-reconfigure samba
The above command will reconfigure the samba
package, ask its initial installation questions again, and restart the Samba daemon.
Debian Packages Compared to Other Package Formats
Debian source packages aren’t single files; they are groups of files — the original source tarball, a patch file that’s used to modify the source code (including a file that controls the building of a Debian package), and an optional .dsc
file that contains a digital “signature” to help verify the authenticity of the collection.
Debian package tools combine and compile source packages to create a Debian binary package.
Whereas RPM source packages may contain multiple patch files, Debian source packages only support one single patch file.
Because all distributions that use Debian packages have derived from Debian, almost all are more compatible with one another than RPM-based distributions are to each other.
It is generally more difficult to locate Debian packages than RPMs for exotic programs. If no Debian package can be found, alien
can be used to convert an RPM to a Debian format.
Debian maintains a good collection of packages at http://www.debian.org/distrib/packages/.
Configuring Debian Package Tools
The main configuration file for dpkg
is /etc/dpkg/dpkg.cfg
or ~/.dpkg.cfg
.
This file contains dpkg
options, but without leading dashes. For example, to force dpkg
to always do a test run instead of installation a dpkg.cfg
file could contain:
no-act
For APT, the main configuration file that is likely to be modified is /etc/apt/sources.list
.
Another APT configuration file is /etc/apt/apt.conf
, which controls APT and dselect
options.
The format to modify the apt.conf
file is complex and modeled after the Internet Software Consortium’s (ISC's
) Dynamic Host Configuration Protocol (DHCP
) and Berkeley Internet Name Domain (BIND
) server configuration files. Options are grouped together by open and close curly braces ( {}
):
APT
{
Get
{
Download-Only "true";
};
};
Note: These lines are equivalent to setting the --download-only
option permanently.
For more information on the apt.conf
file, consult apt.conf
‘s man
page; and review the sample configuration file at /usr/share/doc/apt/examples/apt.conf
.
Debian’s package tools rely on various files in the /var/lib/dpkg
directory tree. These files maintain lists of available packages, lists of installed packages, etc. — effectively making it the Debian installed file database. Due to this directory’s importance, careful consideration should be made before modifying its contents; and backing up this directory is recommended when performing system backups.
Converting between Package Formats
When the appropriate package for a distribution is unable to be found there are several options:
- Continue searching for the appropriate package.
- Create a package from a source tarball using standard RPM or Debian tools.
- Convert between package formats with a utility like
alien
.
The alien
program comes with Debian and a few other distributions, but it can be installed by typing apt-get
install
alien
on APT systems. Alternatively, it can be found on RPMFind or Debian’s package website.
This program can convert between:
- Debian packages
- RPM packages
- Stampede packages
- Tarballs
In order to convert packages, the package management software for each package must be installed (i.e. RPM and Debian package managers must both be installed to convert between RPM and Debian packages).
Note: Although alien
requires both RPM and Debian package systems to be installed to convert between these formats, it doesn’t use the database features of these packages unless the --install
option is used.
The alien
utility doesn’t always convert all dependency information completely and correctly.
When converting from a tarball, alien
copies the files directly as they had been in the tarball, so alien
works only if the original tarball has files that should be installed off the root (/
) directory of the system.
The syntax for alien
:
alien [options] file[...]
Common alien
options:
Option | Description |
--to-deb |
Converts to Debian package. Note: This is the default option if no option is explicitly provided. |
--to-rpm |
Converts to RPM package. |
--to-slp |
Converts to Stampede package. |
--to-tgz |
Converts to tarball format. |
--install |
Installs the converted package and removes the converted file. |
As an example, to convert a Debian package called myprogram-1.0.1-3_i386.deb
to an RPM:
# alien --to-rpm myprogram-1.0.1-3_i386.deb
To install a tarball on a Debian-based system and keep a record of the files it contains in the Debian package database:
# alien --install binary-tarball.tar.gz
Note: The important thing to remember is that converting a tarball converts the files in the directory structure of the original tarball using the system’s root directory as the base. As such, it may be necessary to unpack the tarball, shuffle the files around, and then repack it to get the desired results before installing it with alien
.
Package Dependencies and Conflicts
The usual sources of problems relate to unsatisfied dependencies or conflicts between packages.
Real and Imagined Package Dependency Problems
Package dependencies and conflicts can arise for a variety of reasons:
Reason | Details |
Missing Libraries or Support Programs | A missing support package is one of the most common dependency problems. For example, all KDE programs rely on Qt, a widget set that provides assorted GUI tools. If Qt is not installed, no KDE packages will be able to be installed using RPM or Debian packages. Libraries — support code that is used by many different programs — are also a common source of problems. |
Incompatible libraries or Support Programs | Even if a library or support program is installed, it may be the wrong version. For example, if a program requires Qt 4.8 but Qt 3.3 is installed, it will not run. Fortunately, Linux library-naming conventions allow for the installation of multiple versions of a library. |
Duplicate Files or Features | A conflict can arise when one package includes files that are already installed and belong to another package. |
Mismatched Names | Sometimes package names between RPM and Debian distributions do not match across different distributions. For example, if one package checks for another package by name, the first package may not install, even if the appropriate package is installed with a different name. |
Workarounds for Package Dependency Problems
The options to confront an unmet package dependency or conflict include:
- Forcing the installation.
- Modifying the system to meet the dependency.
- Rebuilding the problem package from source code.
- Finding another version of the problem package.
Forcing the Installation
The --nodeps
parameter can be used to ignore failed dependencies using rpm
:
# rpm -i package.rpm --nodeps
The --force
parameter can be used to force installation despite errors (such as conflicts with existing packages):
# rpm -i package.rpm --force
Note: It is not recommended to use --nodeps
or --force
without first determining the reason for ignoring the dependency checks and errors preventing installation without these parameters.
For dpkg
, the --ignore-depends=<package>
, --force-depends
, and --force-conflicts
parameters can be used to overcome dependency and conflict problems on Debian-based systems.
Upgrading or Replacing the Depended-on Package
The proper way to overcome a package dependency problem is to install, upgrade, or replace the depended-on package. For example, if a program requires Qt 4.8+, the older version currently installed should be upgraded to that version.
Rebuilding the Problem Package
Rebuilding a package from source code can overcome some dependencies.
Fedora (and other developer-oriented RPM-based systems) include commands to rebuild RPM packages if the source RPM for the package is available:
# rpmbuild --rebuild packagename-version.src.rpm
The above command extracts the source code and executes whatever commands are required to build a new package (or sometimes several new packages). The output of this command should be one or more binary RPMs located in /usr/src/<distname>/RPMS/<arch>
.
Note: Older versions of RPM use the rpm
command instead of rpmbuild
.
Be aware that compiling a source package typically requires the appropriate development tools to be installed, such as the GNU Compiler Collection (GCC
) and other assorted development libraries.
Development Libraries (which typically include “dev” or “devel” in their names) are the parts of a library that enable programs to be written for the library.
Locating Another Version of the Problem Package
Sites like RPMFind (http://www.rpmfind.net/) and Debian’s package listing (http://www.debian.org/distrib/packages/) can be useful in tracking down alternative versions of a package.
Startup Script Problems
In the past, most Linux distributions used SysV startup scripts, but these scripts weren’t always transportable between distributions. For instance, systemd has become a more common startup option, and SysV scripts are not compatible with systemd.
Possible workarounds include:
- Modifying the included startup scripts.
- Building a new script based on another one from the distribution in use.
- Using a local startup script (such as
/etc/rc.d/rc.local
or/etc/rc.d/boot.local
).
Note: Startup script problems affect only servers and other programs that are started automatically when the computer boots; they do not affect typical user applications or libraries.
Managing Shared Libraries
Most Linux software relies heavily on shared libraries.
Libraries are software components that can be used by many different programs.
Library Principles
The idea behind a library is to simplify the lives of programmers by providing commonly used program fragments. For example, one of the most important libraries is the C library (libc
), which provides many of the higher-level features associated with the C programming language.
Another common type of library is associated with GUIs. These libraries are often called widget sets because they provide onscreen widgets used by programs — buttons, scroll bars, menu bars, etc. The GIMP Tool Kit (GTK+
) and Qt are the most popular Linux widget sets, and both ship largely as libraries.
Programmers choose libraries, not users; and one library cannot be substituted for another (the main exception being minor version upgrades).
Note: Linux uses the GNU C library (glicb
) version of the C library. As of glibc 2.15, the main glibc file is usually called /lib/libc.so.6
or /lib64/libc.so.6
, but this file is sometimes a symbolic link to a file of another name, such as /lib/libc-2.15.so
.
Most programs use their libraries as shared libraries (aka dynamic libraries). This approach helps keep program file size down, enables sharing of the memory consumed by libraries across programs, and enables programs to take advantage of improvements in libraries by upgrading the library.
Note: Linux shared libraries are similar to the dynamic link libraries (DLLs) of Windows. Windows DLLs are usually identified by .dll filename extensions. In Linux, however, shared libraries usually have a .so
or .so.<version>
extension (.so
stands for shared object). Linux static libraries (used by linkers for inclusion in programs when dynamic libraries are not to be used) have .a
filename extensions.
Linux uses library-numbering schemes to permit multiple versions of a library to be installed at once.
Note: Developers who create programs using particularly odd, outdated, or otherwise exotic libraries sometimes use static libraries. This enables them to distribute their binary packages without requiring users to obtain and install their oddball libraries. Likewise, static libraries are sometimes used on small emergency systems, which don’t have enough programs installed to make the advantages of shared libraries worth pursuing.
Locating Library Files
The major administrative challenge of handling shared libraries involves enabling programs to locate those shared libraries.
Binary program files can point to libraries either by name alone (as in libc.so.6
) or by providing a complete path (as in /lib/libc.so.6
). In the first case, you must configure a library path — a set of directories where programs should search for libraries.
After making a change to the library path or complete path, you may need to use a special command to get the system to recognize the change.
Setting the Path System Wide
The first way to set the library path is to edit the /etc/ld.so.conf
file.
This file consists of a series of lines, each of which lists one directory in which shared library files may be found. Typically, this file lists between half a dozen and a couple dozen directories. These lines begin with the include
directive — which lists files that are to be included as if they were part of the main file. For example, Ubuntu 12.04’s ld.so.conf
file begins with:
include /etc/ld.so.conf.d/*.conf
The above line tells the system to load all of the files in /etc/ld.so.conf.d
whose name ends in .conf
as if they were part of the main /etc/ld.so.conf
file.
Some distributions, such as Gentoo, do something a little different but with the same goal. With these distributions, the env-update
utility reads files in /etc/env.d
to create the final form of several /etc
configuration files, including /etc/ld.so.conf
. In particular, the LDPATH
variables in these files are read, and their values make up the lines in the ld.so.conf
file. Thus, to change ld.so.conf
in Gentoo or other distributions, you should add or edit files in /etc/env.d
and type env-update
to finalize the changes.
Library package files usually install themselves in directories that are already on the path or add their paths automatically. However, if you installed a library package, or a program that creates its own libraries, in an unusual location via mechanisms other than your distribution’s main package utility, you may need to change the library path system wide.
After changing the library path, the ldconfig
command must be run to have programs use the new path.
Note: In addition to the directories specified in /etc/ld.so.conf
, Linux refers to the trusted library directories, /lib
and /usr/lib
. These directories are always on the library path, even if they aren’t listed in the ld.so.conf
file.
Temporarily Changing the Path
The LD_LIBRARY_PATH
environment variable can be set to a directory (or directories) containing shared libraries:
$ export LD_LIBRARY_PATH=/usr/local/testlib:/opt/newlib
This environment variable accepts a single directory or multiple directories, separated by colons.
Directories specified in LD_LIBRARY_PATH
are added to the start of the search path, making them take precedence over other directories.
A user’s shell startup script files can be edited to permanently set the LD_LIBRARY_PATH
environment variable, if desired.
In principle, the LD_LIBRARY_PATH
environment variable could be set globally; however, using the /etc/ld.so.conf
file is the preferred method of effecting global changes to the library path.
Unlike other library path changes, this one doesn’t require that you run ldconfig
for it to take effect.
Correcting Problems
$ gimp
gimp: error while loading shared libraries: libXinerama.so.1:
cannot~CA
open shared object file: No such file or directory
The above error message indicates that the system couldn’t find the libXinerama.so.1
library file. The usual cause of such problems is that the library isn’t installed, so you should look for it using commands such as find
. If the file isn’t installed, try tracking down the package to which it should belong using a web search and install it.
If the library file is available, its directory may need to be added globally or to the LD_LIBRARY_PATH
environment variable.
Sometimes the library’s path is hard-coded in the program’s binary file (this can be checked with ldd
). When this happens, you may need to create a symbolic link from the location of the library on your system to the location that the program expects.
A similar problem can occur when the program expects a library to have one name but the library has another name on your system. For example, a program may link to biglib.so.5
, but biglib.so.5.2
is installed. Since minor version number changes are usually inconsequential, creating a symbolic link should correct this problem:
# ln -s biglib.so.5.2 biglib.so.5
Note: This command must be run as root in the directory where the library resides, and ldconfig
must be run thereafter.
Library Management Commands
The ldd
program displays a program’s shared library dependencies — the shared libraries that a program uses.
The ldconfig
program updates caches and links used by the system for locating libraries — that is, it reads /etc/ld.so.conf
and implements any changes in that file and any directories it refers to.
Displaying Shared Library Dependencies
If a program won’t launch because of missing libraries, the first step is to check which libraries it uses:
$ ldd /bin/ls
Each line of output from ldd
begins with a library name. If the library name doesn’t contain a complete path, ldd
attempts to find the true library and displays the complete path following the =>
symbol.
The ldd
command accepts a few options. The most notable of these is probably -v
, which displays a long list of version information following the main entry. This information may be helpfulin tracking down which version of a library a program is using, in case there are multiple versions installed on your system.
Libraries can also depend on other libraries, which means ldd
can be used on libraries as well. This can be useful if all the dependencies are met for a program but it still fails to load due to missing libraries.
Rebuilding the Library Cache
Linux (or, more precisely, the ld.so
and ld-linux.so
programs, which manage the loading of libraries) doesn’t read /etc/ld.so.conf
every time a program runs. Instead, the system relies on a cached list of directories and the files they contain, stored in binary format in /etc/ld.so.cache
.
This list is maintained in a format that’s much more efficient than a plain-text list of files and directories. The drawback is that it must be rebuilt every time libraries are added or removed. These changes include additions or removals of both the contents of the library directories and adding or remove the directories themselves.
The tool to update the /etc/ld.so.cache
file is ldconfig
:
# ldconfig
Common options to modify ldconfig
:
Feature | Option | Description |
Display Verbose Information | -v |
Displays a summary of directories and files being registered. |
Do Not Rebuild the Cache | -N |
Prevents a rebuild of the library cache, but updates symbolic links to libraries. |
Process Only Specified Directories | -n <dirs> |
Ignores the directories specified in /etc/ld.so.conf and the trusted directories (/lib and /usr/lib ), but updates directories (<dirs> ) passed as arguments. |
Do Not Update Links | -x |
Opposite of -N . It updates the library cache, but does not update symbolic links to libraries. |
Use a New Configuration File | -f <conf-file> |
Changes the configuration file from /etc/ld.so.conf to whatever file is specified by <conf-file> . |
Use a New Cache File | -c <cache-file> |
Changes the cache file from /etc/ld.so.cache to whatever file is specified by <cache-file> . |
Display Current Information | -r <dir> |
Treat <dir> as if it were the root (/ ) directory. Note: This option is helpfulif recovering from a badly corrupted system, or if installing a new OS. |
Both RPM and Debian library packages typically run ldconfig
automatically after installing or removing packages.
Managing Processes
When you type a command name, that program is run and a process is created for it.
Understanding the Kernel: The First Process
The Linux kernel is at the heart of every Linux system.
The uname
command can be run to reveal details about the kernel being run.
Common options for uname
:
Display | Option | Description |
Node Name |
|
Displays the system’s node name / network hostname. |
Kernel Name | -s --kernel-name |
Displays the kernel name (typically ‘Linux ‘ on a Linux system). |
Kernel Version | -v --kernel-version |
Displays kernel version (usually a kernel build date and time, and not an actual version number). |
Kernel Release | -r --kernel-release |
Displays the actual kernel version number. |
Machine | -m --machine |
Displays information about the machine (generally CPU code, such as x86_64 or i686, etc.). |
Processor | -p --processor |
May display information about the CPU; such as, manufacturer, model, and clock speed. In most cases it just returns ‘unknown ‘ though. |
Hardware Platform | -i --hardware-platform |
Is supposed to display hardware information but often returns just ‘unknown ‘. |
OS Name | -o --operating-system |
Returns the OS name (normally ‘GNU/Linux ‘ on a Linux system). |
Print All Information | -a --all |
Displays all available information. |
Examining Process Lists
One of the most important tools in process management is ps
— which displays processes’ statuses:
ps [options]
Using Usefulps
Options
The ps
command supports three option types:
Type | Syntax | Description |
Unix98 Options | -<option> |
Single-character options, can be grouped together. Ex. ls -al |
BSD Options | <option> |
Single-character options, can be grouped together. Ex. ps U <username> |
GNU Long Options | --<option> |
Multi-character options (strings), cannot be grouped together. Ex. firewall-cmd --zone=public --permanent --add-port=22652/tcp |
The reason for so many supported option types is because the ps
utility has historically varied a lot from one Unix OS to another, and support for almost all different implementations has been included with ps
on most major Linux distributions. This behavior can be changed by setting the PS_PERSONALITY
environment variable to posix
, old
, linux
, bsd
, sun
, digital
, etc.
Usefulfeatures for ps
:
Feature | Option | Description |
Display Help | --help |
Summarizes common ps options. |
Display All Processes | -A -e |
By default, ps displays only processes that were run from its own terminal (xterm , text-mode login, or remote login). The -A and -e options cause it to display all of the processes on the system, and the x option owned by the user that gives the command. |
Display One User’s Processes | -u <user> U <user> --User |
Display processes owned by a particular user. <user> may be a username or user ID. |
Display Extra Information | -f , -l ,j , l , u , v |
Expands the information provided in the ps output. |
Display Process Hierarchy | -H -f --forest |
Groups processes and uses indentation to show the hierarchical relationship between processes. |
Display Wide Output | -w w |
The ps command limits output to only 80 characters in width, and truncates anything past that. These options tell ps not to do that. This can be helpfulif writing information to a file:$ ps w > ps.txt |
Interpreting ps
Output
The output from the ps
command typically starts with a heading line, which displays the meaning of each column:
Column | Details |
Username | The name of the user running this program/process. |
Process ID (PID ) |
A number that’s associated with the process. |
Parent Process ID (PPID ) |
The PID for the parent process spawning this process. |
TTY | The teletype (TTY ) is a code used to identify a terminal. Note: Not all processes have a TTY number; only text-mode programs do. |
CPU Time | The TIME and %CPU headings are two measures of CPU time used. The first indicates the total amount of CPU time consumed, the second represents the percentage of CPU time the process is using when ps executes. |
CPU Priority | The NI column, if present, lists the priority codes. The default value is 0 . Positive values represent reduced priority, and negative values represent increased priority. |
Memory Use | RSS is the resident set size (the memory used by the program and its data), and %MEM is the percentage of memory the program is using.Some outputs include a SHARE column, which is memory that’s shared with other processes (such as shared libraries). |
Command | The final column in most listings is the command that was used to launch the process. |
Note: To find specific processes and their PIDs:
$ ps ax | grep <command>
Processes that aren’t linked to others were either started directly by init,
or have had their parent processes killed and were “adopted” by init
.
top
: A Dynamic ps
Variant
top
is a useful command to display task manager of sorts, which displays information such as which processes are consuming CPU time relative to one another.
By default, top
sorts entries by CPU use, and it updates the display every few seconds.
There are also GUI variants of top
, such as kpm
and gnome-system-monitor
.
Common top
options:
Option | Description |
-d <delay> |
Changes the update time to <delay> seconds (default: 5 ). |
-p <pid> |
Monitor specific processes by PID. Note: Specify up to 20 PIDs by using this option multiple times (once for each PID). |
-n <num> |
Display a specific number of updates then quit. |
-b |
Batch mode. Do not use normal screen-update commands. Useful for logging CPU use to a file. |
While top
is running, interactive commands can be entered:
Command | Description |
h ? |
Displays help information. |
k |
Kills a process after prompting for its PID. |
q |
Quits top . |
r |
Change a process’s priority (i.e. renice ) after prompting for its PID and a new priority value (negative to increase, positive to increase — max -20 / 19 , default 0 ).Note: Only root may increase a process’s priority. |
s |
Prompts for a new update rate in seconds. |
P |
Sort by CPU usage (default). |
M |
Sort by memory usage. |
Note: To look at just memory usage, use the free
command. It provides a quick reference of how much physical memory and swap memory is in use, and how much remains available.
One of the pieces of information provided by top
is the load average, which is a measure of the demand for CPU time by applications (0.0
represents no load, 1.0
represents full load on a CPU core).
Note: Most computers these days include multiple CPUs or CPU cores. On such systems, the load average can equal the number of CPUs or cores before competition for CPU time occurs. For example, a quad-core CPU can go up to a load average of 4.0
before any contention occurs between processes demanding CPU time. Typically, one program can create up to a load of 1.0
; however, multithreaded programs can create higher load averages because they can take advantage of multiple CPUs, cores, or multithreaded cores.
The three load-average estimates displayed on the top line of top
correspond to the current load average and two previous measures.
The current load average can also be found with the uptime
command, which displays load averages along with information about how long the machine has been running for.
jobs
: Processes Associated with Your Session
The jobs
command displays minimal information about the processes associated with the current session, such as job ID numbers. These numbers are similar to PID numbers, but not the same.
Jobs are numbered starting from 1
for each session, and generally a single shell will only have a few associated jobs.
The jobs
command can also be used to ensure all programs have terminated prior to logging out.
pgrep
: Finding Processes
The pgrep
command was introduced under the Solaris operating system. It performs a simple search within the process list (similar to ps
piped to grep
):
pgrep [-flvx] [-n | -o] [-d <delim>] [-P <ppidlist>] [-g <pgrplist>] [-s <sidlist>] [-u <euidlist>] [-U <uidlist>] [-G <gidlist>] [-J <projidlist>] [-t <termlist>] [-T <taskidlist>] [-c <ctidlist>] [-z <zoneidlist>] [pattern]
Processes can be searched based on username, user ID, or group ID; and can include an additional regular expression pattern:
$ pgrep -u root cron
The above command will search for processes named ‘cron’ that are run by the root user, and returns the process ID value of the processes that match.
Understanding Foreground and Background Processes
Normally, when a program is launched, it takes over the terminal, and prevents any other work from being done on that terminal (note: some programs do release the terminal).
Ctrl+z
can pause the program and give control of the terminal back.
To get back to the program that was paused, use the fg
command. This brings it back to the foreground of the terminal.
If multiple processes have been paused/suspended, a job number can be provided to the fg
command to ensure it brings that specific process back to the foreground:
$ fg 2
A variant on fg
is the bg
command, which brings a job to the background and keeps it running, while restoring access to the terminal.
The bg
command is often usefulwhen launching GUIs from the command line — as the shell window that launched the program is tied up while the GUI is being displayed. Pressing ctrl+z
on the command line will pause the GUI program, and then entering the bg
command will unfreeze it as it gets moved to the background of the terminal.
An alternative to using ctrl+z
then bg
, is to append an ampersand (&
) to the command when launching the program:
$ nedit myfile.txt &
The above command will launch the nedit
program in the background from the start.
Managing Process Priorities
The nice
command can be used to launch a program with a specific priority, and the renice
command can be used to alter the priority of a running program.
The nice
command has the following syntax:
nice [argument] [command [command-arguments]]
There are three ways to specify a priority value to nice
:
nice -<value>
nice -n <value>
nice --adjustment=<value>
For example, setting a positive 12
value for a fictitious fold-protein
command:
$ nice -12 fold-protein data.txt
$ nice -n 12 fold-protein data.txt
$ nice --adjustment=12 fold-protein data.txt
If the priority value is omitted from the nice
command, it will default to a value of 10
. If nice
is not used at all, the default priority value is 0
.
The range of possible values for priority is -20
to 19
. The greater the negative number, the higher the priority.
Only the root user can launch a program with increased priority (negative priority value), but any user can launch a program with decrease priority (positive priority value).
The renice
command has the following syntax:
renice <priority> [[-p] <pids>] [-g <pgrps>] [-u <users>]
The renice
command accepts one or more PIDs (pids
), one or more group IDs (pgrps
), or one or more usernames (users
). If using pgrps
or users
, renice
changes the priority of all programs that match the specific criteria — but only root may use renice
this way. In addition, only the root user may increase a process’s priority (by lowering the priority value).
If a numeric value is provided after the priority, without -p
, -g
, or -u
, renice
assumes the value is a PID.
An example of using renice
:
# renice 7 16519 -u jeff josh
The above command would change the priority to 7
for PID 16519
for the users jeff
and josh
.
Killing Processes
The kill
command can be used to terminate a program by sending a signal to a specific process. This signal is usually sent by the kernel, the user, or the program itself to terminate the process.
Note: The kill
command will only kill processes owned by the user that runs kill
, with the exception of the root user — which may kill any users’ processes.
Linux supports many numbered signals, each associated with a specific name. They can be listed with:
kill -l
The kill
command has the following syntax:
kill -s <signal> <pid>
The -s <signal>
parameter sends the specific signal to the process.
The signal can be specified as either a number, or as its corresponding name. The most commonly used signals are:
1
/SIGHUP
— terminates interactive programs and causes many daemons to reread their configuration files.9
/SIGKILL
— exits a process without performing routine shutdown tasks.15
/SIGTERM
— exits a process but allows it to close open files, etc.
If no signal is specified, 15
/ SIGTERM
is used as a default.
An alternative option to using a signal number or name, is to use the -signal
option. When using this option, omit the SIG
portion of the signal name:
kill -signal TERM 5219
The above command would send the SIGTERM
/ 15
signal to the process with a PID of 5219
.
Note: Although Linux includes a kill
program, many shells, including bash
and csh
, include a built-in kill
equivalent. To be sure that the external program is buing used, type the full path to /bin/kill
.
The kernel can pass signals to programs, even if you do not use the kill
command. For example, when logging out of a session, the programs you started from that session are sent the SIGHUP
/ 1
signal, causing them to terminate.
To keep a program running after logging out, it can be ran with the nohup
command:
$ nohup <program> <options>
The nohup
command causes the program to ignore the SIGHUP
/ 1
signal.
A variant of the kill
command is the killall
command:
killall [options] [--] <name> [...]
The killall
command kills a process based on its name rather than its PID number.
The default signal for killall
is also 15
/ SIGTERM
.
An important option for the killall
command is -i
. This option will cause killall
to prompt for confirmation before sending a signal to each process it matches:
$ killall -i vi
Kill vi(13219) ? (y/n)
It is highly recommended to always use the -i
option when running killall
as the root user.
Note: Some versions of Unix provide a killall
command that works very differently from Linux’s killall
command. This alternative version kills all of the processes started by the user who runs the command. To ensure you do not use this more destructive version of the command, check the man
page for the system’s killall
command first.
Another variant on kill
is the pkill
command:
pkill [-signal] [-fvx] [-n | -o] [-P <ppidlist>] [-g <pgrplist>] [-s <sidlist>] [-u <euidlist>] [-U <uidlist] [-G <gidlist>] [-J <projidlist>] [-t <termlist>] [-T <taskidlist>] [-c <ctidlist>] [-z <zoneidlist>] [pattern]
The pkill
command can kill one or more processes based on usernames, user IDs, group IDs, and other features, in addition to a regular expression for matching.
The pkill
command was introduced on the Solaris operating system.
Package Manager, Library, and Process Essentials
Most distributions are built around the RPM or Debian package systems, both of which enable installation, upgrade, and removal of software using a centralized package database to avoid conflicts and other problems that are common when no central package database exists.
Yum and APT can be used to assist with keeping a system synchronized with the latest versions of software.
Shared libraries are the necessary building blocks of large programs. Sometimes they need to be configured or upgraded manually.
Processes can be paused, manipulated as foreground or background processes, have their priorities set, or even killed.
Things to know without lookup:
- Identify critical features of RPM and Debian package formats:
- RPM and Debian packages store all of the files for a given package in a single file that also includes information about what other packages the software depends on.
- RPM and Debian systems maintain a database of installed packages and their associated files and dependencies.
- Describe the tools used for managing RPMs:
- The
rpm
program is the main tool for installing, upgrading, and uninstalling RPMs. - The Yum utility, and particularly its
yum
command, enables installation of a package and all of its dependencies via the Internet rather than from local package files.
- The
- Describe the tools used for managing Debian packages:
- The
dpkg
program installs or uninstalls a single package or group of packages that are specified. - The
apt-get
utility retrieves programs from installation media or from the Internet for installation, and can automatically upgrade an entire system. - The
dselect
program serves as a text-mode menu-driven interface toapt-get
.
- The
- Summarize tools for extracting files and converting between package formats:
- The
rpm2cpio
program can convert an RPM file into acpio
archive, enabling non-RPM systems to access files in an RPM.<\li> - The
alien
utility can be used to convert packages between Debian, RPM, Stampede, and also tarballs. This enables the use of packages intended for one system onto another.
- The
- Summarize the reasons for using shared libraries:
- Shared libraries keep disk space and memory requirements manageable by placing code that’s needed by many programs in separate files from the programs that use it, enabling one copy to be used multiple times.
- Shared libraries act as basic building blocks for programmers to use in their programs, so that they do not have to reinvent code for common tasks constantly.
- Describe methods available to change the library path:
- The library path can be changed system wide by editing the
/etc/ld.so.conf
file followed by theldconfig
command to ensure the cache has been updated.<\li> - For temporary or per-user changes, directories may be added to the library path by placing them in the
LD_LIBRARY_PATH
environment variable.
- The library path can be changed system wide by editing the
- Explain the difference between foreground and background processes:
- Foreground processes have control over the current terminal or text-mode window (such as
xterm
). - Background processes do not have exclusive control over a terminal or text-mode window, but are still running.
- Foreground processes have control over the current terminal or text-mode window (such as
- Describe how to limit the CPU time used by a process:
- A program may be launched with the
nice
command to set its priority from the beginning. - A running program can have its priority changed using the
renice
command after it has been started. - Processes can be terminated with the
kill
orkillall
commands.
- A program may be launched with the