LX02G8 Course
LX02G8 Course
cover
Front cover
Course Guide
Linux Basics and Installation
Course code LX02G ERC 8.2
June 2018 edition
Notices
This information was developed for products and services offered in the US.
IBM may not offer the products, services, or features discussed in this document in other countries. Consult your local IBM representative
for information on the products and services currently available in your area. Any reference to an IBM product, program, or service is not
intended to state or imply that only that IBM product, program, or service may be used. Any functionally equivalent product, program, or
service that does not infringe any IBM intellectual property right may be used instead. However, it is the user's responsibility to evaluate
and verify the operation of any non-IBM product, program, or service.
IBM may have patents or pending patent applications covering subject matter described in this document. The furnishing of this
document does not grant you any license to these patents. You can send license inquiries, in writing, to:
IBM Director of Licensing
IBM Corporation
North Castle Drive, MD-NC119
Armonk, NY 10504-1785
United States of America
INTERNATIONAL BUSINESS MACHINES CORPORATION PROVIDES THIS PUBLICATION "AS IS" WITHOUT WARRANTY OF ANY
KIND, EITHER EXPRESS OR IMPLIED, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
NON-INFRINGEMENT, MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE. Some jurisdictions do not allow disclaimer
of express or implied warranties in certain transactions, therefore, this statement may not apply to you.
This information could include technical inaccuracies or typographical errors. Changes are periodically made to the information herein;
these changes will be incorporated in new editions of the publication. IBM may make improvements and/or changes in the product(s)
and/or the program(s) described in this publication at any time without notice.
Any references in this information to non-IBM websites are provided for convenience only and do not in any manner serve as an
endorsement of those websites. The materials at those websites are not part of the materials for this IBM product and use of those
websites is at your own risk.
IBM may use or distribute any of the information you provide in any way it believes appropriate without incurring any obligation to you.
Information concerning non-IBM products was obtained from the suppliers of those products, their published announcements or other
publicly available sources. IBM has not tested those products and cannot confirm the accuracy of performance, compatibility or any other
claims related to non-IBM products. Questions on the capabilities of non-IBM products should be addressed to the suppliers of those
products.
This information contains examples of data and reports used in daily business operations. To illustrate them as completely as possible,
the examples include the names of individuals, companies, brands, and products. All of these names are fictitious and any similarity to
actual people or business enterprises is entirely coincidental.
Trademarks
IBM, the IBM logo, and ibm.com are trademarks or registered trademarks of International Business Machines Corp., registered in many
jurisdictions worldwide. Other product and service names might be trademarks of IBM or other companies. A current list of IBM
trademarks is available on the web at “Copyright and trademark information” at www.ibm.com/legal/copytrade.shtml.
© Copyright International Business Machines Corporation 2016, 2018.
This document may not be reproduced in whole or in part without the prior written permission of IBM.
US Government Users Restricted Rights - Use, duplication or disclosure restricted by GSA ADP Schedule Contract with IBM Corp.
V11.2
Contents
TOC
Contents
Trademarks . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . xi
Agenda . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . xiii
TMK
Trademarks
The reader should recognize that the following terms, which appear in the content of this training
document, are official trademarks of IBM or other companies:
IBM, the IBM logo, and ibm.com are trademarks or registered trademarks of International Business
Machines Corp., registered in many jurisdictions worldwide.
The following are trademarks of International Business Machines Corporation, registered in many
jurisdictions worldwide:
AIX® Notes® Power®
Q®
PostScript is either a registered trademark or a trademark of Adobe Systems Incorporated in the
United States, and/or other countries.
Intel is a trademark or registered trademark of Intel Corporation or its subsidiaries in the United
States and other countries.
Linux is a registered trademark of Linus Torvalds in the United States, other countries, or both.
Microsoft, Windows and Windows NT are trademarks of Microsoft Corporation in the United States,
other countries, or both.
UNIX is a registered trademark of The Open Group in the United States and other countries.
VMware is a registered trademark or trademark of VMware, Inc. or its subsidiaries in the United
States and/or other jurisdictions.
Other product and service names might be trademarks of IBM or other companies.
pref
Course description
Linux Basics and Installation
Purpose
The objective of the course is to teach students enough about Linux to successfully install,
configure, and run Linux on the student's personal workstation and be productive with it.
Audience
This course is designed for students with little or no Linux knowledge or experience who want to
make a start with Linux.
Prerequisites
Students should be able to use a Microsoft Windows-based workstation.
Objectives
After completing this course, you should be able to:
• Install and configure Linux on a workstation
• Use Linux for daily work
Contents
• Introduction to Linux
• Installing Linux
• Using the system
• Working with files and directories
• Linux documentation
• Editing files
• Working with processes
• Shell basics
• Linux utilities
• Shell scripting
• The Linux GUI
• Customizing the user environment
• Basic system configuration
• Connecting to the Internet
• Integrating Linux in a Windows environment
pref
Agenda
Note
The following unit and exercise durations are estimates, and might not reflect every class
experience.
Day 1
(01:30) Unit 1: Linux – Introduction and installation
(01:00) Exercise 1: Linux installation
(00:45) Unit 2: Using the system
(00:45) Exercise 2: Using the system
(01:00) Unit 3: Working with files and directories
(00:45) Exercise 3: Working with files and directories
Day 2
(00:30) Unit 4: File and directory permissions
(00:30) Exercise 4: File and directory permissions
(00:30) Unit 5: Linux documentation
(00:30) Exercise 5: Linux documentation
(00:45) Unit 6: Editing files
(00:45) Exercise 6: Editing files
(00:45) Unit 7: Shell basics
(00:45) Exercise 7: Shell basics
Day 3
(01:00) Unit 8: Working with processes
(00:45) Exercise 8: Working with processes
(01:00) Unit 9: Linux utilities
(01:00) Exercise 9: Linux utilities
(00:45) Unit 10: Shell scripting
(00:45) Exercise 10: Shell scripting
(01:00) Unit 11: The Linux GUI
Day 4
(00:45) Unit 12: Customizing the user environment
(00:45) Exercise 12: Customizing the user environment
(01:00) Unit 13: Basic system configuration
(01:00) Exercise 13: Basic system configuration
(01:00) Unit 14: Integrating Linux in a Windows environment
(01:00) Exercise 14: Integrating Linux in a Windows environment
Uempty
Overview
This unit covers the history of Linux and names some important people involved in the history of
Linux. This unit also discusses the GNU general public license, and the process of installing Linux.
Uempty
Unit objectives
• Discuss the history of Linux
• Name some important people in the history of Linux
• Discuss the GNU general public license
• Prepare a system for installation
• Install Linux from CD-ROM
• Perform a network installation
Uempty
1.1. Introduction to Linux
Uempty
Introduction to Linux
Uempty
Topics
• Introduction to Linux
• Red Hat installation
• SUSE installation
Uempty
The history of Linux starts properly in 1984. In that year, a system administrator working at
Massachusetts Institute of Technology (MIT), Richard Stallman, received a new version of the UNIX
flavor they were using. But in contrast to previous versions, this time they did not receive the source
of the operating system with it, and could not obtain the source separately without signing a
Non-Disclosure Agreement (NDA). Richard Stallman was therefore not able to implement a certain
additional feature into the operating system, which his users had come to like.
Richard Stallman became so upset with these developments in general that he vowed to write a
new UNIX-like operating system from scratch. That new operating system was supposed to be free
(as in free speech): Everybody would have the right to use and adapt the software for its own use,
and to distribute the software to others. (More about this later.) This project was called GNU, which
stands for GNUs not UNIX.
To fund the GNU project and to advocate the use of free software in general, the Free Software
Foundation (FSF) was founded.
The first steps taken by the GNU project was to re-implement various essential utilities in a UNIX
operating system. Although hundreds of little tools were written, four tools stand out:
• The GNU C Compiler (GCC) was essential for compiling all software, including the kernel and
the C compiler itself.
• The GNU C Library (GLIBC) implements a large set of standardized system calls.
Uempty
• Emacs is a full-featured, world-class editor which can be extended into a sort of application
development environment.
• Bash (Bourne again shell) is a command interpreter and programming environment. Having a
shell is essential on a UNIX system, because the shell interprets and executes the commands
you type.
Later on, the GNU project also started development on a UNIX-like kernel* , called Hurd. This
kernel has never been important for Linux, however, because it was released for the first time at the
end of the 1990s, when Linux was already thriving.
Note
* The kernel of an operating system is the program that runs 24 hours a day and takes care of
scheduling, device handling, memory management and so forth.
Uempty
In 1991, a student at the University at Helsinki, Linus Torvalds, started a small research project into
the workings of the Intel 80386 processor, which by then was state-of-the-art. He was interested in
exploring a new feature, which, up to then, was not present in any Intel processor, namely a
memory management unit (MMU). This MMU offered hardware support for running multiple
processes simultaneously, each in its own memory segment. With such an MMU, processes cannot
access memory areas owned by other processes, and this effectively means that if one process
crashes, it cannot take the whole system down with it.
The operating systems available for the 386 (Windows for Workgroups and Minix) all did not use
this feature and were therefore very prone to crashing. (“Who is General Failure and why is he
reading my hard disk?”)
Linus started out writing three small programs:
• A small program that continuously printed the letter A on the screen
• A small program that continuously printed the letter B on the screen
• A slightly larger program that switched the processor to protected mode and scheduled the
other two programs to take turns
When Linus finally managed to see the output of both programs on his screen, in turn, he knew he
had the beginnings of a kernel of a multitasking operating system. Linus continued to improve and
Uempty
refine the kernel, and at the end of 1991, he was able to run the GNU C compiler and the Bash shell
under his kernel, which by then was dubbed Linux, for Linus' UNIX. Linus then decided to upload
this to the Internet (which by then was still largely a university network) for others to use:
From: torvalds@klaava.Helsinki.FI (Linus Benedict Torvalds)
Newsgroups: comp.os.minix
Subject: What would you like to see most in minix?
Summary: small poll for my new operating system
Message-ID: <1991Aug25.205708.9541@klaava.Helsinki.FI>
Date: 25 Aug 91 20:57:08 GMT
Organization: University of Helsinki
Hello everybody out there using minix -
I'm doing a (free) operating system (just a hobby, won't be big and professional
like gnu) for 386(486) AT clones. This has been brewing since April, and is
starting to get ready. I'd like any feedback on things people like/dislike in
minix, as my OS resembles it somewhat (same physical layout of the file-system (due
to practical reasons among other things). I've currently ported bash(1.08) and
gcc(1.40), and things seem to work. This implies that I'll get something practical
within a few months, and I'd like to know what features most people would want. Any
suggestions are welcome, but I won't promise I'll implement them :-)
Linus (torvalds@kruuna.helsinki.fi)
PS. Yes - it's free of any minix code, and it has a multi-threaded fs.
It is NOT portable (uses 386 task switching and so on), and it probably never will
support anything other than AT-hard disks, as that's all I have :-(.
Other people on the Internet started picking up this software, using it, and refining it. The patches
were sent to Linus, who incorporated this into the main kernel stream. Starting to use Linux was a
major undertaking, however. The Linux kernel, the C compiler, the shell, and all the other tools you
need to make a complete operating system were all distributed in source code form. Before you
can make use of them, you need to compile them, which requires a C compiler, which itself also
needs to be compiled first. To break through this vicious circle, people started creating distributions
which contain pre-compiled versions of the kernel, C compiler, various tools, and some sort of
installation program. All this is stored in a convenient format for installation (originally floppy disk
images, but today CD-ROM and DVD, or ISO, images are prevalent). The rest, as they say, is
history. Because of the close association between Linux (the kernel) and the GNU project, an
operating system distribution including the Linux kernel and GNU libraries and utilities is often
called “GNU/Linux”. This is Richard Stallman's strong preference.
Uempty
Uempty
• The user has the right to alter the source code and recompile the source code into binary form.
• The user can distribute the sources and the binaries.
• The user can charge money for all of this.
Basically, the only restriction that the GPL imposes on all users is that the license statement may
not be changed. This means that all your customers have the same rights to the software as you
do. And as a practical aside, that means that in general, it is impossible to make any money from
selling the software (apart from a nominal fee for media and distribution).
The GPL is the most-often used license statement for open source projects, but other licenses,
such as the BSD license, are also being used. BSD-style licenses have very few restrictions.
Uempty
Uempty
large enough beta-tester and co-developer base, almost every problem will be characterized
quickly and the fix will be obvious to someone.”
A third effect of the license model is that if you make significant changes, or add a feature, then that
feature is owned by you, and not by the original author of the software. This means that your name
(as part of the copyright statement for that feature) stays in forever. This is usually a great
motivation factor for people.
Uempty
Linux today
• Linux covers the whole spectrum of computing
Supercomputers
ƒ Embedded devices, smartphones
and mainframes
ƒ Laptops
ƒ Desktop systems
ƒ Development systems
ƒ Small and large servers
ƒ Mega clusters and supercomputers
• Linux is used throughout the world
and in space
• Linux is used by home users, by
most of the largest companies
in the world, and by many
governments Laptops, desktops,
and institutions department servers
Pervasive
computing
The smallest implementations of Linux can be found in embedded devices: the microchips that
control your DVD player, microwave, router, and so forth. The Tivo (http://www.tivo.com), for
instance, runs on Linux. And so does every Android-based smartphone.
In the regular IT-world, Linux runs on laptops, desktops and servers. And it is even used to run most
of the largest supercomputers in the world: As of November 2011, Linux ran on 457 of the Top 500
supercomputers in the world (source: www.top500.org).
Linux is used by home users as well most of the largest companies in the world, numerous
governments and educational institutions. Linux powers most of the web servers on the Internet.
Linux is used throughout the world, and in space: Various experiments on board of the International
Space Station are controlled by systems running Linux.
Linux powered the Deep Blue supercomputer that beat reigning world chess champion Garry
Kasparov. And recently, IBM created a Power-based supercomputer called “Watson”, which
defeated the two most successful contestants of the Jeopardy! game show.*
Note
* http://www.ibm.com/innovation/us/watson/index.html
Uempty
Linux
Operating
System
Linux, in its most narrow definition, refers to the kernel, the heart of the operating system that was
originally written by Linus Torvalds. But today, the word “Linux” is used in much broader definitions
too.
Any operating system that uses the Linux kernel, augmented by GNU and other tools, can be
thought of as a “Linux Operating System”.
Recompiling the Linux kernel and the hundreds of tools that are required to run a Linux Operating
System can be a very daunting task. That’s why “Linux Distributions” appeared quickly after the first
releases of the Linux kernel. A distribution generally consists of an installation program to install the
pre-compiled Linux kernel and other tools quickly and easily on your system. It will also include
things like startup scripts. default settings, management tools, package installation tools, artwork,
themes and so forth.
Creating a Linux Distribution is a large task. Some distributions, most notably Debian, manage to
enlist the help of sufficient volunteers so that their distribution can be downloaded and supported
for free. Most distributions today however have a model where the users of that distribution need to
pay for support, training, certification, marketing, partnerships and so forth. And this income stream
is then used to pay for the further development of the distribution itself. Examples of companies that
have created a commercial enterprise surrounding their distribution are Red Hat, SUSE and
Ubuntu.
Uempty
The last way of looking at Linux is by looking at the Linux Community. This obviously includes the
code itself, and the people developing and supporting that code. But it includes more. There are
various websites that are very Linux-oriented, there are user conferences, mailing lists, support
forums and so forth. And of course there’s Tux, the mascot of Linux.
Uempty
Architecture support
• Intel
• IBM Power
• IBM Mainframe
• ARM
• Itanium
• PA-Risc
• 68000
• And many more!
Almost all operating systems that are currently available are written for one specific hardware
architecture. Originally, that was the case for Linux as well. Linus Torvalds only had an Intel-based
PC. This changed in 1994 when Digital Equipment Corporation (DEC, later bought by Compaq,
which subsequently merged with HP) gave a DEC Alpha to Linus Torvalds, no questions asked. A
few months later, Linux ran on the DEC Alpha.
People took on the effort of porting Linux to other architectures and fed back the
architecture-dependent code to Linus. Later, companies with a commercial interest in running Linux
on their hardware architecture started contributing as well. This means that Linux now runs natively
on a very large number of platforms, including the following:
$ ls /usr/src/linux/arch
alpha blackfin h8300 m68k mips powerpc sh x86
arm cris ia64 m68knommu mn10300 s390 sparc xtensa
avr32 frv m32r microblaze parisc score um
The list in the visual is just the list of architectures that are supported in the mainline kernel.
Patches exist for other architectures as well, but have not all been made part of the mainline kernel.
Uempty
1.2. Red Hat installation
Uempty
Uempty
Topics
• Introduction to Linux
• Red Hat installation
• SUSE installation
Uempty
In many cases, you will be installing third party software. Verify the current version of the operating
system will support your third party application. Review your software documentation or check with
the vendor before installing third party solutions. Make certain any configuration requirements are
part of your installation plan. For example, be aware of the storage space required by the
application and application data. Know where the application will be installed, and memory needed
to support the application.
Uempty
Uempty
Determine if all hardware is compatible with the operating system. In addition to the hardware
manufacturer, several websites can provide this information
Your system must contain sufficient memory. Calculate memory needs for the operating system and
all applications. Memory is defined by type, timing and speed. Your system board will have specific
memory requirements (type and speed) which you need to adhere to.
Calculate the amount of storage you will need to support the operating system, applications, and
data. Your figures should include room for expansion.
Uempty
Installing Linux
• Boot system from bootable media
ƒ CD/DVD
ƒ USB
ƒ PXE
• After booting, install from:
ƒ CD/DVD
ƒ Local hard disk
ƒ Network install
í Requires a network install server and PXE
í Network protocols supported
HTTP
HTTPS
FTP
NFS
Installing Linux starts with booting a very tiny Linux system from some bootable media. All systems
in use today can boot from the installation CD/DVD directly.
Most computer systems support booting from a USB device. USB flash drives are used to run “live”
distributions. Live distributions contain the entire operating system on the USB flash drive.
The third common method of booting a Linux installation program is by using PXE (Preboot
Execution Environment), where all software components are downloaded from a PXE server. In this
case, no local medial whatsoever is required to start the installation.
Once the installation program has been started, it needs access to a package repository. The
package repository may be located on the install CD/DVD, local hard disk or on another system.
Uempty
After the boot process completes, select the install option to begin the installation process.
The first task of the installation process is to choose the installation language. This selection
determines what language is displayed during the installation process.
• Red Hat has a separate screen for selecting the installation language.
• SUSE’s first screen contains a registration agreement, language selection, and keyboard
layout.
Uempty
Next, the installation process displays the installation summary screen. The majority of installation
parameters may be configured from this screen.
Select the appropriate icon to make changes.
• Keyboard Change default keyboard layouts as required.
• Language Select the local language.
• Date and Time Change the current time, day and date, set a specific time zone or configure
network time protocol, NTP, servers.
• Security policy Turns security compliance software on or off (default), All companies do not
require this software which is based on the Security Content Automation Protocol, SCAP,
standard (https://scap.nist.gov/content/index.html).
• Installation Source Specify where package repositories are located (local or network). You
may add additional repositories. If you choose an ISO source, you may verify its integrity by
selecting the verify button. HTTP, HTTPS, FTP, and NFS connections are supported.
• Network and Host Name Configure the system network cards and system hostname. Have
available DHCP, Static IP, DNS, Gateway, and hostname information as required.
• Software Selection Select environment and add-ons for installation.
Uempty
• Installation Destination Choose install location and location of boot loader
• Kdump Linux kernel crash dump reports. Can be enabled or disabled.
• Install Once the installation parameters are set click the install button.
Uempty
Keyboard
• Select and test keyboard layout
Select a keyboard layout or layouts that conform to the keyboards you will use.
Selecting the + symbol will provide a list of available keyboard layouts you may add.
Uempty
Language
• Select additional languages to be installed
This section selects all languages that will be supported on the server.
The column on the left is used to select a general language. The column on the right is used to
select a regional dialect
Uempty
Uempty
Security policy
• Security compliance software on or off
• Select security compliance protocol
Uempty
In the visual above, The window on the left displays the screen used to install network adapters and
configure the host name. This left side of this screen will display all network devices the installer
can “see”. You may add a network device by selecting the + symbol on the bottom left. On the
bottom left of the screen you may enter the machine’s hostname. The right side of the screen is
used to turn the device on and open the configuration screen
When you click on the configuration button the configuration screen (right illustration) is displayed.
This screen is used to configure the adapter. From this screen you may:
1. Set the adapter to be on at boot
2. Allow or restrict all users from accessing the adapter
3. Setup a VPN
4. Setup static IP address, DHCP, gateway, and 802.1 security settings.
Note
You must setup the network first in order to download any software packages over the network.
Uempty
Installation source
• Specify where package repositories are located (local or network)
• Add additional repositories
• Verify ISO source
This screen allows you to select where the installer will find software packages (software
repositories).
If you are installing from a local source installer should have detected it. To the right of the source
device is a verify button. This will verify the integrity of the source
If you have not configured the network you will not be able to select network locations for packages.
To add a repository click the “+” symbol and fill out the repository access information on the right.
To remove a repository select the repository in the repository list and select the “-” symbol
Uempty
Installation destination
• Select the device to install the OS
• Select partitioning scheme
• Select encryption
Select the disk or disks available to the installation process. If a disk drive is not on the list, it may
be added. Disks may be local or available over the network. Supported storage devices include
Fiber Channel, Firmware Raid, ICSCI, and SAN. Disks can be encrypted. A passphrase will be
required when the disk is encrypted.
You may choose to have the operating system partition a disk or partition the disk manually.
The user will also be able to choose the system boot partition and whether or not to install GRUB2
as a secondary boot loader. Having a secondary bootloader allows you to boot from multiple
operating systems (one operating system at a time) as well as change the boot parameters of an
operating system at boot time. A bootloader is a small program used to load and initialize the
operating system’s kernel. A portion of a boot loader is stored in a boot sector, The type of boot
sector is dependent on drive size and motherboard booting method. BIOS based systems with a
disk size less than two (2) Terabytes will use a master boot record, MBR based partition table
scheme. BIOS based systems with a disk size greater than two (2) Terabytes will use a GUID
partition table scheme, GPT, system boards using UEFI will use a GPT partition scheme.
Uempty
Software selection
• Select base environment
• Select add-ons
Uempty
kdump
• Enable kdump
Enable or disable Linux kernel crash dump reports and configure memory to be reserved for
Kdump
Uempty
Clicking Begin Installation starts the install process. Once installation begins, the user is presented
with a screen to set a password for the user root, and to create one additional users. The additional
user may be assigned administrator privileges. There will be an additional opportunity to add users
when the system first boots as part of the First Boot process.
If you forget the root password, you can reset it, but it is easier if you don’t.
As part of the install process the installer, anaconda, writes the file /root/anaconda-ks.cfg.
This file may be used to create a kickstart file. The kickstart file may be used to perform automated
installations.
Uempty
After the installation completes you will need to reboot the operating system.
Once a user logs on they will be presented with several configuration screens which are part of
“First Boot”.
The command systemctl enable initial-setup-graphical.service will display the
first boot configuration screens after the next system reboot.
The First Boot configuration screens display the Red Hat License, and the following configuration
utilities.
Subscription Manager Register Red Hat subscription keys.
User Configuration Add users or configure existing users subscription manager, and screen
displayed after the installation, on reboot, is the Red Hat License. Agree to the license and go
forward.
Configure Date and Time Set date, time, time-zone and time servers.
Kdump Configure Kdump (kernel crash dump). register
Uempty
1.3. SUSE installation
Uempty
SUSE installation
Uempty
Topics
• Introduction to Linux
• Red Hat installation
• SUSE installation
Uempty
Registration Once the user accepts the license agreement the installer will search for devices, and
display the dialog box to configure the network.
If an Internet connection can be made you will be prompted to register your system. Registration is
required for product updates. In addition, if your system is registered, you will be asked if you want
to install updates during the installation process. Registration also permits you access to free
modules and extensions not available to unregistered systems.
Add-on Products Add-on Products are available to everyone. On the next screen select the
location of the Add on Products.
Partitioning SUSE will provide you with a suggested partitioning scheme. You may choose to edit
the proposed settings, select the disk device to partition, or create your own partitioning scheme
using Expert Partitioner. Expert Partitioner starts the Yast Partitioner utility.
Clock and Time Zone This screen sets your time, date and time zone. Selecting the Other Settings
button will allow you to configure your NTP servers.
Create New User Creates a local user. It is not advisable to select automatic logon or use the
password for the system administrator.
Set Root Password Create a password for the user root. DO NOT FORGET THIS PASSWORD.
Uempty
This screen has drop down menus to select the install language and keyboard layout.
In order to proceed with the install check the I Agree to the License Terms checkbox and click the
Next button.
Uempty
Registration
• Valid instance of SLES should be registered
ƒ If you skip registration, you can proceed, but some capabilities will be
limited
• Network must be active for registration to work
Once you have agreed to the license the installer will probe the system for storage and network
devices and other installed systems.
The registration screen is for registering your server. A registered server has access to updates,
extensions, and modules which are not available to non registered servers.
You may skip the registration if you wish.
On the top right of the screen is a Network Configuration button. You must have a network device
configured to register the system with The SUSE Customer Care Center.
Uempty
The installer will try to enumerate a network device. The screen will show a list of the devices it has
found. Select the device and select the edit button to configure the device.
The Hostname/DNS button displays configuration settings for DNS, Hostname, and Domain Name.
The Routing button displays configuration settings for Gateway, and setting up routing tables.
Two check boxes on the bottom left enable IPV4 and IPV6 forwarding.
Uempty
Registration continued
• Once network definition is set, proceed from registration menu with
Next button
Uempty
Add on products
• Optional software repositories can be defined during installation
ƒ Not required to do this
To install packages or drivers from another source select the check box on the top of the screen.
Select the resource type from the list and click on the Next button. On the following screen define
the “path to the repository.
‘
Uempty
Partitioning
• Define disk partitioning
ƒ If you existing Linux partitions exist, menu should be “clean”
ƒ If any Linux partitions have been defined on target disks, menu will show
Uempty
Uempty
Expert partitioning
• Expert partitioning option gives full control of disk configuration
ƒ As name suggests, you have full control, so be careful!
Expert Partitioner is the GNU version of Parted which has been integrated into Yast. This selection
permits you to manually partition your hard disk devices.
With Expert Partitioner you may create new partitions, delete existing partitions, resize partitions,
and place file systems on partitions.
You may also create and manage logical volumes, BTRFS and raid devices.
Uempty
Clock and time are used to set the local region, time zone, and enable UTC,.
Selecting the Other Settings button date and time provides access to settings for the current date
and time, and NTP servers.
Uempty
Uempty
Uempty
This screen is used to review and change system settings, and start the install.
Software Selecting this link allows you add or remove software patterns and packages.
Booting Displays the boot loader (by default GRUB2) configuration
Firewall and SSH Enable or disable SUSE’s firewall and SSH. By default, the firewall is enabled
and set to the external zone (external networks). SSH is disabled by default.
Kdump Turn the kernel crash dump report facility on or off (default).
Default system Target Change whether the system boots into a graphic (default) or text
environment.
System Display system hardware information
Install You will need to click the install button twice. The first time may display software license
agreements. The second time you click the install button the installation process will begin.
Uempty
Software Selection
• SLES installs a lot of software by default
ƒ If you want more, select here
Package Status
The software selection screen shows the patterns which are available and their status.
A pattern with a + symbol contains other patterns. Clicking on the plus sign expands the description
You may select patterns to be installed by clicking on the check box.
Uempty
Details - Selecting the details button expands the patterns (left column) and displays the packages
associated with the patterns (right column) You may add packages which belong to the pattern, but
are not selected by selecting the check box next to the pattern name.
There are several methods of filtering how package groups are displayed.
View – The view button on top allows you to change the display. You can view packages by
patterns, package groups, rpm groups, language and repository. Notice these buttons are also
available across the top of the screen.
Search – String based search for packages
Patterns – List of available patterns. If you select a pattern a list of packages will appear in the top
right view box, If you select a package from the top right view box detailed information concerning
that package (description, dependencies…) will appear in the bottom right view box.
Installation Summary – List of packages installed.
Package Groups – List of package groups.
RPM Groups – List of packages sorted by RPM group
Repository – List of packages grouped by their source repository
Languages – List of packages sorted by language
Uempty
Boot Code Options - Set the Boot Loader. Available Selections are GRUB2, GRUB2 EFI and no
boot loader.
Kernel Parameter – Set kernel parameters to be passed when the system boots.
Bootloader Options – Set timeout, default boot section and assign a bootloader password.
Uempty
By default the firewall and SSH service are enabled, but the Open SSH port is disabled. This
screen allows you to change those settings.
The firewall is configured “external zone”.
Uempty
kdump start-up
• Define kdump memory configuration
Uempty
Uempty
Detected hardware
• Review detected hardware
ƒ Confirm what you expect to be connected is actually there
Uempty
Uempty
Confirm installation
• This is your last chance to change your mind!
Uempty
Keywords
• Linux
• Unix
• GNU
• GPL
• Community
• Architecture
• Red Hat
• SUSE
• Installation media
• PXE boot
These keywords are provided as a reminder of key subjects discussed in this unit.
Uempty
Unit summary
• Discuss the history of Linux
• Name some important people in the history of Linux
• Discuss the GNU general public license
• Prepare a system for installation
• Install Linux from CD-ROM
• Perform a network installation
Uempty
Review questions (1 of 2)
1. True or false: Linus Torvalds wrote the Linux operating
system all by himself.
Uempty
Review answers (1 of 2)
1. True or false: Linus Torvalds wrote the Linux operating
system all by himself.
The answer is false.
Uempty
Review questions (2 of 2)
4. Which of the following steps is not essential in the
installation process?
a. Create partitions for Linux.
b. Configure your printer.
c. Select your keyboard type.
d. Identify the packages to install.
Uempty
Review answers (2 of 2)
4. Which of the following steps is not essential in the
installation process?
a.Create partitions for Linux.
b.Configure your printer.
c.Select your keyboard type.
d.Identify the packages to install.
The answer is configure your printer.
Uempty
Uempty
Exercise introduction
• Learn the various Linux installation methods
Uempty
Overview
This unit describes logging in and out of the system, the structure and execution of Linux
commands, and using Linux commands to communicate with other users. This unit will also discuss
using the keyboard and mouse effectively and the X Window System.
Uempty
Unit objectives
• Log in and out of the system
• State the structure of Linux commands
• Execute basic Linux commands
• Use Linux commands to communicate with other users
• Use the keyboard and mouse effectively
• Discuss the X Window System
Uempty
Just like conventional UNIX systems, Linux is designed from the ground up as a multiuser,
multitasking operating system. This means that multiple users can run multiple tasks
simultaneously on the same system, independent of each other. Security is of course paramount on
such systems, because it would be unacceptable if one regular user could stop or otherwise
influence processes of other users. For this separation to work properly, user authentication is
needed.
User authentication on a Linux system is done when you first start using the system. Before you
can do anything, you need to identify yourself using your username and password. On a real
multiuser system, typically, the system administrator assigns you a username and initial password.
When using Linux on your personal workstation, you'll often administer the system yourself.
Administrators use a special super-user account, called root, which has security privileges to be
able to create other user accounts and set their passwords.
There are multiple ways of logging into a Linux system and you can be logged in as the same user
multiple times. A single log in instance is referred to as a session.
Uempty
Virtual terminals
• In most Linux distributions, the console emulates a number of virtual
terminals (VT)
• Each virtual terminal can be seen as a separate, directly attached
console
ƒ Different users can use different virtual terminals
• The following is a typical setup:
ƒ VT 1 through 6: Text mode logins
ƒ VT 7: Graphical mode login prompt (if enabled)
• Switch between VTs with Alt-Fn (or Ctrl-Alt-Fn if in X) or with
the chvt command
In most Linux distributions, the console emulates a number of virtual terminals. These virtual
terminals can be seen as separate, directly attached consoles and can be used by different users,
although, in practice, this is rather inconvenient. Because the system in reality only has one
console, there are hotkey combinations to switch from one VT to another. This hotkey combination
is Alt-Fn, where the n is the virtual terminal number you want to access. When you are in an X
environment, you need to use Ctrl-Alt-Fn instead.
The default virtual terminal setup differs from distribution to distribution, but the most common setup
offers six text mode logins on VTs 1 through 6, and (if enabled) a graphical mode login on VT 7.
(How this is enabled is covered later.)
Linux also has a chvt command that lets you switch virtual terminals.
Uempty
Login:
Uempty
The visual shows a graphical mode login session. The exact layout of the graphical login session
varies from distribution to distribution and from desktop environment to desktop environment.
Uempty
Linux commands
• Everything on a Linux system can be done by typing commands
ƒ Even browsing the World Wide Web
• The graphical user interface (X Window System or X) is not
needed for running a Linux system
ƒ But is sometimes more convenient
• A terminal emulator will allow you to type commands when
using the graphical interface
Every process that is running on a Linux system is started by a command, although for most
processes, you never see that command because they are started automatically. In addition, every
command can be executed from any login session, be it local or remote, which means a Linux
system can be managed just as easily over the network as locally. You do not need to sit down at
the console, in a possibly noisy and cold server room to manage a Linux system.
Similarly, most commands do not need a Graphical User Interface (X) to run. And if there are
commands that do need X (such as the Web browsers Netscape and Konqueror), then there are
usually text-based alternatives available that can do without X (such as Lynx, a text-based Web
browser). Using the GUI is sometimes more convenient though, especially for things like graphics
design, games and browsing the Web. Commands can obviously be run from a text-based terminal.
But to run commands from within X, you need to start a terminal emulator.
Uempty
Red Hat:
SUSE:
A terminal emulator is a program that emulates a text terminal in an X environment. The window
that is consequently opened is called a terminal window. Various desktop environments have
different terminal emulators, and have different buttons to start them. The visual shows the buttons
for the GNOME and KDE desktop environments.
Uempty
Command prompt
• The command prompt indicates that the system is ready to accept
commands
• It can be configured yourself (this will be covered later)
ƒ The default depends on distribution
• Examples include:
[user@host dir]$
dir$
$
#
• The dollar sign ($) usually means you are logged in as a regular
user
• The hash sign (#) usually means you are logged in as root
The command prompt is the indication that the system is ready to accept commands. Only when
the command prompt shows (in a text terminal or terminal emulator) can you type commands. (If
the command prompt does not show, you can already type the beginnings of a command. The keys
typed then appear as soon as the command prompt displays.)
What the command prompt looks like is something you can configure yourself; we do that later.
Different distributions have different default settings, of which the visual shows some examples.
What is important to note is that, for historic reasons, a dollar sign ($) usually means that you are
logged in as a regular user, and a hash sign (#) usually means that you are logged in as root.
Uempty
$ ls
$ ls –l
$ ls /dev
$ ls –l /dev
Note:
If no flag is used, do not add extra
space in command
Using the system © Copyright IBM Corporation 2001, 2018
The order and separation of the elements of a command is very important. The command or
process name must come first. Spaces are used by the shell as separators on the command line
and should not be placed within the command name.
The flags (also called options) should follow the command name, separated by a space and
preceded by a minus sign (-) or a plus sign (+). Multiple options may be grouped immediately after
a single minus (-) or separated by spaces and each preceded by a minus (-). Options are typically
used to modify the operation of the process.
The arguments follow the options, again separated by a space. The order of the arguments
depends on the command.
Hint: In order to determine valid command options and arguments, many Linux commands have
built in help information.
Command help is accessed using the double minus sign (--) followed immediately by help, for
example, ls –help.
We will go over this in greater detail in a later unit.
Uempty
• Order • Order
$ ls -l myfile $ ls myfile -l
$ rm myfile $ myfile rm
$ who -u $ -u who
Uempty
Command Description
passwd Change your password.
In the next few visuals, we are going to look at the commands listed in the visual.
Uempty
The user password is the primary mechanism for ensuring security on a Linux system. All
passwords are encrypted and cannot be decoded. The passwd command is used to change the
user password and is an example of a simple command that may be entered at the shell prompt.
The system starts the passwd process that prompts the user for a new password. To prevent users
being locked-out of the system through simple typing errors, the new password is entered twice.
Only if the two entries match is the new password accepted. The old password is invalid thereafter.
Choosing a good password is important, because too many systems have been broken into
because of bad (easily guessed) passwords. The passwd command has options to set password
expiration and age parameters of the users password.
The best passwords are passwords that have meaning to you (so they’re easy to remember) but
not (partly) listed in a database (for instance a dictionary) and are long enough not to be guessed
easily by just trying out random passwords. You could for instance form a sentence that has
meaning to you, and use the initial letters of each word as your password. As an example,
“MfewLwiD11@aIc” (which is short for “My first encounter with Linux was in December 2011 at an
IBM course”) is a very strong password.
Uempty
The date command shows you the current system date and time.
Note that the time zone is displayed, too: Linux has a full implementation of time/date functions,
which includes compensation for time zones and daylight savings time. This might seem overkill
until you realize that people from all over the world might be using the same system at the same
time, but all want their times to be displayed as local time.
You can play with your local timezone by setting the TZ variable. This will automatically set all times
as displayed by date and other commands to that timezone. Setting variables will be covered later.
Uempty
• Looking at a year
$ cal 2017
2017
January February March
Su Mo Tu We Th Fr Sa Su Mo Tu We Th Fr Sa Su Mo Tu We Th Fr Sa
1 2 3 4 5 6 7 1 2 3 4 1 2 3 4
8 9 10 11 12 13 14 5 6 7 8 9 10 11 5 6 7 8 9 10 11
15 16 17 18 19 20 21 12 13 14 15 16 17 18 12 13 14 15 16 17 18
22 23 24 25 26 27 28 19 20 21 22 23 24 25 19 20 21 22 23 24 25
29 30 31 26 27 28 26 27 28 29 30 31
With the cal command, you can look at the calendar of a given year or a given month in year.
Uempty
$ who
root tty1 Jan 1 11:10
tux1 tty2 Jan 1 11:04
$ who am i
host!tux1 tty2 Jan 1 11:04
$ whoami
tux1
To find out who is logged onto your system, you can enter one of the following two commands:
• The who command shows you the user’s ID and display where the user logged in, date and time
the user logged in, and (if a network is used) the host name the user logged in from.
• The who am i and whoami commands show you what user you logged in to the system as.
Uempty
$ finger
Login Name Tty Idle Login Time
tux1 Tux (1) 2 Jan 1 11:04
root root *1 7 Jan 1 11:10
$ finger tux1
Login: tux1 Name: Tux (1)
Directory: /home/tux1 Shell: /bin/bash
On since Mon Jan 1 11:04 (UTC) on tty2
No mail.
No plan.
The finger command shows you additional information about a user, for instance, yourself. The
finger command shows you the user ID, full name, display, idle time, date and time the user
logged in, and some office information. The asterisk (*) in the output of the finger command
indicates that the issuer of the finger command cannot write to this (tty1) device.
Note that the finger service is by default disabled in most distributions, because it can also be
accessed over the network and is considered a security risk: through the finger service, an intruder
can easily obtain a list of all usernames on the system, and determine which accounts have been
inactive for a while. This makes breaking in easier, and breaking into an inactive account is less
likely to be noticed. How to install and enable the finger service is covered later in this course.
Uempty
Uempty
Tux1 Tux2
• To disable write, wall and talk reception, use mesg n
talk is one of the earliest programs that allowed you to directly communicate to another user
without the use of a telephone. It was later succeeded by programs like IRC, ICQ and MSN.
To prevent messages originating from programs like write, wall and talk reaching your terminal,
use the mesg n command. To enable these messages again, use mesg y. Note that the root user is
always able to write or wall to your terminal screen.
Uempty
Keyboard tips
• <arrow up/down> Previous/next command
• <arrow left/right> One character left/right
• <Shift PgUp/PgDn> Scroll window up/down
• <Tab> Command or file name completion
• <Ctrl-R> Search for command in history
• <Ctrl-C> Terminate current command
• <Ctrl-D> End of transmission/input/file
The bash shell keeps track of all commands that are entered (including options and arguments) in
the “command history”. Likewise, a text terminal or graphical terminal emulator keeps track of all
the output of the commands as it appeared on screen.
Using the keyboard we can recall these command and output histories.
First, with your arrow keys you can scroll through the command history and thus retrieve, modify
and re-execute previous commands. Ctrl-R even allows you to search in the command history.
Second, using Shift-PgUp and Shift-PgDn you can scroll through the terminal output history.
Another key you need to know about is the <Tab> key. This key is used for command completion (if
used on the first argument on the command line) and filename completion (if used on any other
arguments): Simply type the first few letters of the command of filename you’re trying to type, and
hit <Tab>. If the letters that you typed unambiguously lead to a command or filename, the whole
command or filename will be substituted. If there is ambiguity, the command or filename will be
completed as far as possible. In this case, hit <Tab> twice to get a list of all possible commands or
filenames that fit the first few letters that you typed.
<Ctrl-C> is the key combination that’s most often used to terminate a running command.
Technically speaking, it sends a signal to the command that is supposed to cause it to stop. Signals
will be covered in a later unit.
Uempty
<Ctrl-D> is used as the end-of-transmission/input/file indicator. It is useful to indicate to certain
programs that you’ve reached the end of what you wanted to send to this program. One example is
that <Ctrl-D> is a signal to the shell itself to indicate you’ve finished working with it and want to
leave the shell - effectively logging you out.
Uempty
Locking
• When temporary leaving a system alone, always lock your terminal
• In a text mode terminal, use vlock (lock your terminal) or vlock –a
(lock the whole console)
• In a graphical environment, use the menu, the “padlock” icon or
xlock
ƒ Most screensavers support automatic locking as well
• A locked terminal can only be unlocked with the users password
When you’re going to be away from your system for a short period of time, lock your terminal. The
easiest way of breaking in, after all, is finding a door which is already open.
Locking a text mode terminal can be accomplished with the vlock command. The vlock -a
command not only locks your virtual terminal, but the whole console. Most distributions,
unfortunately, do not install vlock by default.
In a graphical environment, use the menu options, the padlock icon or the xlock command. Most
screensavers support locking too.
A locked terminal can only be unlocked with the users password* .
Note
* Occasionally you will find a configuration where you can also unlock a terminal with the root
password. This requires the xlock command to run with root privileges though, and is generally
considered a security risk.
Uempty
Logging out
• When finished working on a system, always log out
• In a text mode terminal, use logout, exit, or <Ctrl-D>
• In a graphical environment, use the menu
Uempty
Keywords
• multiuser
• multitasking
• root user
• virtual terminal
• text mode
• graphics mode
• terminal emulator
• commands
ƒ passwd
ƒ date
ƒ who
ƒ echo
ƒ write
ƒ wall
ƒ mesg
These keywords are provided as a reminder of key subjects discussed in this unit.
Uempty
Unit summary
• Log in and out of the system
• State the structure of Linux commands
• Execute basic Linux commands
• Use Linux commands to communicate with other users
• Use the keyboard and mouse effectively
• Discuss the X Window System
Uempty
Review questions
1. True or false: A Linux system always needs a graphical user
interface.
Uempty
Review answers
1. True or false: A Linux system always needs a graphical user
interface.
The answer is false.
Uempty
Uempty
Exercise introduction
• Become familiar with Linux, the command syntax, some basic
commands, and multi-user concepts
Uempty
Overview
This unit describes different file types and file names and path names. This unit will also illustrate
how to create, delete, copy, and move directories and files as well as how to view the content of
both text and binary files.
Uempty
Unit objectives
• Describe the different file types
• Describe file and path names
• Create, delete, copy, move, and list directories
• Create, delete, copy, and move files
• View the content of both text and binary files
Working with files and directories © Copyright IBM Corporation 2001, 2018
Uempty
3.1. File system structure
Uempty
Working with files and directories © Copyright IBM Corporation 2001, 2018
Uempty
Topics
• File system structure
• Command operations
Working with files and directories © Copyright IBM Corporation 2001, 2018
Uempty
A file
• A file is:
A_collection_of_data\n
A_stream_of_characters_or_a_"byte_stream"\n
No_structure_is_imposed_on_a_file_by_the_operating_system\n
• \n is a newline character
• _ is a space character
Working with files and directories © Copyright IBM Corporation 2001, 2018
Linux imposes no internal structure on a file's content. The user is free to structure and interpret the
contents of a file in whatever way is appropriate.
Uempty
File types
ascii text
Hardware devices, for
100 .bashrc example:
executable 164 .profile /dev/lp0 (printer device)
238 myfile
jpeg picture 475 walrus
Logical devices, for example:
html file /dev/null (null device)
Working with files and directories © Copyright IBM Corporation 2001, 2018
An ordinary file can contain either text or code data. Text files are readable by a user and can be
displayed or printed. Code data, also known as binary file, is readable by the computer. Binary files
can be executed.
Directories contain information the system needs to access all types of files, but they do not contain
the actual data. Each directory entry represents either a file or subdirectory. Special files usually
represent devices used by the system. A very useful special file is /dev/null, which can be used
as a sort of trash bin for unwanted output.
Uempty
Working with files and directories © Copyright IBM Corporation 2001, 2018
In general, the naming of files is free in Linux. Linux for instance does not force filenames into an
8.3 format like MS-DOS did. Extensions in general have no value to the shell. They might be
relevant for applications, though. Theoretically, every character on your keyboard can be used in a
filename. But since the shell interprets various characters as metacharacters, it is best to stick to
lowercase and uppercase letters, digits, the underscore and the at sign. Other characters, such as
embedded blanks and metacharacters should preferably not be used. If you encounter them, you
need to quote them properly, (discussed later).
The dot is a special case: Anywhere in the filename, it is simply used as part of the file name,
except when the dot is the first character in the file name. If a file name begins with a dot (for
example, .bash_profile), the file is considered to be a hidden file and does not show up when you
enter the ls command, for example. Note that the ls –a command will show all files, including
hidden ones.
Uempty
Directory structure
• All Linux directories are contained in one virtual, unified file system
• Physical devices and network shares are mounted on mount points
ƒ USB flash drives
ƒ Hard disk partitions
ƒ Optical disk drives
ƒ NFS volumes, Windows shares
• There are no drive letters like A:, C:, and so on
Working with files and directories © Copyright IBM Corporation 2001, 2018
All Linux directories and files are contained in one virtual unified file system. This means that all
physical devices with file systems on them (floppy disks, hard disk partitions, optical disk drives) are
all combined into one giant tree structure. Among other things, this means that Linux does not use
drive letters, such as A:, C:, and so forth.
For the layout of this unified file system, most Linux distributions closely follow the Linux File
System Hierarchy Standard, a collaborative document that defines the names and locations of
many files and directories. The standard can be viewed at http://www.pathname.com/fhs.
The standard closely follows the conventional UNIX file system, with some minor modifications. In
the next few graphics, you can view the contents of the various directories.
Uempty
Working with files and directories © Copyright IBM Corporation 2001, 2018
/bin, /lib, and /sbin contain executables and libraries which always need to be available, even
in the worst of scenarios, because these tools are essential for system maintenance and recovery.
The difference between /bin and /sbin is in the people who use them. /bin is for everybody, and
/sbin is typically tools needed only by the system administrators. Therefore, you cannot find /sbin
in the search path ($PATH) of a normal user, but you can in the path of a system administrator.
Libraries are shared parts of code, which are available to every program that might want to use the
code. Because different programs use the same routines, for example, writing to the screen, it
saves disk space and effort to put these routines into one central library. Otherwise, you might need
to put them into individual programs.
Uempty
Working with files and directories © Copyright IBM Corporation 2001, 2018
The /boot directory contains the kernel images, some other things related to these images, and
the files needed for the bootloader (LILO or GRUB).
The /dev directory contains special files that represent the hardware of your system. By writing to
these devices or reading from or both, you can usually (but not always) interact almost directly with
the hardware. Note, however, that this generally is not a particularly safe thing to do. Access to
these devices is, therefore, usually restricted to root.
There are two types of special files in the /dev directory. (Note that two other types of special files
exist too: Named pipes and UNIX sockets. These are generally not located in /dev, but in /tmp.)
The /etc directory contains the system-wide configuration files. These files apply to each and
every program that is running, and each, and every user.
Some programs or subsystems create their own subdirectory in /etc because they have more
than just a few configuration files and want to keep these files together. As an example, /etc/X11
contains configuration files specifically for the X Window System.
Uempty
Working with files and directories © Copyright IBM Corporation 2001, 2018
The /home directory contains the home directories of the users. Within home, each user has its
own directory, identified by the username, for instance, /home/tux1.
/root is the home directory of the root user.
/tmp is used as a temporary storage space for programs and users. Temporary in this context
means a couple of minutes, hours at most, instead of days and weeks.
Some system administrators have automatic cleanup jobs running every night that clean /tmp of
files older than a few days.
Uempty
Working with files and directories © Copyright IBM Corporation 2001, 2018
/proc is a virtual file system that exists only in the imagination of the kernel. It is used for
accessing the kernel's data structures, (for instance, the interrupts, imports, and so on), and for
accessing process information.
/sys is also a virtual file system. It acts as a counterpart to /proc. It provides detailed information
about kernel status to userspace including which modules/drivers that are loaded and specifics
about the file system.
Uempty
• /usr contains all the user programs that the system needs
• /var contains data that is changed when the system is running
normally. It is specific for each system, that is, not shared over the
network with other computers
• Logs often reside on /var, and they can get voluminous
Working with files and directories © Copyright IBM Corporation 2001, 2018
/usr is by far the largest directory on a freshly installed Linux system. It contains all the programs
that need to be available on the system, but need not be available at boot time or in an emergency.
/var holds files that might vary greatly in size. Typical examples of these files include log files,
usually stored in /var/log. But other applications also generate files of which the size or contents
vary greatly. These are then also stored somewhere in /var.
/var/tmp is sometimes also used as temporary storage space, just like /tmp, but with a longer
retention period (weeks or more).
Uempty
Other directories in /
Working with files and directories © Copyright IBM Corporation 2001, 2018
Various other directories might be present in the root of your file system. It is of course up to you to
decide which directories to create and what to store in them. On a SUSE system, subsystems such
as GNOME, KDE, and OpenOffice are installed in /opt.
/mnt is usually used as a placeholder for all the mount points you need for mounting non-standard
file systems. For example: /mnt/windows for a Windows partition.
/media is commonly used as a placeholder for the mount points for various media:
/media/cdrom, /media/floppy, and so forth.
Every file system has a lost+found directory, which is created when you create the file system. It is
normally empty; however, should a system crash occur when the file system is not in a stable state,
fsck (file system-check) checks the file system and places any files that do not have a name in
lost+found. The system administrator then must decide who that file belonged to and find a way to
give it back to the rightful owner.
Uempty
Linux /usr
Linux swap
Linux /var
Working with files and directories © Copyright IBM Corporation 2001, 2018
The file system layout reflects the expected usage of the system.
A typical Linux server has its storage divided into various partitions as needed. It has separate file
systems for each of the main directories. These file systems can then be backed up individually,
can have different quota applied, have different mount permissions and so forth.
For comparison, if you had a workstation with a dual-boot configuration, it would have all its
Linux-specific data in one big root file system. All Windows-specific data is in one big NTFS
formatted Windows file system, and all data that needs to be shared across both platforms sits in a
separate, FAT-formatted file system which can be accessed by both.
Uempty
home
Working with files and directories © Copyright IBM Corporation 2001, 2018
Uempty
3.2. Command operations
Uempty
Command operations
Working with files and directories © Copyright IBM Corporation 2001, 2018
Uempty
Topics
• File system structure
• Command operations
Working with files and directories © Copyright IBM Corporation 2001, 2018
Uempty
Working with files and directories © Copyright IBM Corporation 2001, 2018
The path name is written as a string of names separated by slashes (not back slashes like in DOS,
or Windows). The rightmost name can be any type of file (ordinary, directory, or special). The other
names must be directories.
A path name is always considered to be relative unless it begins with a slash (/). An absolute path
name or full path name always starts with a slash.
Uempty
Where am I ?
• The pwd command (Print Working Directory) can be used to find out
what your current working directory is
$ pwd
/home/tux1
$
Working with files and directories © Copyright IBM Corporation 2001, 2018
The pwd command always returns the full path name of your (current) present working directory. It
is not a bad idea to use this command often, especially when you are removing files (to be sure you
are removing them from the correct directory).
Note
Most distributions, by default, configure a shell prompt, which lists the last part of the current
directory as well.
Uempty
$ cd doc (relative)
$ cd /home/tux1/doc (full)
$ cd ~tux1/doc (home)
Working with files and directories © Copyright IBM Corporation 2001, 2018
Using the cd command with nothing after it automatically returns you to your home directory. This is
the directory into which you are usually placed when you log in.
Uempty
Create directories
• With the mkdir (Make Directory) command:
ƒ $ mkdir dir_name
$ cd /home/tux1
$ mkdir doc (relative pathname)
Working with files and directories © Copyright IBM Corporation 2001, 2018
The mkdir command creates one or more new directories specified by the dir_name parameter.
Each new directory contains the standard entries . (dot) and .. (dot dot).
The -m option can be used with the mkdir command to specify the directory being created with a
particular set of permissions.
Uempty
Removing directories
• With the rmdir (Remove Directory) command:
ƒ $ rmdir dir_name
$ pwd
/home/tux1
$ rmdir doc test
rmdir: doc: Directory not empty
$
Working with files and directories © Copyright IBM Corporation 2001, 2018
The rmdir command lets you delete directories. You get no message if the command is successful.
It never hurts to follow a command such as this with an ls, which is discussed on the next page, to
make sure that you have accomplished what you set out to do.
It is also practical to check if you are in the correct directory with pwd, before you try to remove
something.
Uempty
$ mkdir -p dir1/dir2/dir3
$ rmdir -p dir1/dir2/dir3
Working with files and directories © Copyright IBM Corporation 2001, 2018
The mkdir dir1/dir2/dir3 command generates an error message if neither dir1 nor dir2 exists.
To overcome this problem, you could use the -p option with mkdir. If dir1 and dir2 already exist,
only dir3 is created.
The -p option with rmdir first removes dir3, then dir2, and finally the dir1 directory. If a directory is
not empty, you are in it, or you do not have the right permissions to it when it is removed, the
command terminates.
Uempty
$ ls /home
tux1 tux2 tux3
Important options:
-l long listing (more information)
-a lists all files (including hidden)
-t lists files sorted by change date
-R lists contents recursively
Working with files and directories © Copyright IBM Corporation 2001, 2018
The ls command is used to list the contents of a directory, and has many useful options. If no file or
directory name is given as an argument, the current directory is used.
By default, the ls command displays the information in alphabetic order. When the ls command is
executed it does not display any file names that begin with a dot (.), unless the -a option is used.
These files are generally referred to as hidden files, for this reason.
Uempty
$ ls -l
-rw-rw-r-- 1 tux1 penguins 512 Jan 1 11:10 docs
$ touch docs
$ ls -l
-rw-rw-r-- 1 tux1 penguins 512 Jan 1 15:37 docs
$ touch new
$ ls -l
-rw-rw-r-- 1 tux1 penguins 512 Jan 1 15:37 docs
-rw-rw-r-- 1 tux1 penguins 0 Jan 1 15:38 new
Working with files and directories © Copyright IBM Corporation 2001, 2018
Uempty
Copying files (1 of 2)
• The cp command copies files.
ƒ cp source[s] [target]
$ cp .bashrc bashrc.old
Working with files and directories © Copyright IBM Corporation 2001, 2018
Pay attention to the two ways you can use the cp command. The first syntax copies a file from one
directory to another directory. The second syntax is if you enter more than two parameters to cp.
This means that the first n parameters (which represent files) are copied to the last parameter,
which represents a directory.
Uempty
Copying files (2 of 2)
• cp can recursively copy directories with the -R flag.
$ cp -R /home/tux1/doc /tmp
To prevent cp from
overwriting existing
files
$ cp -R -i /home/tux1/doc /tmp
cp: overwrite `/tmp/doc/walrus´?
Working with files and directories © Copyright IBM Corporation 2001, 2018
When using the cp command, if the file specified as the target file already exists, the copy operation
writes over the original contents of the file without warning. To avoid this, use cp -i (interactive
copy).
If you are copying more than one file in one operation, the specified target must be a directory. If the
target is a directory, the copy has the same name as the original file.
cp -R can be used to recursively copy all files, subdirectories, and the files in those directories to a
new directory.
Uempty
$ mv doc/walrus ../../tmp
Move a file do
$ mv doc documents another directory
Rename a file
Working with files and directories © Copyright IBM Corporation 2001, 2018
The mv command is used to move files from one directory to another. The syntax is
mv source target. The mv command can also be used to rename files. The source can be a file
or a list of files. If the source is a list of files, then the target must be a directory.
The target can be a file or a directory.
CAUTION
If the target is the name of a file that already exists and if you have the correct permissions set for
that file and directory, you overwrite the file and never get an error message. To avoid this, use
mv -i, an interactive move, which prompts you if there are duplicate names. As a result of the mv
you still have the same number of files as you did before. Furthermore, all the attributes remain the
same.
Uempty
$ cd
$ pwd
/home/tux1
$ mv /tmp/walrus ./test/walrus2
Move a directory
$ mv ./test /tmp
mv is recursive by default
Working with files and directories © Copyright IBM Corporation 2001, 2018
If the source is a directory instead of a file, mv attempts to move this whole directory to the new
location, with all the files in it. Earlier versions of mv would only do this if the source and target
directory were on the same file system. Current versions of mv now perform a cp and rm
automatically if you try to move directories between file systems.
The main difference between mv and cp is in what happens with the update time, inode number,
and so forth. mv retains the inode number and the inode. cp creates an entirely new file with new
inode information, changing only the file name and access time.
Uempty
Removing files
• You can move files with the rm command
$ rm test/walrus2
$ ls test/walrus2
ls: rob: No such file or directory
If unsure, use -i
$ rm -i test/walrus2 option
rm: remove `test/walrus2´?
$ rm -ir test/
Remove files and
directories recursively
Working with files and directories © Copyright IBM Corporation 2001, 2018
The rm command removes the entries for the specified file or files from a directory. Note that the rm
command by default does not require confirmation from the user2. For the interactive version of the
command, use the -i option.
The -r option permits recursive removal of directories and their contents if the directory is
specified. Be careful when using this option, as it does not require the directory to be empty for this
option to work.
The -f (force) option prevents error messages and does not ask the user for confirmation.
Uempty
$ cat walrus
"The time has come", the walrus said,
"To talk of many things:
Of shoes - and ships - and sealing wax -
Of cabbage - and kings -
And why the sea is boiling hot -
And whether pigs have wings."
$
Working with files and directories © Copyright IBM Corporation 2001, 2018
If the output of the cat command is longer than a screen, the file scrolls until the bottom of the file is
reached. Thus, you may only be able to read the last full screen of information. The cat command
can be used to copy two files into one file. The syntax is:
cat file1 file2 > new_file
Uempty
$ less walrus
"The time has come", the walrus said,
"To talk of many things:
Of shoes - and ships - and sealing wax -
Of cabbage - and kings -
And why the sea is boiling hot -
And whether pigs have wings.“
/tmp/test/walrus 1-6/6 (END)
Working with files and directories © Copyright IBM Corporation 2001, 2018
The more and less commands reads the file names specified and displays the contents of the files
one page at a time. Use the space bar to view the next page and the b key to view previous one.
To search for patterns in the file which is displayed, use the / (forward slash) key. To repeat a
search, use n. The advantage of less over more is that less can also scroll backwards if its input is
received from a pipe. Another difference is that less clears the screen when done, while more
keeps the content of the last page on screen.
Use the q to end the more and less commands. (less does not terminate itself when the end of the
file is reached.)
Uempty
Working with files and directories © Copyright IBM Corporation 2001, 2018
od (Octal Dump) allows you to view the contents of a binary file byte by byte. Without any option,
od shows the contents of the file in octal format, but you can also specify the -c option for decimal
display, or the -h option for hexadecimal display. Other output options also exist.
strings is also a very handy tool to take a peek at binary files. It displays only all the strings that
occur in a binary file. (A string is a combination of at least four consecutive, contiguous, printable
ASCII characters.)
An alternative for od is hexdump. It basically does the same thing, but in a slightly more readable
format. It is not available on all distributions by default, however.
Uempty
File managers
• Linux also offers different graphical file managers
ƒ Nautilus (GNOME)
ƒ Konqueror (KDE)
Working with files and directories © Copyright IBM Corporation 2001, 2018
When you are in a graphical environment, you do not need to use these commands (although they
are not that hard if you are used to them), but you can use one of the several graphical file
managers that are available for your desktop environment to perform file operations.
Both the GNOME and KDE file managers have the capability to recognize the type of file that you
are working with and, if appropriate, allow you to do something with the content as well. If you click
a .tar.gz file (a compressed file archive), for instance, it automatically uncompresses the file and
opens the archive. You can then copy the files out of the archive.
Uempty
Kernel
Individual file systems space
Device drivers
Working with files and directories © Copyright IBM Corporation 2001, 2018
The virtual file system (VFS) is the primary interface to the underlying file systems. This component
exports a set of interfaces and then abstracts them to the individual file systems, which may behave
very differently from one another. Each individual file system implementation, such as ext2, JFS,
and so on, exports a common set of interfaces that is used (and expected) by the VFS.
The VFS layer provides added flexibility that allows individual file systems to be dynamically added
or removed on a Linux system.
Uempty
/dev/hda5 /dev/hda6
This directory
/ / is now called
bin lib sbin tmp spool log /var/log
/dev/hda5 is /dev/hda6 is
mounted on /usr mounted on /var
Working with files and directories © Copyright IBM Corporation 2001, 2018
The virtual unified file system model that Linux uses allows all know file systems to be mounted on
top of each other in a huge, virtual file system. Mounting associates a storage device with a file
system. This offers transparency to users, makes system administration easier, and makes it
possible to support far more than 26 different file systems simultaneously.
The first file system is called the root file system and is mounted by the kernel itself, when the
kernel starts. In addition to regular directories and data, this file system also contains a number of
empty directories, which are used as mount points for other file systems. As an example, take a
look at /dev/hda6 in the visual. It is a fully contained file system, with its own directories and files.
One of the directories is called log. When this file system is mounted on the var directory in the root
file system, the log directory now becomes available in our virtual file system hierarchy as
/var/log. But you also could have mounted /dev/hda6 on, let’s say, the mount point (empty
directory) variable in the root file system (/dev/hda2). Then all of a sudden, the log directory would
have become available as /variable/log.
There are several reasons for creating multiple file systems, and then mounting these on top of
each other:
• It makes it easier to do partial and incremental backups.
• It allows you to set different disk space quota per file system.
Uempty
• It allows you to split your data over multiple disks and makes migration of data between disks
easier.
• It allows you to apply different security settings (such as read-only) to different file systems.
• It allows you to mount certain file systems over the network.
Therefore, on important servers, you typically see multiple (sometimes even hundreds) of file
systems, all mounted on top of each other.
There are only a few directories in the root file systems that cannot be a separate file system:
▪/root
▪/bin
▪/lib
▪/sbin
▪/etc
▪/dev
All other directories are candidates to become a separate file system. To determine which scheme
is useful, you need to attend the System Administration class.
Uempty
/dev/hda2
/
/usr /var /tmp
/dev/hda5
/
/bin /lib /sbin
Working with files and directories © Copyright IBM Corporation 2001, 2018
The mount command is used to mount a file system on a mount point. It can best be compared to
attaching a branch to a tree. After a file system (a disk partition, a CD-ROM device or a floppy disk,
for instance) has been mounted, it has become part of the unified file system and can be accessed.
The syntax of the mount command is:
mount [-t type] [-o options] device mountpoint
The type specifies the file system type, for example ext2, vfat or iso9660. The options might
indicate read-only, for instance. The device identifies the device name, which contains the file
system to be mounted. The mount point identifies the (empty) directory where the file system
should be mounted.
As an example, suppose you want to mount the /dev/hda5 partition on the /usr mountpoint. The
command to use then becomes:
mount /dev/hda5 /usr
Uempty
# umount /dev/hda5
- OR -
# umount /usr
Working with files and directories © Copyright IBM Corporation 2001, 2018
Unmounting a file system is done with the umount command. This command needs only one
argument, which is either the device name or the mount point of the file system to be unmounted.
Unmounting a file system can only be done if the file system is no longer in use. A file system is in
use when one of the following three conditions is true:
• A user currently has a file opened on the file system.
• A user is currently running a program from that file system.
• A user uses a directory on that file system as its current working directory.
Uempty
# cat /etc/fstab
/dev/hda1 /mnt/winC vfat defaults 0 0
/dev/hda2 / ext3 defaults 1 1
/dev/hda5 /usr ext3 defaults 1 2
/dev/hda6 /var ext3 defaults 1 2
/dev/cdrom /media/cdrom iso9660 noauto,owner,ro 0 0
/dev/fd0 /media/floppy auto noauto,owner 0 0
none /proc proc defaults 0 0
none /dev/pts devpts gid=5,mode=620 0 0
Note: Current distributions transitioning to file system labels instead of device names!
Working with files and directories © Copyright IBM Corporation 2001, 2018
The /etc/fstab file lists all known file systems on the system. On a large server, this might add up
to dozens of file systems, each with their own mountpoint and special options. We're not going to
cover the file in great depth, but you need to be aware of it at least. The file lists every file system
known to the system on a single line, where each line consists of six columns:
• The first column identifies the device name.
• The second column identifies the mount point.
• The third column identifies the file system type.
• The fourth column identifies the options.
• The fifth column is a parameter for the dump program.
• The sixth column is a parameter for the fsck program.
All file systems listed in this file will be mounted automatically at the corresponding mountpoint
when the system boots, except for the file systems which have the noauto option. As you can see
in the visual, this applies to /mnt/cdrom and /mnt/floppy.
Uempty
Working with files and directories © Copyright IBM Corporation 2001, 2018
As you have seen in other visuals, both the floppy and CD-ROM can be predefined in the /etc/fstab
file, but have the noauto option set, so they’re not automatically mounted when the system boots.
These entries are nevertheless useful, because the mount command uses this file to complete the
information about a file system if only a partial mount command is given: The only command
needed to mount a CD-ROM is:
mount /media/cdrom
which, based on the /etc/fstab file, will be expanded by the mount command to
mount -t iso9660 -o owner,ro /dev/cdrom /media/cdrom
The owner option by the way allows a regular user to perform the mount command. When this
option is set, you don't need to be root on the system to mount that particular device at that
particular mountpoint. It’s enough to be logged in on the console.
Uempty
$ ln FileA FileB
$ ls –il FileA FileB
8986669 –rw-r—r-- 2 test test 200 2010-04-22 15:15 FileA
8986669 –rw-r-r-- 2 test test 200 2010-04-22 15:15 FileB
$ ln –s FileB FileC
$ ls –il FileB FileC
8986669 –rw-r-r-– 2 test test 200 2010-04-22 15:15 FileB
8986670 lrwxrwrwx 1 test test 5 2010-04-22 15:16 FileC -> FileB
Working with files and directories © Copyright IBM Corporation 2001, 2018
Linux has a few helpful tools that allow files to reference other files. This is useful for shortcuts,
organization, and so on. These tools are called file linking. There are two types of file links: hard link
and soft or symbolic links.
Hard links: Hard links create a new file entry that actually points to an existing inode, (of an
existing file). The new file can have a different name, but it will share an inode and inode number
with the existing file. This means it is essentially the same file, but with maybe a different name and
location. The actual file data is not removed from the system until all references to it are removed
as well.
Symbolic links: Soft or symbolic links allows you to create a new small file, this time with its own
inode and inode number that contains the name and path of another file the system knows about.
The new file becomes a link or shortcut to the existing file.
Hard links cannot be used to link to a directory and cannot be linked across file systems. Symbolic
links can link to directories and to file across other file systems. Symbolic links, however, become
useless when their target file is deleted.
Links are created using the ln command.
Hard links use the syntax: Symbolic links use the syntax:
ln targetFile linkedFile ln –s targetFile symLinkFile
Uempty
Keywords
• File
• File system
• Directory
• Physical device
• Commands
ƒ pwd
ƒ cd
ƒ mkdir
ƒ rmdir
ƒ cp
ƒ mv
ƒ rm
ƒ more
ƒ less
ƒ mount
ƒ unmount
Working with files and directories © Copyright IBM Corporation 2001, 2018
These keywords are provided as a reminder of key subjects discussed in this unit.
Uempty
Unit summary
• Describe the different file types
• Describe file and path names
• Create, delete, copy, move, and list directories
• Create, delete, copy, and move files
• View the content of both text and binary files
Working with files and directories © Copyright IBM Corporation 2001, 2018
Uempty
Review questions
1. True or false: Linux imposes an internal structure on a
regular file (not a directory or special file).
Working with files and directories © Copyright IBM Corporation 2001, 2018
Uempty
Review answers
1. True or false: Linux imposes an internal structure on a
regular file (not a directory or special file).
The answer is false.
Working with files and directories © Copyright IBM Corporation 2001, 2018
Uempty
Working with files and directories © Copyright IBM Corporation 2001, 2018
Uempty
Exercise introduction
• Work with directories
• Work with files
• Work with files and directories recursively
• Work with binary files
Working with files and directories © Copyright IBM Corporation 2001, 2018
Uempty
Overview
This unit describes how permissions are used, lists permissions required to perform common
commands, demonstrates how to change permissions using symbolic and octal notation, and
explains how default permissions are calculated.
Uempty
Unit objectives
• Describe how permissions are used
• List the permissions required to perform several common commands
• Change permissions using symbolic and octal notation
• Describe how default permissions are calculated
Uempty
richard
tux1
alan
tux2 linus
X
• Each file has an owner
/groups/penguins/herring.txt • Each file is assigned to a group
File and directory permissions © Copyright IBM Corporation 2001, 2018
To protect your files from other users, Linux allows you to set permissions on files and directories.
As an example, you might want to protect your own files from all other users on the system, or
make sure that certain system files can only be read by users, and not written to.
Permissions also work on a group level, allowing you to create files that are accessible only to
users that are members of a particular group, while members of other groups would not have
access.
Uempty
Permissions
• File permissions are assigned to:
ƒ The owner of a file
ƒ The members of the group the file is assigned to
ƒ All other users
• Permissions can only be changed by the owner and root!
Permissions under Linux are configured for each file and directory. There are three levels of
permissions:
1. The permissions that apply to the owner of the file. The owner of a file is by default the user that
created the file.
2. The permissions that apply to all members of the group that is associated with the file.
3. The permissions that apply to all other users on the system.
Permissions can only be changed by the file owner and root.
Uempty
To view the permissions that are currently applied to a file, use the ls -l command. Note that,
when viewing the permissions on a directory, you cannot use the command ls -l
<directoryname> because that command lists the contents of the directory and not the directory
itself. Instead, use the command ls -ld <directoryname>.
Some distributions, including Red Hat, have “access control lists” (ACLs) enabled. This allows
more extended permission groups than just user/group/others. If the ACL functionality is enabled in
your distribution, all permission bits will be followed by either a “.” (dot) or a “+” (plus). A dot means
that this particular file/directory does not have any additional access controls, while a plus means
that it has. You can then view the additional access controls with the getfacl command. ACLs will
be covered at the end of this unit.
Uempty
Permissions notation
r Read
rwxrwxrwx w Write
owner group other x Execute
Regular files
r File is readable
w File is writeable
x File is executable (if in an executable format)
Directories
r Contents of directory can be listed (ls)
w Contents can be modified (add/delete files)
x Change into directory is possible (cd)
File and directory permissions © Copyright IBM Corporation 2001, 2018
Uempty
Required permissions
cd x N/A N/A
ls x, r N/A N/A
mkdir, rmdir x, w N/A N/A
cat, less x r N/A
cp x r x, w
cp –r x, r r x, w
mv x, w None x, w
vi x, r r, w N/A
rm x, w None N/A
The visual shows the permissions that are required for certain common Linux commands. Note that
you do not need write permissions on a file for moving or removing that file. This sounds strange at
first, but is easily explained: the name of a file is actually stored in a directory. So if you have write
permissions on a directory, you can change the name of all files in that directory, or remove files
from that directory.
Uempty
$ ls -ld /home/tux1
drwx------ 4 tux1 penguins 1024 Jan 5 12:43 /home/tux1
You can see who the owner is by looking at the output of the ls -l command. The third column
lists the owner's name. If you are working as the listed user (or root) you are allowed to change
permissions on the listed file (or directory).
Uempty
Changing permissions (1 of 2)
• To change the permission of a file use the chmod command
• Syntax: chmod <MODE> <FILE[S]>
• Mode can be symbolic
$ chmod go-rx /home/tux1
$ ls -ld /home/tux1
drwx------ 4 tux1 penguins 1024 Jan 5 12:43 /home/tux1
Changing permissions is done with the chmod command. This command supports two different
ways of writing down the required permissions: symbolic and octal. Symbolic notation describes the
permissions using the following syntax:
chmod <who operator what> <filename(s)>
<who> can be:
• u for the owner (user) of the file
• g for the group assigned to the file
• o for all other users
• a for all (owner+group+others)
<operator> can be:
• A plus sign (+) to add permissions
• A minus sign (-) to delete permissions
• An equals sign (=) to clear all permissions and set to the permissions specified
<what> can be any combination of r, w, and x.
Legal commands are, for instance:
Uempty
• chmod u=rw,go=r <file> gives the user read-write permissions and gives read
permissions to the group and others. All previous permissions are discarded.
• chmod a+x gives everybody execute permissions in additions to the permissions they already
had.
With octal notation, permissions are identified with an octal number.
Uempty
Changing permissions (2 of 2)
mode is 750
The visual shows how octal numbers are calculated. Octal permissions might seem incredibly
complex when compared to symbolic notation; however, in actual practice there are only a few
permission combinations that make sense.
When applying these permissions, experienced Linux users do not have to think about them
anymore, but apply them blindly. These combinations are:
• 600 (rw-------): For private files
• 700 (rwx------): For private programs and directories
• 644 (rw-r--r--): For files that you want to be readable by others
• 755 (rwxr-xr-x): For programs and directories you want to be readable/executable by others
• 666 (rw-rw-rw-): For public writable files (does not happen often)
• 777 (rwxrwxrwx): For public writable directories, such as /tmp
Uempty
umask
• New files should not be created with 666! To avoid this problem, a
permission mask exists
Regular files:
Default permissions rw-rw-rw 666
umask (-) ----w--w- 022
Directories:
Default permissions rwxrwxrwx 777
umask (-) ----w--w- 022
Resulting permissions rwxr-xr-x 755
It is obviously important to know with what permissions new files and directories are created. Under
Linux, it is not really easy to tell, since the default permissions can be modified by setting a umask
(with the umask command).
If no umask were set (which never happens, by the way), a file would always be created with
permissions 666 (rw-rw-rw-) and a directory would get 777 (rwxrwxrwx). In actual practice,
however, a umask is set, and this number is subtracted from these permissions.
Therefore, with a umask of 022, the default permissions for a file becomes 644 (rw-r--r--,
666-022) and the default permissions for a directory becomes 755 (rwx-r-xr-x, 777-022). The
default umask depends on your distribution, and whether your distribution uses something called
User Private Groups.
• Red Hat assigns a umask of 002 to regular users and 022 to root.
• SUSE assigns a umask of 022 to all users, including root.
User Private Groups and the reasons for the different umasks are beyond the scope of this course.
They are covered in the LX03 course.
Uempty
At some systems you might also be confronted with access control lists (ACLs). ACLs are a way of
assigning permissions to more groups than just one user, one group and others. With ACLs, you
can assign different permissions to multiple users and multiple groups.
Setting ACLs is done with the setfacl command, while displaying ACLs is done with the getfacl
command. In addition to this, tools such as ls have been modified to work with ACLs. On an
ACL-enabled system (such as Red Hat 6), the output of ls will look like this:
$ ls -l
drwxr-xr-x. 2 tux tux 4096 Dec 14 12:45 Desktop
-rw-rw-r--+ 1 tux tux 12 Dec 14 15:28 ourdocument
The “.” (dot) after the permissions on the Desktop directory signify that there are no further ACLs
associated with this directory (other than the default permissions/ACLs).
Uempty
The “+” (plus) after the permissions on the ourdocument file mean that there are further ACLs
assigned to this file. To view these ACLs, use getfacl:
$ getfacl ourdocument
# file: ourdocument
# owner: tux
# group: tux
user::rw-
user:tux2:rw-
group::rw-
mask::rw-
other::r--
As ACLs are typically not used by regular users, coverage of them is outside the scope of this
course.
Uempty
You can also view and edit file permissions using the GUI interface; however, the method might
vary depending on the desktop environment. Typically, you would right-click on a file and choose
Properties from the menu to bring up a window of properties; then click on the Permissions tab.
Uempty
Keywords
• Permissions
• Masking
• Authorization
• ACL
• Commands
ƒ umask
ƒ chmod
These keywords are provided as a reminder of key subjects discussed in this unit.
Uempty
Unit summary
• Describe how permissions are used
• List the permissions required to perform several common commands
• Change permissions using symbolic and octal notation
• Describe how default permissions are calculated
Uempty
Review questions
Can tux2 (who is also a member of the penguins group) successfully execute the
following commands?
1. cd /groups/penguins
2. mkdir /groups/penguins/mydir
3. cp /groups/penguins/task.c ~/task.c
4. vi /groups/penguins/zip.c
5. vi /groups/penguins/newfile.c
6. rm /groups/penguins/hello.c
$ pwd
/groups/
$ ls -l
drwxrwxr-x 2 root penguins 1024 Jan 1 10:03 penguins
$ ls -l penguins
-rw-r--r-- 1 tux1 penguins 544 Jan 1 10:15 hello.c
-rw-r--r-- 1 tux1 penguins 544 Jan 1 10:15 task.c
-rw-r--r-- 1 tux1 penguins 544 Jan 1 10:15 zip.c
Uempty
Review answers
Can tux2 (who is also a member of the penguins group) successfully execute the following
commands?
1. cd /groups/penguins
The answer is yes.
2. mkdir /groups/penguins/mydir
The answer is yes.
3. cp /groups/penguins/task.c ~/task.c
The answer is yes.
4. vi /groups/penguins/zip.c
The answer is no.
5. vi /groups/penguins/newfile.c
The answer is yes.
6. rm /groups/penguins/hello.c
The answer is yes.
$ pwd
/groups/
$ ls -l
drwxrwxr-x 2 root penguins 1024 Jan 1 10:03 penguins
$ ls -l penguins
-rw-r--r-- 1 tux1 penguins 544 Jan 1 10:15 hello.c
-rw-r--r-- 1 tux1 penguins 544 Jan 1 10:15 task.c
-rw-r--r-- 1 tux1 penguins 544 Jan 1 10:15 zip.c
Uempty
Uempty
Exercise introduction
• Apply file and directory permissions
Uempty
Overview
This unit describes the use of the man and info commands and the HOWTO documentation. This
unit also explains the importance of the Internet for gathering information about Linux.
Uempty
Unit objectives
• Use the man command to view information about Linux commands
• Describe the use of info
• Describe the HOWTO documentation
• Explain the importance of the Internet for gathering information about
Linux
Uempty
The man command shows the manual page of the commands and subroutines given as an
argument to the man command. Most manual pages consist of the following:
• Name: The title and a one-line description of the command
• Synopsis: The syntax of the command
• Description: Many pages of information about the function and usage of the command
• Options: An explanation of the options
• Files: Any system files associated with the command
• Bugs: Any information about the behavior and performance of the command in unusual
circumstances
• See also: Other commands that are related to the same topic (viewing them can tell you more
about the working of this particular command)
You can search for a pattern in a manual page with the forward slash (/) key.
Uempty
$ man finger
FINGER(1) BSD General Commands Manual FINGER(1)
NAME
finger — user information lookup program
SYNOPSIS
finger [-lmsp] [user ...] [user@host ...]
DESCRIPTION
The finger displays information about the system
users.
Options are:
This is only the first screen of the manual page of the finger command. You can now use the less
commands (spacebar, b, q, and so forth) to browse the page.
Uempty
The man -k command shows the commands that have manual pages that contain any of the given
keywords in their title.
The apropos command can also be used and is equivalent to using the man -k command.
To allow the use of man -k and apropos, the superuser (root) must have run the
/usr/sbin/makewhatis command to create the /var/cache/man/whatis file. Typically, a
distribution or an administrator sets up a cron job so that this is done each night. This is covered in
the LX03 course.
Uempty
Manual pages are stored in nine different sections. The first eight of them are standard across
UNIX, and Section 9 is used for Linux kernel documentation. In some cases, a single subject might
appear in multiple sections. As an example, passwd is both a command and a file; so a man page
appears in two different sections. To retrieve a manual page from a specific section, specify the
section number as the first argument to man.
Uempty
Uempty
• S: Search for a string in the current node
• ?: Go to the help
• L: Leave the help and go back to the node
• Q: Quit info
• <tab>: Jump to the next cross reference
• F: Follow this cross reference (this brings you to another node)
• M: Pick menu item specified by name.
• <Ctrl-l>: Refresh screen
Cross references are indicated by an asterisk (*) on a line. With the Tab key, you can jump to this
cross reference. Pressing the f key makes info follow the cross reference and show you another
node.
Another way of moving through info is by specifying menu items. A node only contains a menu
when you see * Menu: in the text. Menu items are also indicated by a *. Again use the Tab key to
jump to a menu item. Then press the m key and info asks you what menu item you want to go to.
Just pressing Enter makes you follow the link for the currently selected menu item. You could also
enter another menu item, to follow its link.
The info command can be used to obtain the up-to-date information when a manual page starts
with a sentence such as: “This documentation is no longer being maintained and may be inaccurate
or incomplete. The Texinfo documentation is now the authoritative source.”
Uempty
pwd [OPTION]...
The program accepts the following options. Also see *note Common
options::.
`-L'
`--logical'
If the contents of the environment variable `PWD' provide an
absolute name of the current directory with no `.' or `..'
components, but possibly with symbolic links, then output those
--zz-Info: (coreutils.info.gz)pwd invocation, 38 lines --Top------------
The info command is invoked with an argument that is the command of which you want to view the
documentation. On the screen, you see the following:
• File: The file that contains the node you are looking at
• Node: The current node
• Next: The next node. You can use the n command to jump to this node
• Up: Besides a next node, a node can also have an up node. Use the u command to jump to the
up node.
The node you are viewing:
• Lines: The total number of lines for this node
• Position:
▪ ALL: You see all the lines of the node.
▪ TOP: You are at the top of the node.
▪ BOT: You are at the bottom of the node.
▪ 75%: You are at 75% of the node.
Uempty
As we already saw, the man and info commands can be used to obtain information about the
working of a command. This information is stored in a separate file in /usr/share/man or
/usr/share/info. Obviously, this manual page has to be installed.
Another way of getting help about a command is using the --help option of the command itself.
This option shows you a brief explanation of the synopsis of the command and the options that can
be used with the command. The information shown is part of the command itself, and does not
require the presence of a separate file.
The visual shows some lines of the help the who --help command would give you. The actual
output probably does not fit on your screen. To read the complete help, issue who --help | less,
which shows the output by page.
Note that not all commands support the --help option. Conveniently, for most commands that do
not support --help, invoking them with --help will produce an invalid parameter error message,
and the “usage” information will be printed anyway.
Uempty
HOWTO documents
• These are documents that describe in detail a certain aspect of
configuring or using Linux
• They include detailed information about how to perform a given task
ƒ DHCP support
ƒ Kernel compilation
ƒ Dual boot with other operating systems
• HOWTO documents are text files in /usr/share/doc/HOWTO
ƒ Need to be installed manually
• On the Internet:
ƒ http://www.tldp.org/index.html
Linux HOWTOs are documents that describe in detail a certain aspect of configuring or using Linux.
For example, there is the installation HOWTO, which gives instructions on installing Linux, and the
Mail HOWTO, which describes how to set up and configure mail under Linux. Other examples
include the NET-3 HOWTO and the Printing HOWTO. HOWTOs are comprehensive docs, much
like an FAQ but generally not in question-and-answer format; however, many HOWTOs contain an
FAQ section at the end. There are several HOWTO formats available: plain text, PostScript, DVI,
and HTML. In addition to the HOWTOs, there are a multitude of mini-HOWTOs on short, specific
subjects. They are only available in plain text and HTML format.
Uempty
HOWTO example
• Use the command zless to view compressed file
$ zless /usr/share/doc/HOWTO/en-txt/UPS-HOWTO.gz
UPS HOWTO
Nick Christenson
Revision History
Revision 2.2 2007-05-22 Revised by: esr
An Uninterruptible Power Supply (UPS) is an important thing to have if you
live in an area where power outages are at all common, especially if you
run a mail/DNS/Web server that must be up 24/7. This HOWTO will teach you
things you need to know to select a UPS intelligently and
/usr/share/doc/HOWTO/en-txt/UPS-HOWTO.gz
The example on the slide shows you the HOWTO on how to install and configure XFree86 on your
system.
XFree86 is the graphical environment of a Linux system.
The example on the visual does not show the complete HOWTO. You see only the first 12 of 792
lines.
Uempty
Other documentation
• Certain programs also offer other kinds of documentation
ƒ HTML
ƒ PDF
ƒ PostScript
ƒ Plain text
• These are usually stored in /usr/share/doc/<package_name>
When a programmer creates a program, the programmer usually includes the standard
documentation, such as manual or info pages or both, and implements the --help option. But most
programmers also write some non-standardized pieces of documentation. These are typically
README files, with up-to-date release information, or CHANGELOGS, which list the changes
since the previous versions. Other programmers might write large amounts of HTML- based
documentation, or Postscript-based installation instructions, and so forth.
A typical distribution leaves this documentation intact and stores it in
/usr/share/doc/<programname>.
In practice, the value of this documentation varies greatly. There are programmers who only use the
standardized tools (man, info) and as a consequence, /usr/share/doc/<programname> is virtually
empty. Other programmers have created a whole Web site about their program, consisting of more
than 20 HTML pages with supporting graphics, example configuration files, and so forth. So your
mileage might vary here.
Uempty
Internet
• All Linux documentation available on the Internet
• Google: http://www.google.com/linux
• Other sites:
ƒ www.tldp.org
ƒ www.linux.org
ƒ www.redhat.com
ƒ www.novell.com/linux
ƒ www.fedoraproject.org
ƒ www.kernel.org
ƒ www.lwn.net
ƒ www.ibm.com/developerworks/linux
ƒ Many more
All information about Linux can also be found on the Internet. There are scores of Web pages on
Linux. For more personal and up-to-date help, you can also go to Usenet news and other forums.
Uempty
Keywords
• Documentation
• man pages
• HOWTO
• Commands
ƒ man
ƒ info
ƒ apropos
ƒ zless
These keywords are provided as a reminder of key subjects discussed in this unit.
Uempty
Unit summary
• Use the man command to view information about Linux commands
• Describe the use of info
• Describe the HOWTO documentation
• Explain the importance of the Internet for gathering information about
Linux
Uempty
Review questions
1. True or false: A HOWTO document is the best source of
documentation if you want up-to-date information about a
specific command.
Uempty
Review answers
1. True or false: A HOWTO document is the best source of
documentation if you want up-to-date information about a
specific command.
The answer is false.
Uempty
Exercise: Linux
documentation
Uempty
Exercise introduction
• Use the man command
• Use the info command
• Locate and use other Linux documentation
Uempty
Overview
This unit shows how to use the file command to determine the type of file, illustrates how to edit text
files with vi, and discusses other text file editors as well as ways that non-text files can be edited.
Uempty
Unit objectives
• Determine the type of file using file
• Edit text files with vi
• Discuss other text file editors, such as KEDIT
• Discuss the ways non-text files can be edited
Uempty
When we are editing a file, we are changing the content of the file. For this, we need an editor.
Since Linux does not impose any structure on the contents of the file, there is no editor under Linux
which can edit any file available. Different files need to be edited using different editors.
To determine the file type, the file program is used. This program reads the first few bytes of the
file and compares it to a database of known file types. If there is a match, then the type of the file is
displayed.
If the file turns out to be a text file, then you can edit this file with a text editor. On a typical Linux
system, there's usually a large assortment of text editors available, including vi, kedit, emacs and
so forth. Non-text files usually need to be edited through the application that created them, or with a
so-called “hex-editor”, an editor which displays the file in hexadecimal format and thus is able to
display and modify non-printable characters.
Most configuration files on a Linux system are text files. This makes it possible to perform most
system administration tasks with just a simple text editor.
Uempty
vi, which officially stands for visual interpreter, is the most commonly available editor in all UNIX
operating systems. The reason for this is that it was the first, and for a long time only editor which
was capable of editing a file in full-screen mode. Before vi, all editors were line-based: they could
only display and edit one line at a time.
Considering today’s standards, vi is relatively hard to learn. Editors like KEDIT for example have a
graphical interface and are therefore much easier to use for novices. But if you need to do system
management on a remote system, connected by using a slow network or modem connection,
KEDIT is not an option.
The same goes for emergency situations. When a system crashes and won't boot in the normal
fashion anymore, you need to fall back to some sort of rescue mode. This rescue mode is usually
started from CD-ROM or over the network, and makes only the minimum amount of tools available
to get the system up and running again. In such a rescue mode, the only full-screen editor available
is usually vi.
The last reason for learning vi is that certain programs (such as mail and news readers) use an
external editor if the user needs to type more than a few words (the body of your e-mail message
for instance). In all but a few cases, the external editor called is vi. So it is important to learn vi, at
least enough to make simple changes to text files. That doesn't mean that vi has to be your
preferred editor, and that you need to learn all features.
Uempty
If that's what you want, that's fine. But if you prefer KEDIT or Emacs (to name two ends of the
spectrum) for your daily work, that's fine too.
When executing the vi command in Linux, in most distributions, the program actually started is vim
(vi Improved). vim is downwards compatible with vi, but offers a large number of advantages and
improvements over traditional vi. The visual lists some of them.
For a complete list, start vi (or vim) and execute the command :help vi_diff.txt.
Uempty
vi modes
• vi knows three modes of operation
ƒ Command mode (for simple, one-letter commands)
ƒ Edit mode (insert text)
ƒ ex mode (for complicated commands)
• You can easily change between modes
Command mode Edit mode
ex mode
The apparent complexity of vi is largely due to the concept of different modes that vi uses, and that
you constantly need to change between them.
The first mode that you need to know about is the command mode. When vi is in this mode, you
can type simple, one-letter commands that do specific things. There are as many commands as
there are letters in the alphabet, where the lowercase and uppercase letter (and sometimes the
control-sequence too) have a different meaning.
The second mode is the edit mode. This mode allows you to enter characters that show up in the
file.
The third mode is the ex mode. The ex line editor was the direct predecessor of vi. It was really
powerful, but did not have full-screen capabilities. Most of the powerful ex commands have been
integrated in vi, as the ex mode.
Uempty
Starting vi
• From command line, use vi command
$ vi myfile.txt
~
~
~
~
~
~
~
~
~
~
~
~
~
~
~
"myfile.txt" [New File]0,0-1 All
vi does editing in a buffer. When a session is initiated, one of two things happen:
• If the file to be edited exists, a copy of the file is put into a buffer in /tmp by default.
• If the file does not exist, an empty buffer is opened for this session.
Tildes (~) represent empty lines that are not part of the file you are editing. The editor starts in
command mode.
Uempty
Left-arrow Right-arrow
h l
0 $
b w
Down-arrow
j
<Ctrl-f>
G
L
A number can be entered before many commands to cause vi to repeat the command.
For example, 10j to move down 10 lines or 23G to go to line 23
Editing files © Copyright IBM Corporation 2001, 2018
To move about in your file, make sure you are in command mode.
• <left arrow> or h: One character left
• <right arrow> or l: One character right
• B or b: One word left
• W or w: One word right
• ^: Move to beginning of line
• $: Move to end of line
• (): One sentence left or right
• {}: One paragraph left or right
• <up-arrow> or k: One line up
• <down-arrow> or j: One line down
• 1G: Go to the first line of the file
• G: Go to the last line of the file
• <ctrl-u> or <ctrl-d>: One half-page up or down
Uempty
• <ctrl-b> or <ctrl-f>: One page back or forward
Uempty
Command mode
Uempty
IiAa
Command mode Edit mode
ESC
There are a number of ways to get from command mode to edit mode:
• I (capital I): Insert text at beginning of current line.
• i: Insert text before current cursor position.
• a: Append text after current cursor position.
• A: Append text at end of line.
To exit the edit mode, press the Esc key.
Uempty
After starting vi, you are in the command mode. If you want to type some text, you have to change
to the edit mode of vi.
To enter edit mode, enter the i command. This places you in edit mode. Look at the last line in vi
because it should state now that you are in edit mode (it shows “-- INSERT --”).
To exit from input mode, press the <esc> key. The bottom line should no longer show “-- INSERT
--”.
Uempty
Uempty
vi can also search for patterns. This is done with the / (slash) command. To repeat a previous
search, use the n command.
Uempty
Replacing patterns
• Advanced search and replace can be done in ex mode
• To replace old text with new text use the following command:
:1,$s /old/new/g
This file contains some lines.
Line 2.
And that for example is line 3.
Line 4 follows line 3.
The last line is line 5.
~
~
~
~
~
~
: 1,$s/this/that/g
Editing files © Copyright IBM Corporation 2001, 2018
Advanced search and replace functions are available in ex mode. The command :%1,$s
/old/new/g for instance replaces all occurrences of the word old with new.
Let’s break down this command a little:
• The colon (:) switches to ex mode.
• 1,$ means that our command is going to apply to all lines, starting with line 1 and ending with
the last line of the file. You could also specify 1,5 to limit your search to lines 1 through 5,
inclusive. Other possibilities are .,$, for the current line through to the end, or %, which also
means the whole file.
• s means that you are going to execute a search and replace. There are a lot of other
possibilities here, but d is perhaps the most common: it allows you to delete lines.
• The first slash (/) is the start delimiter of the search phrase. The second slash (/) is the end
delimiter of the search phrase, and the start of the replacing phrase. The third / is the end
delimiter of the replacing phrase.
You are free to choose your delimiter character, but / is the most common. If your delimiter
character happens to be part of the search or replace phrase, pick a delimiter character which is
not (usually a colon (:) is used instead), or make sure you escape the delimiter character with a
backslash.
Uempty
• The g means a global replace. Normally only the first occurrence of the search phrase on a
particular line is replaced.
There are far more possible commands in ex mode. See the manual page of vi.
Uempty
The dd and yy commands allow you to cut and copy a single line into a buffer. The p command
then retrieves the buffer contents and adds it after the current line.
To cut or copy multiple lines at once, precede the command by the number of lines you want to cut
or copy.
Uempty
The dd and the p commands are used to move (a number of) lines. Use the proper keys (that is, H,
J, K or I) to go to the line you want to move. Now give the dd command. This removes the line you
were in and place it in a buffer.
Use the move keys again to go to the place where you want the line to reappear. Use the p
command if you want the line to reappear under the line where the cursor is in. Use the P command
if you want the line to reappear above the line the cursor is in.
You can also delete a couple of lines with the dd command. To delete 12 lines, enter 12dd. The u
command can undo your last command if you make an error. If you delete something in error,
immediately type the u command to retrieve it.
Uempty
To copy and paste text, you can use the same steps you used with cut and paste. The only
difference is the yy command instead of the dd command.
Uempty
vi options
• Options entered in ex mode change the behavior of the vi editor
ƒ :set all
ƒ :set autoindent/noautoindent
ƒ :set number/nonumber
ƒ :set list/nolist
ƒ :set showmode/noshowmode
ƒ :set tabstop=x
ƒ :set ignorecase/noignorecase
ƒ :set wrapmargin=x
ƒ :set hlsearch/nohlsearch
ƒ :syntax on/off
ƒ :set fileformat=dos/unix
• To make an option available to all vi sessions, put it into a .exrc or
.vimrc file in your home directory
vi has many settings for operation. Some of these affect the way text is presented, while others
make editing easier for novice users.
• :set all: Display all settings
• :set autoindent: Sets autoindent on
• :set ai: idem
• :set noai: Turns autoindent off
• :set number: Enables line numbers
• :set nu: idem
• :set nonu: Turn line numbers off
• :set list: Display non-printable characters
• :set nolist: Hide non-printable characters
• :set showmode: Show the current mode of operation (default on)
• :set noshowmode: Hide the mode of operation
• :set tabstop=4: Set tab to 4 character jumps
Uempty
• :set ts=4: idem
Beware of tab stop settings. They apply only to your local display.
What is inserted in the file is actually the tab character itself, which is
expanded to spaces whenever the file is read. The number of spaces
depend on the terminal settings at that moment, not at the terminal
settings from the time the file was created.
• :set ignorecase: Ignore case-sensitive
• :set ic: idem
• :set noic: Case-sensitive
• :set wrapmargin=5: Set the margin for automatic word wrapping from one line to the next.
• :set wrapmargin=0: Turn off word wrapping
• :set hlsearch: Set highlighting of search results on
• :set nohlsearch: Set highlighting of search results off
• :syntax on/off: Set syntax highlighting on/off
• :set fileformat=dos: Set MS-DOS style line endings (CR/LF)
• :set fileformat=unix: Set UNIX style line endings (LF)
You might want to create a .exrc or .vimrc file in your home directory containing these commands
(without the leading colon). The settings in this file are then read and applied when starting vi (or
vim).
Uempty
Exiting vi
• To save in ex mode
ƒ :w
• To forcefully save file in ex mode
ƒ :w!
• To quit without saving in ex mode
ƒ :q
• To forcefully exit in ex mode (without saving changes)
ƒ :q!
• To save and exit in ex mode (recommended)
ƒ :wq
• To save and exit in ex mode, shorter
ƒ :x
• To save and exit in command mode
ƒ ZZ
There are a number of ways to exit vi, both in command mode and ex mode.
The :w! command is useful if you are editing a read-only file but want to write it nevertheless. vi
then tries to remove the read-only attribute, write the file, and set the read-only attribute again.
Obviously, if vi cannot remove the read-only attribute (because the user is not the owner, for
instance), vi reports an error.
The :q! command is useful if you want to exit vi without saving your changes.
Uempty
vi cheat sheet
Command mode Edit mode
To edit mode
I i a A Can now type
Cut, copy, paste line Join lines Cursor move
text. Note: In
dd yy p J 1G Vim arrow keys,
Delete char, word Search, repeat k Del, Backspace
x X dw / n ^ h l $ will work.
You can use this page as a quick reference for some of the most used commands in vi. There are
many cheat sheets or helper pages on the Web. Do a Google-Linux search for vi and cheat sheet
and use the one you like.
Uempty
Other editors
• A typical Linux distribution comes with a large number of editors
• Text mode editors:
ƒ Pico (really simple), Joe
ƒ Original vi
ƒ emacs (even more powerful and complicated than vi)
• Graphical mode editors:
ƒ KVim, KEDIT, KWrite
ƒ gVim, gedit
• Hex editors allow you to change non-text files if you know the internal
structure
ƒ KHexEdit
ƒ emacs (in hex-mode)
If you do not want to use vi, or cannot use vi on the file you want to edit, there are usually more
editors available. The visual just shows a shortlist. If you do not like any of the editors that are
available, you are free to write your own (that is the main reason that there are so many editors
around in the first place!)
Uempty
Keywords
• editor
• file type
• config file
• hex editor
• command mode
• edit mode
These keywords are provided as a reminder of key subjects discussed in this unit.
Uempty
Unit summary
• Determine the type of file using file
• Edit text files with vi
• Discuss other text file editors, such as KEDIT
• Discuss the ways non-text files can be edited
Uempty
Review questions
1. True or false: You need to learn vi because vi is the best
editor for any job.
Uempty
Review answers
1. True or false: You need to learn vi because vi is the best editor for any
job.
The answer is false. vi is just the most common editor available on Unix-
style systems and is thus more likely to be there when you need to edit
a file. Indeed, it might be the only editor available. Having vi skills can
be quite handy on unfamiliar UNIX-style systems.
Uempty
Uempty
Exercise introduction
• Use vi to create and edit files
• List a few other editors that are available on your system
Uempty
Overview
This unit describes the function of the shell, metacharacters and reserved words, the use of
wildcards, using redirection and pipes, using command substitution, common filters, grouping
commands, working with shell variables, using aliases, and applying quoting.
Uempty
Unit objectives
• Explain the function of the shell
• Discuss metacharacters and reserved words
• Use wildcards to access files with similar names
• Use redirection and pipes
• Use command substitution
• Describe and use the most common filters
• Group commands to control their execution
• Work with shell variables
• Use aliases
• Apply quoting
Uempty
7.1. Shell operations
Uempty
Shell operations
Uempty
Topics
• Shell operations
• Shell variables
Uempty
The shell
• The shell is the command line user interface to Linux
Command interpreter
Can be configured
Available shells:
bash
ksh
csh The shell
The shell is a special program in any UNIX operating system, including Linux, because it allows the
user to interact with the operating system.
It does this by allowing the user to type a command and subsequently interprets and executes this
command. The shell also has a number of commands and control structures built-in, which allow it
to be used as a comprehensive programming language.
A huge number of shells have been written by various people since the first shell, simply called sh
was released. A lot of these shells are also available for Linux.
In most distributions the default shell is bash, which stands for Bourne Again Shell.
Tcsh is another fairly popular shell, which is similar, but also has many syntactic differences. It will
not be covered.
Uempty
Shell features
• When the user types a command, various things are done by the
shell before the command is actually executed
ƒ Wildcard expansion * ? [ ]
ƒ Input/output redirection < > >> 2>
ƒ Command grouping { com1 ; com2; }
ƒ Line continuation \
ƒ Shell variable expansion $var
ƒ Alias expansion dir -> ls -l
ƒ Shell scripting #!/bin/bash
As said, the shell allows you to type your command, after which it interprets it and executes the
corresponding program. However, before it executes the program it performs certain
transformations on the command you just entered. If you know what these transformations are, and
how to use them, it makes your life much simpler.
Some of these transformations are listed in the visual. We cover them in this unit. But these are not
the only things that the shell can do. Just like when we talked about vi, we are only going to scratch
the surface here.
Uempty
For the shell to make a distinction between the actual command and the actual parameters that you
typed, and the hints you want to give to the shell to let it do something, there has to be some sort of
agreement on what the shell can touch in your command and what not. As part of this agreement, a
number of metacharacters and reserved words have been defined.
Metacharacters are individual characters that have a special meaning to the shell. They can appear
anywhere in your command and are always handled by the shell itself, before the command is
executed. Reserved words are words that the shell interprets as special commands. They only
have a special meaning if they appear as a single word, surrounded by whitespace* . Function for
instance is a reserved word, but functions is not.
Note
* Whitespace is the beginning of the line, one or more spaces or tabs, or the end of the line.
You should never name your file or program after a reserved word, nor should your file names ever
contain a reserved character. (Technically, it is possible, but it only gets you or somebody else in
trouble later, when you or they need to work with the file by name and have trouble typing it.)
Uempty
One of the first things the shell does after it has read your command is to try to perform wildcard
expansion. This means that it starts looking in your command for words that contain (or solely
consist of) one or more wildcards. It then looks in the filesystem to see if it can expand that word to
one or more file names that match the pattern.
The most often used wildcards are the asterisk (*) and question mark (?). The asterisk (*) matches
zero or more arbitrary characters. The question mark (?) matches exactly one arbitrary character.
Note that file names that start with a dot (.) are considered “hidden” by the shell and are not
included in wildcard expansion unless a dot is explicitly included in the expression, like “.*” And
don’t just blindly try .* either, since that also matches ., the current directory, and .., the higher-level
directory. So if you execute rm -fr /tmp/.*, you are wiping out your whole system and not just the
contents of /tmp.
Wildcard expansion is done for each and every command that is entered by the user, even if the
program that started does not accept any filenames as parameters at all! As an example, the
command userdel * is entirely legal, but does not delete all user accounts on your system. What
does the command userdel * attempt to do?
Uempty
$ ls ne[stw]
net new
/
$ ls *[1-5]
home
test1 test1.2 test1.3
tux1
$ ls [!tn]*
few myfile test1
test1.2
test1.3
$ ls ?[!y]*[2-5] myfile
ne
test1.2 test1.3 new
nest
net
few
.w
.et
At certain times, the question mark (?) and asterisk (*) wildcards give a match that is too broad. You
might for instance only want filenames that start with the letters a or b. In that case, inclusive lists
can be used. An inclusive list is defined with square brackets ([ and ]), which contain the letters to
match. The dash sign can be used to specify a range, and the exclamation mark can be used to
invert the list (all characters match except the ones listed). See the visual for examples.
Uempty
command
standard error
Integer value Name Symbolic File stream stderr
0 Standard input STDIN_FILENO stdin (2)
1 Standard output STOUT_FILENO stdout
Three files are automatically opened for each process in the system. These files are referred to as
standard input, standard output, and standard error.
When an application works with a file, it opens the file using the path to the file, but once the file is
open the application uses a numerical identifier, called a file descriptor, to identify which file to read
from or write to. The numbers shown on the visual are the standard file descriptors for: stdin (0),
stdout (1), and stderr (2).
Standard input, sometimes abbreviated to stdin is where a command expects to find its input,
usually the keyboard.
Standard out (stdin) and standard error (stderr) are where the command expects to put its output,
usually the screen. These defaults can be changed using redirection.
A file descriptor number is what a program uses when it needs to identify a file which it will be read
from or writing to. The file descriptors will differ depending on the command or utility that is currently
running. Each Linux command opens its own set of file descriptors in order to keep track of the data
files, input, output, and error messages.
Remember that in Linux, not all file names refer to real data files. Some files might be special files
which, in reality, are a pointer to some of the devices on the system. An example would be
/dev/tty0.
Uempty
Input redirection
• Default standard input:
$ cat
Atlanta
Atlanta
Chicago
Chicago
<Ctrl-d>
The symbol < tells cat to take input from the file instead of the keyboard.
The file table for the redirection example looks like the following:
Descriptor 0 (standard input):
- default: keyboard
- for “cat < cities” command: “cities” file
Descriptor 1 (standard output):
- default: screen
- for “cat < cities” command: screen
Descriptor 2 (standard error):
- default: screen
- for “cat < cities” command: screen
Uempty
Output redirection
• Default standard output is stdout
$ ls
file1 file2 file3
Redirection allows standard output to go to somewhere other than the screen (default). In the
example, standard output has been redirected with > to go the file named ls.out.
The file descriptor table in this example holds the following values:
Descriptor 0 (standard input):
- default: keyboard
- for “cat < cities” command: keyboard
Descriptor 1 (standard output):
- default: screen
- for “cat < cities” command: file “ls.out”
Descriptor 2 (standard error):
- default: screen
- for “cat < cities” command: screen
Using ordinary redirection overwrites an existing file. To avoid this, use the >> (no space between
them) to append output to an existing file.
Uempty
Error redirection
• Default standard error is stderr
$ cat fileA
cat: fileA: No such file or directory
Standard error can be independently redirected, using 2>. There can be no space between the 2
and the >. The special file /dev/null is a bottomless pit where you can be redirect unwanted data.
All data sent there is just thrown away.
/dev/null has the unique property of always being empty. It is commonly referred to as the bit
bucket. The file descriptor table for the first error redirection example contains the following:
Descriptor 0 (standard input):
- default: keyboard
- when command runs: keyboard
Descriptor 1 (standard output):
- default: screen
- when command runs: screen
Descriptor 2 (standard error):
- default: screen
- when command runs: file “error.file”
Uempty
Combined redirection
• Combined redirects
$ cat < cities > cities.copy 2> error.file
$ cat >> cities.copy 2>> error.file < morecities
• Association
ƒ This redirects stderr to where stdout is redirected
With the association examples, the order in which redirections are specified is significant. In the first
example, file descriptor 1 is associated with the file specified, outfile. Then the example associates
descriptor 2 with the file associated with file description 1, outfile.
If the order of the redirection is reversed, the errors are redirected to the same place as standard
out. But standard out at this point has not been redirected yet, so the default value is used, which is
the screen. So, the error messages are redirected to the screen. Remember that the default error
messages are sent to the screen.
In bash, using the sequence &> is roughly identical to appending 2>&1:
$ cat >output 2>&1
Is equivalent to:
$ cat &>output
Uempty
Pipes
• A sequence of one or more commands separated by a vertical bar "|"
is called a pipe
• The standard output of each command becomes the standard input
of the next command
$ who | wc –l
4
$ wc -l tempfile
4 tempfile
Two or more commands can be separated by a pipe or vertical bar (|) on a single command line.
The requirement is that any command to the left of a pipe must send output to standard output. Any
command to the right of the pipe must take its input from standard input.
Note that everything ls sends to standard out can now be counted by wc.
Uempty
Filters
• A filter is a command that reads from standard in, transforms the
input in some way, and then writes to standard out
$ ls -l
total 0
drwxr-xr-x 2 team02 staff 256 Feb 19 16:58 dir1
-rw-r--r-- 1 team02 staff 0 Feb 19 16:58 file1
-rw-r--r-- 1 team02 staff 0 Feb 19 16:58 file2
$ ls -l | grep d*
drwxr-xr-x 2 team02 staff 256 Feb 19 16:58 dir1
$ ls -l | grep d* | wc -l
1
A command is referred to as a filter if it can read its input from standard input, alter it in some way,
and write its output to standard output. A filter can be used as an intermediate command between
pipes.
A filter is commonly used with a string of piped commands, as in the example above. The ls
command lists all the files in the current directory and then pipes this information to the grep
command. The output of grep is piped to the wc -l command. The result is that the command
counts the number of files in our current directory that contain .doc. In this example, the grep
command is acting as a filter.
Uempty
Common filters
Filter Description
grep: Only displays lines that match a pattern
sed: Allows string substitutions
awk: Pattern scanning and processing
fmt: Insert line wraps so that text looks pretty
expand, unexpand: Change tabs to spaces and vice versa
tr: Substitute characters
nl: Number lines
pr: Format for printer
sort: Sort the lines in the file
tac: Display lines in reverse order
Many programs can be used as a filter on an average UNIX system. The list in the visual shows the
more common ones.
expand expands all TAB characters to spaces, ensuring that everything is aligned properly. The
number of tab stops can be specified as a parameter. unexpand does exactly the opposite.
sed allows string substitutions. It works like the global editing facilities in vi, but doesn't edit a file.
Instead, it filters standard input to standard output, executing the specified substitutions on the go.
A short example: sed s/old/new/ < oldfile > newfile copies oldfile to newfile, changing all
occurrences of old to new.
awk is a pattern scanning and processing language. awk scans each line of text and applies the
necessary procedures to that line. A short example: awk { print $1 } < infile only prints the first field
of each line of infile to STDOUT.
sed and awk are really powerful commands -- so powerful that some people refer to them as
programming languages. O'Reilly has a book about them in case you're interested. They are also
covered in the AL32 (Linux Bash Programming) course.
fmt is a text formatter. It takes unformatted text and formats them so that it looks pretty, inserting for
instance line breaks, spaces and so forth where necessary.
Uempty
tr converts individual characters. Here's how you convert all uppercase characters to lowercase:
tr '[A-Z]' '[a-z]'.
grep scans individual lines for a pattern and only displays them if there is a match. It is very useful
for filtering specific things out of a large file.
nl numbers all lines.
pr formats your output for a printer, adding headers, footers, page numbers and page breaks in the
process.
sort sorts the lines in the file.
tac (inverse of cat) displays the lines in reverse order, last line first.
Uempty
Split outputs
• The tee command reads standard input and sends the data to both
a file and standard output
$ ls
dir1 file1 file2
$ ls | tee ls.save | wc -l
3
$ ls
dir1 file1 file2 ls.save
tee
ls wc -l 3
ls.save
dir1
file1
file2
The tee command can be used to capture a snapshot of information going through a pipe. tee puts
a copy of the data in a file as well as passing it to standard output to be used by the next command.
tee does not alter the data flowing through the pipe.
Uempty
Command substitution
• Command substitution allows you to use the output of a command as
arguments for another command
• Use backtick (`) or $(text) notation
$ rm -i `ls *.doc | grep tmp`
Command substitution allows you to use the output (STDOUT) of a command as arguments for
another command. One common use is where you have a command which delivers a series of file
names or user names, and need to use these file names or user names as arguments.
Two notations are possible: backticks (‘) and the $() notation.
Each example in the chart uses a different notation. They work as follows:
• The ls command generates a list of files which end in .doc in the current directory.
• The grep command filters the list of files, and only shows all lines (filenames) that contain the
word tmp.
• The resulting list is used as arguments to the rm command.
In short, the command listed removes all files with names ending in .doc, and containing the string
tmp.
The second example:
• The ps command generates a detailed list of processes running on the system, one per line.
• The wc -l command counts the lines (processes) from the output of the ps command
• The resulting output of the wc command is substituted in the string argument to the echo
command.
Uempty
Command grouping
• Multiple commands can be entered on the same line, separated by a
semicolon (;)
$ date ; pwd
Placing multiple commands separated by a semicolon (;) on a single line produces the same result
as entering each command on a separate command line. There is no relationship between the
commands, nor is any input or output redirection being done.
Commands can be grouped into one input/output stream by putting curly braces ({ and }) around
them. This combines their input/output streams into one.
You can also group commands into one input/output stream by putting round braces (( and ))
around them. In this case, the grouped commands are executed in a subshell.
Uempty
7.2. Shell variables
Uempty
Shell variables
Uempty
Topics
• Shell operations
• Shell variables
Uempty
Shell variables
• Variables represent data whose value might change
All shell variable names are case-sensitive. For example, HOME and home are not the same.
As a convention, uppercase names are used for the standard variables set by the system and
lowercase names are used for the variables set by the user.
In addition to the variables discussed above, there are other variables that the shell maintains
which will be discussed later.
Uempty
$ set
BASH=/bin/bash
BASHOPTS=checkwinsize:cmdhist:expand_aliases:extquote:force_fi
gnore:histappend:hostcomplete:interactive_comments:login_she
ll:progcomp:promptvars:sourcepath
BASH_ALIASES=()
. . .
TERM=xterm
UID=1000
USER=student
XDG_RUNTIME_DIR=/run/user/1000
XDG_SESSION_ID=3
_=set
colors=/home/student/.dircolors
$
The set command displays the names and values of all shell variables. The set command is a
built-in command of the shell, and therefore gives a different output depending on the shell being
run, for instance a Bourne or a Korn shell.
Uempty
Variables can hold any type of data, like integer numbers, single words, text strings or even
complex numbers.
It is up to the application referencing the variable to decide what to do with the contents of that
variable.
The contents of the system-defined variables is fairly static, for example, the HOME variable can
only contain a path to a directory file and not, for instance, a file.
To set a variable, use the = with no spaces on either side. Once the variable has been set, to refer
to the value of that variable precede the variable name with a $. There must be no space between
the $ and the variable name.
The echo command displays the string of text to standard out (by default to the screen).
Uempty
$ xy=day
$ echo $xy
day
There does not need be a space before the $ of the variable in order for the shell to do variable
substitution. Note what happened when there was no space after the variable name. The shell
searched for a variable whose name was xylong, which did not exist. When a variable that has not
been defined is referenced, the user does not get an error. Rather, a null string is returned.
To eliminate the need for a space after the variable name, the curly braces { } are used. Note that
the $ is outside of the braces.
Uempty
Command substitution
• Replace command content with pre-defined values
$ date
Thu Feb 22 15:59:25 PST 2018
$ now=$(date) or now=`date`
$ echo $now
Thu Feb 22 16:00:46 PST 2018
$ HOST=$(hostname) or HOST=`hostname`
$ echo $HOST
sys1
$ echo "Today is `date` and `who | wc -l` users are logged in"
Today is Thu Feb 22 16:01:20 PST 2018 and 1 users are logged
in
A variable can be set to the output of some command or group of commands by using the back
quotes. They should not be mistaken for single quotes. In the examples, the output of the date and
who commands are stored in variables.
The back quotes are supported by the Bourne shell, C shell and Korn shell. The use of
$(command) is specific to the Korn shell.
When the shell sees a command substitution string on a command line, it will execute the enclosed
command and will then substitute the entire command substitution string with the standard output of
that command. After completing the substitution(s), the shell will then execute the resulting line.
Uempty
Quoting metacharacters
• Single quotes: '
ƒ Ignores all metacharacters between the quotes
$ echo '$HOME'
$HOME
• Backslash: \
ƒ Ignores the special meaning of the following character
$ echo \$HOME
$HOME
Quoting is used to override the shell's interpretation of special characters. Quotes allow a
metacharacter to be interpreted literally instead of expanded.
You can use the backslash \ to stop the shell from interpreting one of the quoted characters.
For example:
$ echo "This is a double quote \""
This is a double quote "
Uempty
2. Command and
1. Redirection
variable substitution
>, >>, 2>, |
$var, $(cmd)
3. Wildcard expansion
4. Command Execution
*, ?, [ ]
When the shell parses a command line, it breaks the line into a series of words. One of these words
determines which command will execute. Other words are information passed to the commands
such as filenames and flags. Some of the words are instructions to the shell, like redirection.
The shell does a lot of things with a command line before the command ever gets to execute. The
order in which the shell reads and processes a command is done from left to right. In logical order,
the shell looks for redirection, command and variable substitution, then wildcard expansion. The
command is then executed.
.
Uempty
Aliasing
• The alias command allows you to set up aliases for often-used
commands
• For example:
$ alias ll='ls -l'
$ alias rm='rm -i'
To show all currently defined aliases:
$ alias
To delete an alias:
$ unalias ll
$ ll
bash: ll: command not found
The shell also supports aliases. An alias is typically a short letter combination which expands into a
far larger command. By making this large command an alias, you save yourself a lot of typing,
especially if you use that command a lot.
Aliases are defined with the alias command. To show all aliases, use the alias command without
an argument. To remove an alias, use the unalias command.
Most distributions define a number of aliases by default.
Uempty
Keywords
• shell
• command interpreter
• metacharacter
• bash
• korn
• wildcard
• variable
• redirection
• alias
• stdin
• stdout
• stderr
These keywords are provided as a reminder of key subjects discussed in this unit.
Uempty
Unit summary
• Explain the function of the shell
• Discuss metacharacters and reserved words
• Use wildcards to access files with similar names
• Use redirection and pipes
• Use command substitution
• Describe and use the most common filters
• Group commands to control their execution
• Work with shell variables
• Use aliases
• Apply quoting
Uempty
Review questions
1. True or false: A filter is a command that reads a file,
performs operations on this file, and then writes the result
back to this file.
Uempty
Review answers
1. True or false: A filter is a command that reads a file,
performs operations on this file, and then writes the result
back to this file.
The answer is false.
Uempty
Uempty
Exercise introduction
• Get to know the basic features of the Linux shell (Bash)
Uempty
Overview
This unit describes defining a Linux process, the relationship between parent and child processes,
the purpose of a shell, foreground and background processes, the concept of signals and how they
are used to terminate processes, and the concept of priorities.
Uempty
Unit objectives
• Define a Linux process
• Describe the relationship between parent and child processes
• Explain the purpose of a shell
• Start foreground and background processes
• Explain the concept of signals and use them to terminate processes
• Explain the concept of priorities and manage them
Uempty
What is a process?
• A program is an executable file
• A process is a program that is being executed
• Each process has its own environment
Process environment
A program or a command that is actually running on a system is referred to as a process. Linux can
run a number of different commands at the same time as well as many occurrences of the same
program (such as Vi) at the same time.
The Linux kernel holds an internal table, called the process table, in which the information about
running processes is kept.
A shell is a special process that is able to read user commands and can start the appropriate
program. One of the built-in commands of the shell is echo, which displays something on the
screen, and one of the built-in shell variables is $$, which displays the process ID (PID) of the shell.
Uempty
bash fork()
exec() ls -l exit()
All processes in a Linux system are started by another process, so for each and every process you
can identify the parent (the process that started this particular process) and the children (the
processes that were started by this particular process), if any.
There is one exception to this. The init process is started by the kernel itself, and always has
process ID 1. (Actually, there are a few more processes that are started by the kernel. These
processes usually have PID 2, 3, and so forth, and their name usually starts with the letter k. The
amount of processes and their names vary from kernel version to kernel version.)
Processes do not run forever. They can be terminated because of two reasons:
• Because the process terminates itself, either automatically (when the work has been done) or
based on user input (such as a user entering ZZ in Vi).
• When another process sends a “signal” to the process.
Uempty
Linux system
Login: /sbin/mingetty
Login: Password: ...forks /bin/bash
$ -bash (login shell)
Environment
Program -bash
UID 503 (tux3)
GID 100 (users)
Open files /dev/tty1
PID 201
When a user approaches a Linux system and wants to start working with it, he or she is greeted
with the login prompt. This login prompt is generated by the login process. This is not entirely true.
The first login prompt is generated by getty, telnetd, sshd or another program that opens that
particular tty. When the user types in his username, the login program is started with that username
as parameter. The login program then asks for the password, and if authentication fails, it displays
the second login prompt. Complicated, isn’t it?) The user types the login name, and the login
program asks for a password. If the user also types in the correct password, then the login program
looks up the favorite shell of the user and starts this shell program. This first shell is called the login
shell.
In a graphical environment, things work differently. The graphical login prompt is generated by a
display manager* . When users correctly authenticates himself, his window manager is started. The
window manager can then start a terminal window, which in turn starts a shell. Because in a
graphical environment more than one terminal window can be opened, a user can run multiple
shells simultaneously.
Note
* xdm, kdm, and gdm are the most common display managers.
Uempty
$ bash
$ echo $$
675
$ date
Mon Jan 1 22:28:21 UTC 2018
$ <ctrl-d>
$ echo $$
561
PID PPID
-bash 561 320
675 561
bash 777 675
date
Working with processes © Copyright IBM Corporation 2001, 2018
The PID is the process identification number used by the kernel to distinguish the different
processes. The PPID is the parent process identification number, or in other words, the PID of the
process which started this one.
The special environment variable $$ identifies the PID of the current shell.
The echo command is built into the shell, so it doesn't need to create a subshell to be run.
In the example above, a second bash shell is started as a way to illustrate the parent/child
relationship with processes. As another example, a second, different shell could be started (for
example csh) to run specific shell scripts or programs.
Uempty
Monitoring processes
• The ps command displays process status information
$ ps aux
USER PID %CPU %MEM VSZ RSS TTY STAT START TIME COMMAND
root 1 0.0 0.0 1336 436 ? S Jan1 0:05 init
root 2 0.0 0.0 0 0 ? SW Jan1 0:00 [keventd]
root 3 0.0 0.0 0 0 ? SW Jan1 0:05 [kapmd]
root 4 0.0 0.0 0 0 ? SW Jan1 0:05 [kswapd]
...
root 10248 0.0 0.1 2852 884 pts/2 R 13:47 0:00 ps aux
The ps command prints process information. When no options are given, it only prints the
processes that were started on your current terminal. ps supports a large number of options. The
most common invocation is ps aux, which displays all processes, with and without a tty (a and x)
in a user-oriented format (u).
Uempty
The pstree command is a very simple tool which allows you to view the process hierarchy. It also
supports a number of options that allow you to include the PID, for instance.
Uempty
Controlling processes
• Processes can be controlled in two ways
ƒ From the shell that started it, using its job number
ƒ From anywhere on the system, using its PID
Uempty
• Background processes
ƒ Background processes are invoked by putting an ampersand (&) at the
end of the command line
Processes that are started from and require interaction with the terminal are called foreground
processes. As long as a foreground process runs, you are not able to run another command in the
system using this shell. Processes that are run independently of the initiating terminal are referred
to as background processes.
Background processes are most useful with commands that take a long time to run and do not
need to interact with the user. A background process is started by ending the command line with a
&. Normally, this must be the last character on the command line.
When a background process is started, you can see two numbers.
[1] 417
This means:
• [1] is the first process you are running in the background.
• 417 is the process ID of this process.
Uempty
You can stop a foreground process by pressing <Ctrl-z>. This does not terminate the process; it
suspends it so that you can subsequently restart it.
To restart suspended processes in the background, use the bg command. To bring a suspended or
background process into the foreground, use the fg command.
To find out what suspended/background jobs you have, issue the jobs command. This command
shows you the job number of a process.
The bg, fg, and kill commands can be used with a job number. For instance, to kill job number 3,
you can issue the command kill %3.
The jobs command does not list jobs that are started with the nohup command if the user has
logged off and then logged back into the system. On the other hand, if a user invokes a job with the
nohup command and then issues the jobs command without logging off, the job is listed.
Uempty
It is not mandatory to use job numbers with fg, bg, and kill. Look at the bg and kill commands to
see how to use process IDs and process names.
Uempty
Kill signals
• Several signals can be sent to a process
ƒ Using keyboard interrupts (if foreground process)
ƒ Using the kill command
í Synopsis: kill -signal PID
ƒ Using the killall command to kill all named apps
í Synopsis: killall -signal application
• The following table lists the most important signals
Signal Keyboard Meaning Default action
01 Hangup End process
02 <ctrl-c> Interrupt End process
03 <ctrl-\> Quit End process and core dump
09 Kill End process – cannot be
redefined – handled by kernel
15 Terminate End process
If you want to control a process from outside the shell (or other process) that started it, you need to
use signals. Signals are the UNIX way of “nudging” a process into doing something.
When a process is running in the foreground, you can use keyboard interrupts (Ctrl-key) to send a
signal. Otherwise, you need to use the kill or killall command to send a signal.
Most signals are delivered to the application itself. Technically, this means that the programmer of
an application can write a special subroutine (called a signal handler) that is executed when a
signal arrives. If the programmer did not write these special signal handlers, then the kernel
performs the default action for that signal, which in most cases means that the application is
terminated.
For us, only a few signals are important.
The hangup (01) signal is sent to a process if its parent dies, for example, if you log off when a
background process is running. Most daemons (discussed later) redefine this signal to mean
re-read configuration file.
The interrupt signal (02) is generated when the user presses the interrupt key (usually <Ctrl-c>)
on the keyboard. The key is in different places depending upon the system and the terminal type.
Uempty
The command nohup tells the process to ignore signals 01 and 03 (hangup and quit). This
allows the process to continue if you log off the system.
Since all processes need to have an associated parent process, commands that start with nohup
get the init process as the parent when you log off the system. nohup is designed to be used for
background processes as it has little meaning when used with a foreground process.
Uempty
User-defined priority
Default priority (0) (negative values are
allowed only to root!)
Reserved for
-20
. . .-60
} kernel threads
Processes on a Linux system are scheduled according to a dynamic priority value: when a CPU is
free to run a process, it looks through the process table for a process with the lowest priority
number which is ready to run. This process then gets a timeslice on the CPU. The priority number
of a process is continuously changed. Basically three factors influence this:
• The nice value for the process: The priority number of a process will never decrease below this
number.
• After a process has had a certain amount of CPU time, its priority number is increased. This
means that the next time a CPU becomes available, the process is less likely to be first in the
list.
• After a process has been idle (not using CPU time) for a while (either because it is waiting for
something to happen, or because other processes are keeping the CPU busy), the priority
number is decreased.
This scheme results in a usage pattern where processes with the same nice value get equal
amounts of CPU time. Processes with higher nice values get less CPU time than processes with
lower nice values.
In reality, process scheduling is a lot more complex than what was written above. A lot of academic
research has gone into optimizing scheduling, and a lot of that academic research has made its
Uempty
way into the kernel. There are several issues that need to be taken into account, in addition to the
process priority and its nice value. A few of the more important issues are:
• Real-time processes are processes that need to have immediate access to the CPU as soon as
something (e.g. an interrupt) happens. This cannot be delayed, for instance because it needs to
control something in the physical world. The logic that controls robot arms is an example: You
would not want your robot arm to continue moving beyond its stop point simply because
somebody issued a difficult database query by using a web server.
• Processes that last run on a specific processor of a multi-processor system should, if possible,
run on the same processor the next time again. This preserves the cache contents of that
processor and makes the processes generally run faster. This is known as “cache affinity”.
• Sometimes processes are dependent on other processes. For instance your web server scripts
may be dependent on a single database process. If this database process is delayed, the result
is that tens, or possibly hundreds of other processes are also delayed. It therefore makes sense
to give this database a higher priority, to reduce the overall latency of the system.
Linux uses a “Completely Fair Scheduler” that is optimized for most workloads, takes issues such
as these into account, and uses very few CPU cycles itself.
Uempty
To decrease the priority of a process when starting that process, use the nice command.
By default, nice sets a priority of 10 for a process, but this can be changed with the -n option.
Only root can set negative nice values.
Note that, because of the priority mechanism, even on a busy system, a process with a nice value
of 20 gets some CPU time.
Uempty
$ renice 15 4862
4862: old priority 10, new priority 15
$ ps l
F UID PID PRI NI VSZ ... COMMAND
0 500 4372 20 0 4860 ... –bash
0 500 4862 30 15 3612 ... my_program
0 00 4863 20 0 1556 ... ps l
When you want to change the priority of a process which is already running, use the renice
command.
Uempty
Daemons
• The word daemon refers to a never-ending process
ƒ Usually a system process that controls a system resource
ƒ Examples
í Job scheduling
í Network operations
í Print management
cupsd
Print queue
Print job 1
Print job 2
Print job 3
/dev/lp0
A daemon (as in a sort of a friendly ghost or spirit, which guards your interests on your behalf)
means a background process that typically starts when you start your system and runs until you
shut it down. These processes are typically used to control access to a system resource, or to
perform a network service.
cupsd (the CUPS daemon or Common UNIX Printing System) is one example of a daemon. cupsd
tracks print job requests and the printers available to handle them. The cupsd daemon maintains
queues of outstanding requests and sends them to the proper device at the proper time.
Technically speaking, daemons are nothing more than regular background processes. It's just the
purpose that gives them another name.
Uempty
Keywords
• Process
• Parent and child processes
• PID
• priority
• job
• Foreground
• Background
• Daemon
These keywords are provided as a reminder of key subjects discussed in this unit.
Uempty
Unit summary
• Define a Linux process
• Describe the relationship between parent and child processes
• Explain the purpose of a shell
• Start foreground and background processes
• Explain the concept of signals and use them to terminate processes
• Explain the concept of priorities and manage them
Uempty
Review questions
1. True or False: Any user can send a signal to a process of
another user and cause that process to halt.
3. What is a daemon?
Uempty
Review answers
1. True or False: Any user can send a signal to a process of
another user and cause that process to halt.
The answer is false. A normal user will not have the appropriate
permission to send signals to another user's processes. The root user
does have permission to do this.
3. What is a daemon?
The answer is a daemon is a never ending process which provides a
system service.
Uempty
Uempty
Exercise introduction
• Monitor processes
• Change and understand the process environment
• Control jobs
• Terminate processes
Uempty
Overview
This unit discusses the following commands: find, locate, grep, cut, sort, head,
tail, type, which, whereis, file, join, paste, gzip, gunzip, zcat, bzip2,
bunzip2, and bzcat.
Uempty
Unit objectives
• Use the find and locate commands to search for files
• Use the grep command to search text files for patterns
• Use the cut command to list specific columns of a file
• Use the sort command to sort the contents of a file
• Use the head and tail commands to view specific lines in a file
• Use the type, which, and whereis commands to find commands
• Use the file command to find out the content of a file
• Use the join and paste commands to combine files
• Compress and uncompress files with gzip, gunzip, zcat, bzip2,
bunzip2, and bzcat
Uempty
The find command recursively searches the directory tree for each specified path, seeking files
that match a Boolean expression.
The output of the find command depends on the terms specified by the final parameter.
The basic syntax of the command could be written down as:
find <from where> <search for> <do something to it>
Uempty
home
tux1
orange
phone1
phone2
sample
Uempty
Using find
• Generally, you want to search a directory structure for files with
certain names and list the names found
$ cd /home/tux1
$ find . -name orange
./orange
./color/orange
./shape/orange
./size/orange
Note that the directory search is recursive meaning that find searches the current directory and all
the subdirectories underneath it.
If not specified otherwise, the find command matches both directories and files.
The examples on the visual search for all files with the name orange, starting in the current
directory (.).
Note that the -print option is the default and is not required. This was not always the case. In UNIX
versions that have not yet implemented the POSIX standard for the find command, the -print
option is required for the result to be displayed or used in a pipe.
Uempty
• A set of curly brackets ({}) is a placeholder for each file name. The
backslash (\) escapes the following semicolon (;)
The command following the -exec option, in this case the ls command, is executed for each file
name found. find replaces the {} with the names of the files matched. {} is used as a placeholder
for matches.
Note the use of the escaped “;” to terminate the command that find is to execute. The \; is hard
coded with the find command and is required for use with -exec and -ok options.
$ find . -name 's*' -exec ls -l {} \;
is equivalent to
$ find . -name 's*' -ls
Uempty
It is a good idea to use the -ok option rather than the -exec option if there are not a lot of files that
match the search criteria.
Uempty
-perm
onum Access permissions match onum
mode Access permissions match mode
-user user Finds files owned by user
There are many other options to the find command, which are listed in the online manuals. Some
options of find are:
• -type: Allow searches for only files or only directories.
• -size: Search for files that exactly match a size (-size 10), that are more than a size (-size
+10) or that are below a certain size (-size -10). Size values are expressed in blocks, or with the
c modifier, in bytes.
• -mtime: Search for files that have been modified in the time parameter supplied. The times are
in days relative to the current day plus 24 hours. The times can be an exact match, older, or
newer than the time specified.
• -perm: Search for files that have a certain permission mask (see chmod).
• -newer: Search for files that are newer than the reference file.
• -o: Allow multiple conditions to be matched (find a or b).
• -a: Require multiple conditions to be matched (find a and b).
Uempty
The first example finds all the files (files and directories) that have their permissions set as 777 and
were modified more than four days ago.
The second example searches for file names, not directory names, which are greater than 1024
bytes (two blocks of 512 bytes). When these have been found, the ls -i command is executed on
them.
The third example shows you both files and directories that have circle as a name or whose name
starts with a b.
Uempty
The locate command also searches for files in the directory tree. There are two differences, if you
compare locate to find:
• locate can only work with very simple criteria.
• locate uses a database which was created earlier.
This means that locate is faster in use, but requires a little effort to set up: The superuser has to
run the updatedb command regularly (preferably every day or so) to keep the database up to date.
Most distributions are configured to run updatedb every night.
Uempty
The grep (Global Regular Expression Print) command searches for the pattern specified and writes
each matching line to standard output.
The search can be for simple text, like a string or a name. grep can also look for logical constructs,
called regular expressions, that use patterns and wildcards to symbolize something special in the
text. Only lines that start with an uppercase T, for example.
The command displays the name of the file containing the pattern if more than one file is specified
for the search.
Uempty
• Phone 2:
Chris 1342 internal
Jan 2083 internal
Lee 3139 external
Pat 4200 internal
Robin 5200 internal
Terry 6342 external
This visual shows the sample files used to illustrate the examples that follows.
Uempty
$ grep 20 phone*
phone1:Jan 20500 internal
phone2:Jan 2083 internal
phone2:Pat 4 200 internal
phone2:Robin 5200 internal
grep searches for the string given. If not specified otherwise, grep does not see the difference
between a whole word matching the pattern or just a portion of a word matching the pattern.
The -v option reverses the working of grep; only lines that do not match are displayed.
Uempty
The purpose of regular expressions on lines is the same as wildcards for file names.
When an asterisk (*) is used with the grep command to specify a regular expression, it matches
zero or more occurrences of the previous character. If you want to use it to match zero or more
arbitrary characters, it should be preceded by a dot, which means any single character.
Note that many metacharacters can have different meanings in regular expressions than they do in
the shell. The following is a chart that compares grep metacharacters to the shells.
grep | grep Interpretation | Shell | Shell Interpretation
^ | beginning of line | ^ | “old” Bourne pipe symbol
$ | end of line | $ | variable
. | any single character | ? | any single character
.* | any number of any characters | * | any number of any characters
[-] | character range | [-] | character range
Uempty
Answers:
1. To display all processes running on the system that belong to tux1, enter:
$ ps aux | grep '^tux1 '
(Note the space after tux1.)
1. Display all lines of the phone1 file:
$ grep '.*' phone1
1. Display only the lines of phone1 that contain an e and end in a 0:
$ grep 'e.*0$' phone1
Uempty
grep supports various useful options. Some of the most important ones are listed on the chart.
These options can be combined. One of the most useful options is the -v option in combination
with the -f option. This is typically used in logfile analysis: Logfiles are usually full of routine
messages, and by putting these routine messages in an ignore file, you can filter your actual log
file, discarding all routine messages, and displaying only the interesting messages, with this single
command:
grep -v -f ignorefile logfile
Another useful trick is to do a full-text search over a large number of files, displaying the name of
the file that matches automatically:
grep -l searchstring ‘find $HOME -name "*.txt"‘
Uempty
Other greps
• fgrep allows only fixed strings (no regular expressions)
• egrep allows for multiple (alternate) patterns
$ egrep '20500|40599|50599' phone1
Jan 20500 internal
Pat 40599 external
Robin 50599 external
egrep is slightly slower than normal grep because it allows you to or patterns together using the
vertical bar (|). To match all the patterns against a line takes a little bit more time than just matching
one pattern.
fgrep is slightly faster because there is no interpretation that must take place first. Every regular
expression must be evaluated first and this takes a little bit of time.
The answer to the question on this chart is: Display all lines in phone1 that contain both the string
30 and the string intern.
With a pipe from one grep to another, you can define an and-construct.
Uempty
Uempty
$ cat /etc/passwd
root:x:0:0:Big Brother:/root:/bin/bash
shutdown:x:6:0:shutdown:/sbin:/sbin/shutdown
tux1:x:500:500:Tux the Penguin(1):/home/tux1:/bin/bash
tux2:x:501:501:Tux the Penguin(2):/home/tux2:/bin/bash
Uempty
$ ps
PID TTY STAT TIME COMMAND
9374 p0 S 0:00 -bash
14460 p0 R 0:00 ps
$ ps | cut -c-5,20-
PID COMMAND
9374 -bash
14471 ps
In some files, the columns are not evenly divided by delimiters. The output of ps is an example of
this. We see five columns, but what is the delimiter character between these columns? We cannot
say that a space is the delimiter because the first line has two leading spaces, then PID. PID would
thus be in the third column according to cut -d' '. However, on the second line, the actual PID
has one leading space, putting it in the 2nd column, and the third line has no leading spaces, so PID
would be in the first column.
If we run ps | cut -f5 -d " ", we would get this as output:
STAT
To overcome this problem we cannot use the syntax that defines columns with delimiters. Instead
we have to tell cut what characters we want to see.
ps | cut -c-5,20- tells the cut command only to display the characters specified; characters
1 to 5 and characters 20 and further.
Uempty
$ cat animals
dog.2
cat.4
penguin.10
$ sort animals
cat.4
dog.2
penguin.10
To specify a delimiter with sort, use the -t option. This option has the same function as the -d
option for cut. The -t option tells sort what character separates fields. This is often a : (colon), \t
(tab) or \n (new line) character.
Uempty
sort animals
Sorts the file animals starting with the first character of each line as the primary key.
sort -k1.2 animals
Forces a sort on the second character of each line.
sort -t. -k2 animals
Forces sort to sort on the second (-k2) column. Columns are separated here with a dot. Be aware
that sort always tries to perform an ASCII (not necessarily numeric) sort, so 10 comes before 2, for
example.
sort -t. -n -k2 animals
Performs a numeric sort on the second (+1) column.
Uempty
• The tail command displays the last few lines of a file or files
$ tail [{-lines|-n lines|-n +lines|-f}] file(s)
The head command shows you the first ten lines of a file by default. You can change the default by
specifying a number to head.
The tail command can be used with either a positive or a negative number.
• -n indicates the number of lines to read beginning from the end of the file. This displays the last
n lines of the file.
• +n indicates the number of the line where you want to start displaying the lines.
The tail -f command can be used to monitor the growth of a file being written by another
process. The -f option causes the tail command to continue to read additional lines from the input
file as they become available.
For example: tail -f logfile
displays the last ten lines of the logfile file. The tail command continues to display lines as they are
added to the logfile. The display continues until the interrupt key <Ctrl-c> is pressed. The -f option
of tail can only be used when you specify a file. It cannot be used when tail has to read its input
from STDIN.
Uempty
What if you are writing a program that uses grep and you must include the full path name, but you
do not know where the command resides? The type command can tell you. When you type the
name of a command, the shell searches for the command in your search path and runs the first one
it finds. You can find out which copy of the program the shell runs by using the type utility.
An alternative to type is which. This command looks only in your search path. Note the different
answers for echo. which does not know that echo is also a shell built-in. The reason for this
difference is that type is a shell built-in itself, and which is not.
To locate a command, try using the whereis command, which looks in a few standard locations
instead of using your search path. The whereis command also displays any manual page and
source code files found.
The type command also reports on shell built-ins whereas the whereis command doesn't. A
problem that could show up is shown on the chart. The type command tells you that the echo
command is a shell built-in, but the whereis command tells you that there is an executable in /bin.
Uempty
The file command can be used to determine the type of a file. This can be useful for a couple of
reasons. First, it can tell you what files are readable before you potentially hang your screen by
trying to display an executable file. Second, it can help you determine what kind of binary file it is
and what operating system version it was compiled under.
The file command uses the /usr/share/misc/magic file to identify files that have some sort of
magic number; that is, any file containing a numeric or string constant that indicates the type.
Using file on a non-existing file results in an error message stating that it could not get a file status.
You could use the file command to find out if a command is a shell script or an executable. To find
out enter this:
$ file ‘which command‘
Uempty
The join and paste commands allow you to merge files together. They are rarely used, except for
the most complicated shell scripts.
Uempty
The gzip command compresses data, using the Lempel-Ziv coding (LZ77), to reduce the size of
files. A compressed file replaces each file with a new compressed file with .gz appended to the
original name. The compressed file retains the same ownership, modes and modification time of
the original file. If compression does not reduce the size of the file, a message is written to stderr
and the original file is not replaced.
The -v option writes the percentage of compression that occurred.
The zcat command allows the user to expand and view a compressed file without creating an
uncompressed version of that file first. It does not rename the expanded file or remove the .gz
extension. It simply writes the expanded output to stdout.
The gunzip command restores the original file that was compressed by the gzip command. Each
compressed file is removed and replaced by the expanded copy. The expanded file has the same
name as the compressed version without the .gz extension.
Files compressed with the compress command can also be uncompressed with gunzip.
The bz family of commands operates very similarly. The bzip2 command compresses files using
the Burrows-Wheeler block sorting text compression algorithm, and Huffman coding. bunzip2
uncompresses bzip2-compressed files, and bzcat expands bzip2-compressed files to standard
output.
Uempty
Keywords
• find • file
• locate • join
• grep • paste
• cut • gzip
• sort • gunzip
• head • zcat
• tail • bzip2
• type • bunzip2
• which • bzcat
• whereis
These keywords are provided as a reminder of key subjects discussed in this unit.
Uempty
Unit summary
• Use the find and locate commands to search for files
• Use the grep command to search text files for patterns
• Use the cut command to list specific columns of a file
• Use the sort command to sort the contents of a file
• Use the head and tail commands to view specific lines in a file
• Use the type, which, and whereis commands to find commands
• Use the file command to find out the content of a file
• Use the join and paste commands to combine files
• Compress and uncompress files with gzip, gunzip, zcat, bzip2,
bunzip2, and bzcat
Uempty
Review questions
1. True or false: The command ps -aux | grep tux |
grep firefox lists all Firefox processes of a user named
tux.
Uempty
Review answers
1. True or false: The command ps -aux | grep tux | grep firefox
lists all Firefox processes of a user named tux.
The answer is true. Technically, the command lists all processes for which
the ps command output includes the tux and firefox strings. Note that this
command will also list all processes of a user named tux01, for example,
and all processes named tux or tuxedo, for example. Note also that all
Firefox processes is nebulous in that a Firefox application might include a
process called plug-in container that would not appear in the command
output.
2. Which command would best be used to locate all files in your system that
begin with the string team?
a. find / -name "^team"
b. find / -name "team*"
c. find / -name "*team*"
d. find / -type f -name "team"
The answer is find / -name “team*”. Note that the find command
uses the same metacharacters as the shell.
Uempty
Uempty
Exercise introduction
• Become familiar with some of the many helpful tools available
with Linux
Uempty
Overview
This unit shows how to invoke shell scripts, how to pass positional parameters to shell scripts, how
to implement interactive shell scripts, and how to use conditional execution and loops.
Uempty
Unit objectives
• Invoke shell scripts in three separate ways and explain the difference
• Pass positional parameters to shell scripts and use them within scripts
• Implement interactive shell scripts
• Use conditional execution and loops
• Perform simple arithmetic
Uempty
$ pwd
$ date
$ ls -l
$ cat script1
pwd
date
ls -l
$
A shell script basically is a collection of shell commands stored in a text file. This makes it easier to
repeat a sequence of commands and is especially handy for automating your work.
Uempty
Start of subshell
bash
date
There are three ways of invoking a shell script. The chart shows the first method. With this method,
a bash subshell is started with the script name as argument. Obviously, for this to work, the script
needs to be readable. It does not have to be executable however, nor does it have to be in the
PATH.
With this method, the script is executed within the shell that was started. This means that any
environment variable changes are not propagated to the initial shell.
Uempty
Start of subshell
bash
date
The second method of invoking a shell script is by making it executable with chmod. This allows you
to call the script directly. As with the first method, the script is executed in a subshell and thus any
changes to environment variables are not propagated to the initial shell.
If you make sure that the script is located somewhere in your PATH, then you can invoke the script
with just its script name. If the script is not in your PATH, you must invoke it with its relative or
absolute path name.
Uempty
-bash
script1 date
The third method is by invoking the script using the . (dot) or source command. In this case, the
script is executed in the current shell. This means that the script can make changes to environment
variables in the current shell.
Uempty
• The script will now always runs in bash even if the user’s default shell
is something else
A shell is a very personal choice. Under Linux, most people prefer the bash shell, but people from
an AIX background might prefer pdksh, and C programmers might prefer csh. If your script was
written for the bash shell and contains bash-specific commands or constructs, you might want to
make sure that the script is always invoked in a bash shell. This is done by adding the following line
on top:
#!/bin/bash
When a shell (any shell) encounters a shell script that starts with the magic marker #!, it knows that
this script is to be executed using the command that follows the magic marker, in our case
/bin/bash.
The same magic marker can also be used to identify perl scripts (#!/usr/bin/perl), awk scripts
(#!/usr/bin/awk), and so forth.
Uempty
As said, a shell script is nothing more than a series of shell commands. Any shell command can be
used in a shell script and vice versa. Having said that, there are a few things that are typically only
found in shell scripts because using them on the command line would be silly or complicated. The
rest of the unit covers these things.
Uempty
Arguments, also called positional parameters, can be passed to shell scripts when the shell script is
invoked. Within the shell script, they are available as special shell variables:
• The positional parameters themselves are available as $1, $2, $3 and so forth. Positional
parameters after number 9 must be referenced using the curly braces { } and a number, like
${10}.
• The curly brace notation for numbers above 9 is rarely used, because large numbers of
parameters are typically handled using the shift command, which we discuss later.
• The amount of positional parameters is stored in $#.
• All positional parameters are stored in $@ and $*. The only difference is the way they are stored:
$@ is equal to “$1” “$2” “$3”...
$* is equal to “$1 $2 $3...”
The difference is important when using $@ and $* as parameters for another command.
Uempty
Complex redirection
• To redirect fixed text into a command, use << END
$ cat << END > cities
Atlanta
Chicago
END
In the previous units, we have already seen redirection using >, >> and <. This allows us to redirect
input and output to a file. But what if we want to input some static content to a command? In that
case, we can use the << operator. This allows us to specify the input to a command on the lines
that follow that command in our script, until we reach the specified delimiter. In the visual, the
content of the file cities would be:
Atlanta
Chicago
END is the delimiter string. It is not included in the file. Note that this delimiter should start at the
start of a new line. It is not permitted to put any characters (including spaces) in front of the
delimiter.
Another form of complex redirection is the xargs command. It is used to avoid the situation where a
command such as cat ‘ls *.txt‘ would possibly dump so many filenames onto the argument
list of cat that certain limits would be exceeded. With xargs, the arguments to use are fed from
stdin, which can handle unlimited input, and the command to execute is executed as many times as
necessary, without ever reaching shell limits.
Uempty
Conditional execution
• The return code from a command or group of commands can be
used to determine whether to start the next command
do
This
If command
Command
That
Returns command
Conditional execution means that the execution of a command or block of commands is dependent
on the return code of another command.
There are two ways of making commands conditional:
• If you need to make one command conditional, then you can use the && or || notation.
• If you need to make a block of commands conditional, then you can use the if then else fi
notation.
In most cases, the return code to test is actually generated by the test command, which is a really
versatile command for testing for files, strings, variables, and so forth.
Uempty
Uempty
• Arithmetic tests
<value> -eq <value> equals
<value> -ne <value> not equal
<value> -lt <value> less than
<value> -le <value> less than or equal
<value> -gt <value> greater than
<value> -ge <value> greater than or equal
The chart lists some more examples of test expressions. Remember that in each and every case
the return value of the test command ($?) is set to 0 if the test is positive, and 1 if the test is
negative. Another thing to remember is to surround all your variables you use in a test expression
with double quotes. As an example, consider what would happen with the following command:
$ test $var == "test"
If $var is not empty, then the test is carried out and the return code is set to 0 or 1, depending on
whether $var actually contained the word test. But if $var happens to be empty or not defined, then
the shell changes this statement into:
$ test == "test"
This statement is obviously incorrect and gives you a syntax error, and a return code of 2. This
could easily be prevented by using the following syntax:
$ test "$var" == "test"
Now, if $var is empty or not defined, the statement is changed into:
$ test "" == "test"
This is a legal syntax. Obviously, the return code is 1.
Uempty
The first way of conditionally executing commands is by using the && and || operators. These
operators allow a single command to be executed, depending on the return code of another single
command.
Uempty
The if command
• The structure of the basic if statement is:
if command-sequence returns true (0)
then
carry out this set of actions
else
carry out this set of actions
fi
$ cat myscript
if [ "$MY_VALUE" -eq 10 ]
then
echo MY_VALUE contains the value 10
else
echo MY_VALUE is not 10
fi
$
Shell scripting © Copyright IBM Corporation 2001, 2018
The if then else fi construct allows you to execute multiple commands, based on the return
code of a command.
You do not always need an else statement, but you can use only one within an if statement.
command1 && command2
is the same as
if command1'
command2'
However, the if statement is usually more readable, especially if there are a lot of commands to be
executed.
Uempty
Command repetition
• A loop is a set of commands that is executed over and over
ƒ Until or while a certain condition is true
ƒ Or for each item from a list
if <condition> is false,
leave this set of
commands.
A loop is the programmers term for a set of commands that is executed over and over again. Loops
in the bash shell can be of these two forms:
• Loops that run until or while a certain condition is true
• Loops that are executed for each item of a list
Uempty
The while loop is executed only while the expression evaluates true. By using the true argument
with the while command, it forces the set of commands to be executed until the script is
interrupted, for instance, with <Ctrl-c>.
The sleep command suspends execution of a process for the specified number of seconds, or until
externally interrupted.
The expression used in the while loop can be any command, but in practice it is most often a test
command, just like with if.
Uempty
$ cat my_forloop
for file in /tmp/mine_*
do
cp $file /other_dir/$file
done
$
The for command sets the identifier variable to each of the values from the list in turn and executes
the command block. Execution ends when the list is finished.
In the given example, the list for the for command has been formed by metacharacter expansion
into certain file names in the /tmp directory.
Other examples are:
for fruit in Apple Banana Carrot
do
echo I would like a $fruit
done
And
for file in ‘find /home -perm 777‘
do
echo Dangerous File Permissions on $file
done
Uempty
$ cat make_backup
while [ $# -gt 0 ]
do
cp $1 $1.bak
shift
done
$
while and for loops are typically used to evaluate a large number of command line arguments.
Shell scripts with a large number of arguments are typically shell scripts that are called with
wildcards. In that case, the number of arguments is unpredictable and can, of course, be quite
large.
There are basically two methods of evaluating such a large number of arguments: by using a for
loop and by using a while loop. The for loop is the easiest and therefore not shown in the visual. It
would look like this:
for file in $@
do
cp $file $file.bak
done
Evaluating a large number of command line arguments using the while loop generally involves the
shift command. This command shifts the arguments down by one (or perhaps to the left by one):
• $2 is copied to $1, $3 is copied to $2, and so forth.
• The last set variable is unset.
• $# is decreased by one.
Uempty
So, the basic construct works like this: As long as $1 is not empty, perform the operations on $1
and then execute the shift command. The chart shows how this is implemented in bash.
Although the while construct looks a little more complicated than the for construct, it is used more
often for handling large numbers of arguments. The reason for this is that it gives more flexibility in
that its loop test is re-evaluated on each loop iteration, not set at the beginning. As an example,
your script might accept a number of options in addition to arguments. These should first be
evaluated, possibly within a while construct, and then the arguments should be evaluated, again in
their own while construct.
Uempty
$ cat delfile
#!/bin/bash
#Usage delfile
echo Please enter the file name:
read name
if [ -f $name ]
then
rm $name
else
echo $name is not an ordinary file -
echo so it is not removed
fi
Shell scripting © Copyright IBM Corporation 2001, 2018
The read command can be used to set more than one variable with a value. If more than one
argument is given, the first argument would be assigned to the first variable name specified. The
second argument would be assigned to the second variable and so on until the last argument is
reached.
If there are more arguments supplied than variable names defined, the last variable name is given
the value of all remaining arguments.
Usage is by programming convention. In this example, the usage statement is preceded by a #,
which indicates that it is a comment.
The example does not test for the file permissions. This could be a worthwhile addition.
Uempty
$ let x=2+3
$ echo $x
5
$ echo $(( 2+3 ))
5
$ let x=3*(3+5)
$ echo $x
24
$ let x=3*3+5
echo $x
14
$ x=$(( 3 * ( 3 + 5 ) ))
The bash shell allows you to do simple arithmetic using the let command. An alternative notation
for this command is the $(( )) notation.
The let command and the $(()) notation only works on integers and is limited by certain bounds,
because it uses a “signed long int” variable type for internal representation. This means that,
depending on the hardware architecture, the lowest number that can be stored is -231 or -263 , and
the highest number is 231 -1 or 263 -1.
The operators that can be used are:
• An asterisk (*) for multiplications
• A slash (/) for division (results are rounded down to the nearest integer)
• A plus sign (+) for addition
• A minus sign (-) for subtraction
• A percent symbol (%) for the remainder of a division
• Left and right parenthesis () for argument grouping
According to the POSIX standard, arithmetic is done before wildcard expansion and command
grouping. Because of this, the (, ), and * characters do not need to be escaped, independent of
whether you are using let or $(()). However, experience has shown that not all versions of bash
Uempty
correctly implement this. If you want to be safe, make sure you surround your expression with
double quotes.
Also, make sure that any shell variables you use indeed contain integers: they should only contain
the digits 0-9.
Uempty
Not all shells support the built-in let command or the $(( )) notation. In that case, you have to use
the expr command. This is not a shell built-in and thus takes some extra time to execute. In
practice, a script which does a lot of arithmetic is about 10 times slower when it has to use expr.
The usage of expr differs slightly from let, because expr cannot do assignments to environment
variables directly. Instead, it prints the output of an arithmetic expression on stdout. This output can
then be assigned to a variable by command evaluation.
Just as with let, expr also suffers from the drawback that it can only do calculations on integers,
and has to stay within certain bounds (depending on the architecture and the version of expr) to
work properly.
Uempty
You can see where the shell looks for the commands to be executed when it is ready.
Reserved words are those words that have a special meaning to the shell, such as: if, then, else,
while, and so forth.
Aliases are set and managed with the alias and unalias commands.
Built-in commands are those commands that are part of the shell. Examples include cd, umask,
read, and echo. If you cannot find a command in the manual pages, try searching in the manual
page of the bash shell.
Functions have not been covered in this unit. They can be thought of as shell scripts within shell
scripts.
The PATH variable is the last thing searched.
Uempty
Keywords
• shell script
• positional parameters
• conditional execution
• arithmetic operations
• redirection
• return code
• Commands
ƒ chmod
ƒ test
ƒ &&
ƒ ||
ƒ if
ƒ while
ƒ for
ƒ read
These keywords are provided as a reminder of key subjects discussed in this unit.
Uempty
Unit summary
• Invoke shell scripts in three separate ways and explain the difference
• Pass positional parameters to shell scripts and use them within scripts
• Implement interactive shell scripts
• Use conditional execution and loops
• Perform simple arithmetic
Uempty
Review questions (1 of 2)
1. What will the following piece of code do?
TERMTYPE=$TERM
if [ -n "$TERMTYPE" ]
then
if [ -f /home/tux1/custom_script ]
then
/home/tux1/custom_script
else
echo No custom script available!
fi
else
echo You don't have a TERM variable set!
fi
Uempty
Review answers (1 of 2)
1. What will the following piece of code do?
TERMTYPE=$TERM
if [ -n "$TERMTYPE" ]
then
if [ -f /home/tux1/custom_script ]
then
/home/tux1/custom_script
else
echo No custom script available!
fi
else
echo You don't have a TERM variable set!
fi
The answer is if TERMTYPE is set to a non-null value and if
custom_script exists as a normal file, the script attempts
to execute it. If the script does not exist, this is reported. If
the TERMTYPE is null or not set, that is reported.
Shell scripting © Copyright IBM Corporation 2001, 2018
Uempty
Review questions (2 of 2)
2. Write a script that will multiply any two numbers together.
Uempty
Review answers (2 of 2)
2. Write a script that will multiply any two numbers together.
The answer is:
#!/bin/bash
echo $(($1 * $2))
Uempty
Uempty
Exercise introduction
• List common constructs used in writing shell scripts
• Create and execute simple shell scripts
Uempty
Overview
This unit describes the main components of the X Window System, the function of the X Server, the
function of window managers, and the main characteristics of desktop environments. This unit also
explains how to switch between GNOME and KDE.
Uempty
Unit objectives
• List the main components of the X Window System
• List the function of the X Server
• List the function of a window manager
• List the main characteristics of desktop environments
• Switch between GNOME and KDE
Uempty
The X Window System, called X for short, is a network-based graphics system that was developed
at the Massachusetts Institute of Technology (MIT) in 1984. In 1985, MIT released X (version 9) to
the public, license free. It was designed as a generic, UNIX-oriented basis for graphical user
interfaces (GUIs). Prior to X, the only way to communicate with a UNIX system was using
commands in an ASCII environment.
In 1987, a group of vendors and researchers formed the X-Consortium to continue work on this
windowing system. X version 11 (X11) was released in 1987, and continues to be the version of X
that is used. There have been several releases of X, the most current being release 6 (1994), better
known as X11R6 or Xorg.
Linux doesn't use the original X Window System but an implementation called XFree86.
X is an open standard that heavily uses standard TCP/IP network connections. This makes it ideal
in a mixed UNIX/Linux environment, because it allows applications written for and running on Linux
to display their windows on any other X-capable system. In fact, applications exist that can capture
Microsoft Windows application windows and display them on an X capable workstation over a
network connection.
Uempty
Client/server architecture
The X Window System uses a client/server architecture, which makes it very flexible. The central
piece of software is the X Server. The X Server traps all keyboard and mouse events and sends
them to the appropriate application. If an application wants to put something on the screen, it sends
that data to the X Server, which then performs the necessary hardware calls to the graphical
adapter.
Any application can connect to the X Server, but there should always be one special application
active: the window manager. The window manager basically puts a border around each application
window and allows you to drag windows around. Another task of the window manager is to allow
you to resize windows.
There are numerous window managers available, each with its own style. The most popular
window managers are the window managers that come with the GNOME and KDE projects
(discussed later), but other window managers may also be present or can be downloaded from the
Internet: fvwm, fvwm95, twm, mwm, olvwm, afterstep, and so forth.
Uempty
X components
• An X Server (usually Xorg)
ƒ Controls keyboard, mouse, and one or more screens
ƒ Controls resolution, refresh rate, and color depth
ƒ Allows simultaneous access by several clients
ƒ Performs basic graphic operations
ƒ Forwards keyboard and mouse events to the correct clients
• An X Client
ƒ Is, for instance, an application
ƒ Receives keyboard and mouse inputs from server
ƒ Sends output to be displayed to server
• A window manager
ƒ Is a special X Client
ƒ Performs window dressing on other clients
ƒ Allows other client windows to be moved, iconified, and so forth
The central component in any X configuration is the X server. This is a piece of software which
handles the low-level complexities of controlling a keyboard, mouse, graphical adapter and monitor.
One of the most important configuration choices that need to be made while configuring this server
is the resolution, the monitor refresh rate and the color depth. When the X server is running, all
keyboard and mouse events are received and forwarded to the appropriate X clients.
X clients are the applications that the user started, or that are started by the system by default. If
an application is activated by the user (usually by clicking it), it is sent all relevant keyboard and
mouse events, and can react to it. If the client wants to output something, then it sends these
requests to the server, which displays them.
A special client is the window manager. This client usually does not have its own window, but
displays the borders around other windows, and thus ensures that windows can be resized, moved
and iconified. The window manager is usually the first client that is started, and it may start other
clients in turn, if configured. Typical applications that are started by the window manager are task
bars, launchers, pagers, and so forth.
Uempty
Desktop environments
• A desktop environment is:
ƒ A set of tools, libraries and standards that allows rapid development of X
clients
ƒ A set of X clients (including one or more window managers) that are
developed with these tools, libraries, and standards
• Examples:
ƒ GNU Network Object Model Environment (GNOME)
ƒ K Desktop Environment (KDE)
Uempty
The KDE
The visual shows a screenshot of the K Desktop Environment. Several things can be identified.
First, the desktop itself. On this are a number of icons which were created automatically when the
system was installed. Clicking these icons launches various programs, varying from the mount
command (to mount the CD-ROM) to help browsers. Second, the panel, which stretches all the way
along the bottom of the screen. The panel is divided into a number of areas:
• The first area starts with the KDE button, which starts a Start menu just like Windows.
• The second area shows the virtual desktops that are currently configured.
• The third area shows the applications that are currently running in this desktop.
• The fourth area holds a lock and an Exit button.
• The fifth area holds icons for certain KDE applications, such as Klipper, the KDE clipboard.
• The sixth area holds a clock.
The third thing that can be seen is the set of applications that are running. In the visual, only a
terminal window, a browser (Konqueror) and the GIMP have been started.
Uempty
The visual shows a screenshot of a GNOME (GNU Object Modeling Environment) desktop, again
taken from a Red Hat system. As you can see, the basic functionality is not all that different.
Uempty
Starting X
• If logged in on a text terminal, run startx
ƒ This only starts a single session
ƒ When the session ends, you are back in your text terminal
• If you want to enable the graphical log in screen, bring the system
into the graphical target
ƒ To switch to graphical mode, use the systemctl set-default
graphical.target command
X can be started in two ways. The first way is by running the startx command. This command
searches for the first free virtual terminal and starts XFree86 on that terminal. It then starts your
favorite window manager of your favorite desktop environment. The window manager finally starts
all other applications that make up your desktop.
The second way is by switching to the graphical target where a display manager is started. This
program (depending on your settings this is xdm, kdm, or gdm) displays a graphical login prompt.
When a user logs on, it subsequently starts the favorite window manager of that user, just as with
startx.
Uempty
X can be started in two ways. The first way is by running the startx command. This command
searches for the first free virtual terminal and starts XFree86 on that terminal. It then starts your
favorite window manager of your favorite desktop environment. The window manager finally starts
all other applications that make up your desktop.
The second way is by switching to the graphical target where a display manager is started. This
program (depending on your settings this is xdm, kdm, or gdm) displays a graphical login prompt.
When a user logs on, it subsequently starts the favorite window manager of that user, just as with
startx.
Uempty
Keywords
• Graphical User Interface (GUI)
• X Consortium
• X Windows
• X Server
• Client Server
• GNOME
• KDE
These keywords are provided as a reminder of key subjects discussed in this unit.
Uempty
Unit summary
• List the main components of the X Window System
• List the function of the X Server
• List the function of a window manager
• List the main characteristics of desktop environments
• Switch between GNOME and KDE
Uempty
Review questions
1. True or false: The main configuration file of KDE is
/etc/X11/XF86Config.
Uempty
Review answers
1. True or false: The main configuration file of KDE is
/etc/X11/XF86Config.
The answer is false.
Uempty
Uempty
Exercise introduction
• Start X
• Work with GNOME
• Work with KDE
• List and compare various applications within GNOME and
KDE
Uempty
Overview
This unit describes the order of login scripts, explains how to modify login scripts to customize the
bash environment, and covers the tools available for customized the GUI.
Uempty
Unit objectives
• List the order of login scripts
• Modify login scripts to customize the bash environment
• List the tools available for customizing the GUI
Uempty
/etc/profile
$HOME/.bash_profile
-or- $HOME/.bash_login
-or- $HOME/.profile
$HOME/.bash_logout
Customizing the user environment © Copyright IBM Corporation 2001, 2018
The first file that shell uses at login is /etc/profile. This file contains variables specifying the
basic environment for all processes and can be changed only by the system administrator.
Furthermore, this file runs commands in your environment when you log in.
Next, the shell executes $HOME/.bash_profile. This file serves the same purpose as
/etc/profile but this file can be changed by the user. If it is not found, $HOME/.bash_login is
used, and if that file is not found, $HOME/.profile is used.
Ensure that newly created variables do not inadvertently conflict with standard variables such as
MAIL, PS1, PS2, and so forth.
Uempty
~/.bashrc
$BASH_ENV
When a shell is started, but not as a login shell, /etc/profile and ~/.bash_profile are not read.
Instead, the bash shell either uses $HOME/.bashrc (for a non-login, interactive shell, such as the
shell that runs in a terminal window) or the $BASH_ENV script (for a non-interactive shell, such as a
shell executing a shell script).
Uempty
/etc/profile.d/*.sh
$HOME/.bash_profile
export BASH_ENV=$HOME/.bashrc
$HOME/.bashrc
/etc/bashrc
$HOME/.bash_logout
Customizing the user environment © Copyright IBM Corporation 2001, 2018
On a Red Hat system, a number of extra files are called when a user starts bash.
• First, /etc/profile also calls every shell script in /etc/profile.d. To avoid confusing this
with the csh shell, only scripts with the extension .sh are called.
• In $HOME/.bash_profile, $BASH_ENV is set to $HOME/.bashrc. This ensures that a
non-interactive, non-login shell initializes itself with the $HOME/.bashrc file too.
• Then, from $HOME/.bash_profile, $HOME/.bashrc is called. This ensures that even a login
shell initializes itself with the $HOME/.bashrc file.
• $HOME/.bashrc in turn calls /etc/bashrc. This ensures that global options can be defined by
the system administrator, even for non-login and non-interactive shells.
All files mentioned are customizable. As an example, the system administrator could add scripts
that send an alert (log file entry or mail) when a user logs in our out. If you modify the shell scripts
mentioned, there are two things to be aware of:
• Make sure you do not inadvertently change standard shell variables, such as $HOME, $MAIL,
and so forth.
• An upgrade of a system might overwrite these standard shell scripts.
Uempty
$HOME/.bash_logout
Customizing the user environment © Copyright IBM Corporation 2001, 2018
SLES has also extended the bash startup flow, but differently. Here, the /etc/profile script has a
far more important function. It calls, in turn:
• All shell scripts in /etc/profile.d. Only scripts with a .sh extension are called.
• /etc/SUSEconfig/profile. This script is modified by YaST when the system configuration
changes, and should not be changed by hand.
• /etc/profile.local. This script is for local customizations.
• /etc/bash.bashrc. This script contains system-wide bash customizations that are also
applied to non-login shells.
• /etc/bash.bashrc also calls /etc/bash.bashrc.local, which can be used for local
customizations. This is not shown in the visual.
• $HOME/.bashrc. This script can obviously be modified by the user.
• $HOME/.alias. This script can also be modified by the user, and is used to define
user-specific aliases.
Obviously, after having called /etc/profile, bash also calls $HOME/.profile. This file is virtually
empty on a default SLES system, but can be modified by the user.
Uempty
KDE customization
Although the KDE configuration consists of a large number of text files as well, you do not have to
know or edit them by hand: KDE comes with a control center, which allows you to modify your
environment easily.
Uempty
GNOME customization
GNOME also comes with its own graphical configuration screens. As with KDE, your changes are
actually stored in text files which can also be modified by hand, using a text editor, such as vi, but
this is hardly ever necessary.
Uempty
Keywords
• Bash initialization
• Login shell
• /etc/profile
• $HOME/.bash_profile
• $HOME/.bashrc
• $BASH_ENV
These keywords are provided as a reminder of key subjects discussed in this unit.
Uempty
Unit summary
• List the order of login scripts
• Modify login scripts to customize the bash environment
• List the tools available for customizing the GUI
Uempty
Review questions
1. Which file would you use to customize your environment
variables, and why this file?
Uempty
Review answers
1. Which file would you use to customize your environment
variables, and why this file?
The answer is $HOME/.bash_profile because this
overwrites the defaults set in /etc/profile. If the settings
cannot be exported to subshells, the $HOME/.bashrc file
can be used.
Uempty
Uempty
Exercise introduction
• Customize the .bash_profile and .bashrc files
• Set alias definitions
• Alter umask values
Uempty
Overview
This unit discusses system management tools, installing and deinstalling additional software, and
configuring a printer, sound card, and network adapter.
Uempty
Unit objectives
• Discuss system management tools
• Install and de-install additional software
• Configure a printer
• Configure a sound card
• Configure a network adapter
Uempty
In most distributions, a workstation install takes care of configuring most of your system. In fact, in
all but a few cases you can be productive right away when your system has been installed.
There are, however, a few cases in which you need to do additional configuration to your Linux
workstation:
• Certain things were not be configured during the installation. This might be because the
distribution manufacturer left that component out altogether, or that you decided to skip that part
of the installation process.
• The attempted configuration of a certain thing failed. This typically happens to sound cards:
Trying to detect certain older types of sound cards may cause your system to hang.
• After installation, the environment in which your workstation has to operate changes. You might
be getting a new printer, or be relocated to another network, for instance.
All these factors might require you to do system configuration by hand. There is a number of ways
this can be done on a Linux system, and the following three terms are widely used in this respect.
• Temporary system administration means changing a parameter without making the change
permanent. So the next time your system reboots, the old configuration which was stored on
disk is used again. This sort of administration is for instance used when you need to connect
your laptop to another network than the network you usually connect to.
Uempty
Temporary system administration usually comes down to entering a single command which
overrides the parameters that are stored on disk.
• Manual system administration generally refers to making the configuration change on disk
yourself. As we've already seen, virtually all configuration options of a Linux system are stored
in text files somehow. Editing these files by hand, using a text editor, is called manual
administration.
Manual administration is typically done only by experienced system administrators who know
the internal layout of all these configuration files, and who understand the interactions between
the various components of a Linux system.
Manual configuration typically requires you to restart the appropriate service afterwards
manually too.
• Automated configuration means that you use some sort of system administration tool with a
menu-driven interface that makes the desired change for you. The advantage of this method is
that you don't need to know the internal layout of the configuration files, that the chance of
making errors is smaller, and that the restart of the appropriate service is taken care of too. This
makes automated configuration the ideal method for a beginning user.
There are disadvantages too to automated configuration. One is that an experienced system
administrator can usually make the desired change faster by doing a manual configuration
change than by using a system administration tool. And the other, bigger disadvantage is that
the changes you can make are limited by the capabilities of the tool. Typical system
administration tools are not written by the programmers of the service to be configured, but by
someone else. And that someone else typically does not support all configuration options that
the programmer has built into the service.
A Linux system is highly configurable and supports a lot of services and hardware. In this unit, we're
only going to look at four of the most common system administration tasks that you encounter on a
typical workstation:
• Adding and removing software
• Configuring printers
• Configuring sound cards
• Configuring network adapters
Uempty
One of the main disadvantages of Linux as compared to commercial UNIXes as AIX, for instance,
is that there is no single, large manufacturer behind it who can force all developers to work
according to a single standard. This is particularly visible when it comes to system configuration
tools. Where for instance AIX comes with one tool, SMIT, with which you can manage the entire
system, there is no Linux distribution who can do that.
Nevertheless, there is a need for system administration tools. Various people have worked on
developing these, but all these tools had a specific, limited purpose.
There are, for instance, tools that are developed by the authors of an application, to allow
management of that particular application. Other tools are developed by distribution manufacturers
to allow basic configuration of that particular distribution. There are tools that attempt to be generic
Linux configuration tools, and there are even some tools that attempt to be generic UNIX
configuration tools.
The perfect tool, however, does not exist. Now what perfect is, is in the eyes of the beholder, but all
of the tools that present themselves as generic still suffer one major deficiency (as of now): They
currently do not motivate the author of a program to also write the configuration menus for that
program, for that particular system configuration tool. It is virtually always the author (or a team of
people working for the author) of the system configuration tool who writes the configuration menus
for a particular application. This means that the system configuration tool always lags behind,
increases the chance of errors, and limits the features that are supported by the configuration tool.
Uempty
A “perfect” administration tool should preferably work like the man command: It should have a
published interface (file format or whatever) that everybody can produce, and be available on every
Linux (or UNIX) distribution. Only then would this motivate and allow the authors of an application
to also write the configuration menus for that application, just like they are currently already doing
for manual pages.
That perfect tool is not yet available. Instead, every distribution comes with its own distribution
specific tools, and some applications have their own tools as well. This means that you have to
figure out from the information about your distribution which tools are available for you, and you
also need to figure out which tool you prefer, if multiple tools perform the same function. This unit
attempts to be a guide in that, but it can never be complete, unfortunately.
Uempty
$ rpm -e myprog
Most distributions in the market today distribute their software in RPM format* . RPM, which stands
for RPM Package Manager* , is a file format that is extremely suitable for software distribution,
because it combines the following things in one file:
Note
* In fact, the Linux Standards Base (LSB), which aims at developing a set of standards that every
distribution has to adhere to, has specified RPM to be the package distribution format.
Note
* RPM used to stand for Red Hat Package Manager. But to encourage the use of RPM by other
distributions, Red Hat has released it under the GPL and has renamed it to RPM Package
Manager. And yes, that’s a self-referencing acronym, just like GNU.
Uempty
• Copyright License
• Authors
• Build information
• Dependency information
• The files that make up the software package, grouped into programs, configuration files and
other files.
• Pre- and post-installation scripts
• Pre- and post-deinstallation scripts
• Cryptographic checksums (so the integrity of the individual files and the whole package can be
verified.)
Furthermore, all these components are automatically compressed.
When an PRM package (a file which generally ends with .rpm) is installed, the information about it
goes into a database on disk (usually /var/lib/rpm). This makes it possible to retrieve all
information about all installed packages without having to read the original RPM files.
Virtually everything you want to do with an RPM package or with the RPM database is done with
the rpm command. It is really powerful, but we only cover the most common things:
Installing additional software is done with the rpm -i command, followed by the file names of the
packages to install.
Updating software is done with the rpm -U command, followed by the package file name.
Removing software is done with the rpm -e command, followed by the package name.
Uempty
Querying already installed packages is done with the rpm -q command, followed by the package
name. If no further options are given, only the package name shows up. Adding the -i option gives
you all information about a package, while adding the -l option gives you all the files that are part
of this package. To query all packages, use the -a option and do not give a package name.
Querying not yet installed packages is done the same as querying already installed packages,
with one exception: you need to specify the -p option and the package file name instead of the
package name.
Note that there is a difference between the package file name and the package name. A package
file name typically consists of the package name, the version number and the .rpm extension like
this: <packagename>-<version>.rpm. Also note that some distributions (for example, SUSE) do not
include the version number in the package file name.
Uempty
The default distribution format for source code in the Linux community (and to a large extent, the
UNIX community as well) is not .rpm, but .tar.gz. This extension means that:
• All files have been combined into one large archive file using the tar command.
• The resulting single file has been compressed using the gzip command.
If you want to make use of these files, you need to uncompress and unpack them first. Fortunately,
GNU tar (the tar command that is available on most Linux distributions) can do all of this in one
run. The default location to perform this operation is /usr/local/src. The archive itself usually
creates its own subdirectory (/usr/local/src/<archive-version>) and stores all its files in there.
The next step is then to cd into the directory and view the documentation that the author wrote to
figure out the next steps. This is usually stored in a file called README or INSTALL. If you only
received the source code, you need to compile the software too, which usually involves running a
configuration program (./configure or make config), a compilation program (typically make) and
an installation program (make install or ./install).
Uempty
On top of rpm, both Red Hat and SUSE have created additional programs. The main functionality of
these is that they are able to communicate with Internet-based repositories. This allows you to
update to the latest level automatically, and allows you to install any prerequisite software
automatically.
yum (Yellowdog Updater, Modified) is the Red Hat tool of choice. It communicates with the Red Hat
Network (RHN), which is (amongst other things) the repository for Red Hat software. To make use
of this repository you need an RHN license.
you (YaST Online Update) is the YaST module that takes care of keeping the system up to date,
and installing new software from the SUSE repository.
Uempty
Printer configuration
• On RHEL and SLES, the printer subsystem is Common UNIX
Printing System (CUPS)
ƒ Configuration is done through lpadmin or with a browser
(http://hostname:631/) (recommended)
Printer configuration is, technically speaking, one of the most complex tasks of system
administration. The reason lies not in the configuration files itself, but in the fact that there are so
many file formats that your printer subsystem may need to handle, while your printer typically only
supports one or two. This requires the setup of elaborate filters, which detect the file format of the
file to be printed, and convert it into a format suitable for your printer.
Furthermore, printers themselves have evolved a lot in recent history: from daisy wheel printers that
supported only a single character set in a single font, to high-volume, double sided color laser
printers that support various color models.
These developments have led to a number of printer subsystems, each progressively more
complex and powerful. The printer subsystem currently in use on Red Hat and SUSE is CUPS
(Common UNIX Printing System). Other distributions might use other printing subsystems, such as
BSD, LPRng, or PPS.
CUPS is highly configurable. As with most subsystems, it can be configured by editing a series of
configuration files, but this is not recommended. Instead, you should use lpadmin to configure
CUPS, or point your browser to http://<hostname>:631. This gives you an HTTP-interface to the
cupsd daemon and is by far the easiest method of configuring CUPS.
When configured, you can submit print jobs to CUPS by using the lp command (derived from and
compatible with AT&T System V printing subsystem) or the lpr command (derived from and
Uempty
compatible with BSD printing subsystem). Graphical applications are typically compatible with
kdeprint, which means that they call kdeprint and interface with it to get the job printed. This
gives you a seamless print interface from that application.
Other useful commands are:
• lpstat and lpq: These commands show you the jobs queued to be printed.
• lpcancel and lprm: These commands allow you to cancel a print job.
Uempty
Modifies your
sndconfig /etc/modules.conf
/etc/modules.conf
Sound card support is performed by the Linux kernel itself, in the form of kernel modules* . The file
that holds the information about the modules to be loaded to support various hardware components
is /etc/modules.conf* . This file itself is not that hard to configure (it is usually only a few lines
after all), but it is hard to obtain the correct parameters (a typical sound card can be configured in a
dozen ways, depending on whether MIDE needs to be supported, or wavetables, and so forth).
Because of this, a dedicated tool is usually used.
Note
* Pieces of code that can be loaded into the kernel while the system is running to provide support
for one specific hardware component.
Note
Uempty
When your sound card has been configured, many multimedia programs can use your sound card.
The visual lists a few of these.
Uempty
Network configuration
• Need correct network module to be loaded into kernel
ƒ /etc/modules.conf or /etc/modprobe.conf
• Need to set correct IP addresses and so forth
ƒ Generally done with ifconfig command
ƒ For DHCP, dhcpcd, pump, or dhclient
• Configuration done through scripts, which are different in each
distribution
ƒ RHEL: /etc/sysconfig/network-scripts/ifcfg-eth0
ƒ SLES: /etc/sysconfig/network/ifcfg-eth0
• Use distribution-specific tool to configure
ƒ RHEL: system-config-network
ƒ SLES: YaST
• For desktop use, NetworkManager is an alternative
Uempty
NetworkManager
• NetworkManager: Framework for automatic configuration of network
parameters
• DHCP client
• Wireless networks: SSID detection, security parameters
• Support for various VPNs (Cisco, OpenVPN, PPTP)
• Components:
ƒ System Daemon
ƒ User Interface Applet
NetworkManager is a relatively new tool that has not made it into every distribution yet. It is
developed as a replacement for the previously mentioned shell scripts and configuration files. It
consists of two components: a system daemon (NetworkManager) and a user interface applet
(nm-applet).
At startup, NetworkManager automatically detects all available network adapters, and will try to
configure any network adapter for which it has sufficient information. Usually, this means that it will
only configure wired Ethernet adapters (through the use of DHCP).
Once a user logs in to the graphical interface, the NetworkManager applet (nm-applet) will be
started. This enables an icon in the system tray, through which the user can interact with the
NetworkManager daemon. The nm-applet also contacts the local keychain program for any stored
WEP/WPA keys for any detected SSIDs. With these security parameters, NetworkManager is able
to connect to a secured Wireless Access Point, and will again use DHCP to configure the IP
parameters of the adapter.
Lastly, NetworkManager has support for three different kinds of Virtual Private Networks:
• Cisco
• PPTP
• OpenVPN (IPSec)
Uempty
The configuration for these VPNs is again stored in the local keychain so that the information is
secure from other users. Through the NetworkManager applet you can configure, start and stop
these VPNs.
Uempty
Keywords
• Configuration tools
ƒ Appliction specific
ƒ Distribution specific
ƒ Generic Linux tools
• RPM
• yum
• tar.gz file
• CUPS
• yast
These keywords are provided as a reminder of key subjects discussed in this unit.
Uempty
Unit summary
• Discuss system management tools
• Install and deinstall additional software
• Configure a printer
• Configure a sound card
• Configure a network adapter
Uempty
Review questions
1. True or False: When you configure your system as a DHCP
client, you do not need to configure IP addresses, and so
forth, yourself.
Uempty
Review answers
1. True or false: When you configure your system as a DHCP client, you
do not need to configure IP addresses, and so forth, yourself.
The answer is true.
Uempty
Uempty
Exercise introduction
• Install and uninstall RPMs
• Configure a printer
• Configure a sound card
• Configure the network interface
Uempty
Overview
This unit shows you how to access Windows-based file systems, run Windows programs, access
Windows servers, and read Windows document formats.
Uempty
Unit objectives
• Access Windows-based file systems
• Run Windows programs
• Access Windows servers
• Read Windows document formats
Uempty
mounted
/ / /
/bin /lib /share /X11R6 /kde /gnome /etc /ln /tux1 /tux2 /tux3 /tux4
D: E: F:
\ \ \
\otto \pdf \doc \ibm \kde \games \tmp \ln \dir1 \dir2 \dir3 \dir4
In most cases where people integrate Linux in a Windows environment, dual-boot PC's are used. In
this case, data residing on a certain partition has to be read both by Windows and by Linux.
Because Windows can't handle Linux partitions, shared file systems are typically a Windows
filesystem of some sort. Depending on the Windows version used, and the size of the filesystem,
various file systems can be used:
• fat-12, fat-16: These are older file systems used with MS-DOS and floppy disks.
• fat-32: These are used on Windows-95 formatted hard disks.
• vfat: This is virtually identical to fat-32 but supports long file names.
• NTFS: This is used by Windows NT and later Windows versions. It is more efficient than all
FAT-based file systems, and supports Access Control Lists (ACLs). Note: NTFS support is
provided by the NTFS-3G package, which is included in most Linux distributions.
Windows partitions are, under Windows, referred to with a drive letter, followed by a colon. Drives
A: and B: are floppy disks, and drive letters C: and up are hard disk partitions. Linux partitions are
not accessed by drive letters, but are mounted into one big, hierarchical file system. The content of
the floppy disk can therefore be found under /mnt/floppy, for instance.
To access Windows file systems under Linux, there are basically two options:
• Mounting the partition into the Linux file system
• Using mtools to access the file systems by drive letters
Uempty
...or
# mount -t ntfs /dev/hda1 /mnt/winC
Because the Linux kernel supports virtually all Windows file systems, it can simply mount the file
system into the Linux virtual filesystem structure. This is done with the mount command.
If you want the mount to be permanent, you should add an entry for it to the /etc/fstab file. The –t
option specifies specifically which filesystem type to expect when mounting. If you are not sure
which filesystem to expect, you can always use the fdisk –l command to list all of the know
volumes and information on each, including the detected filesystem.
Uempty
The mtools is a collection of programs that can read/write Windows file systems directly, without
mounting them, using drive letters. All commands have the same name (with an m prepended) and
the same syntax as the corresponding MS-DOS/Windows command.
The commands included in the mtools are:
• mattrib: Change MS-DOS file attribute flags.
• mbadblocks: Test a floppy disk and marks the bad blocks in the FAT.
• mcat: Dump raw disk image.
• mcd: Change MS-DOS directory.
• mcopy: Copy MS-DOS files to/from UNIX.
• mdel: Delete an MS-DOS file.
• mdeltree: Delete an MS-DOS directory tree.
• mdir: Display an MS-DOS directory.
• mdu: Display the amount of space occupied by an MS-DOS directory.
• mformat: Add an MS-DOS filesystem to a low-level formatted floppy disk.
• minfo: Print the parameters of an MS-DOS filesystem.
Uempty
• mlabel: Make an MS-DOS volume label.
• mmd: Make an MS-DOS subdirectory.
• mmount: Mount an MS-DOS disk.
• mmove: Move or rename an MS-DOS file or subdirectory.
• mpartition: Partition an MS-DOS hard disk.
• mrd: Remove an MS-DOS subdirectory.
• mren: Rename an existing MS-DOS file.
• mtoolstest: Tests and displays the mtools configuration.
• mtype: Display contents of an MS-DOS file.
• mzip: Change protection mode and eject disk on Zip/Jazz drive.
All commands use the /etc/mtools.conf file to determine the drive letter assignation.
Note that to avoid inconsistencies, drives accessed by the mtools may not be mounted!
Uempty
Every Windows program that you want to run under Linux, expects the underlying operating system
to be Windows. So you have to somehow emulate this operating system. This can be done in
roughly two ways:
• By emulating a PC and installing Windows on this emulated PC
• By emulating Windows itself.
Depending on your needs, one or both solutions can be used.
Licensing note: If you want to run Windows programs under Linux, you might need various
components (most often DLLs) from the Windows environment. If you use these components,
make sure that you have a license to use these!
Uempty
A PC emulator is a piece of software that emulates a complete PC, including a CPU, memory,
BIOS, hard disks and various other devices in software. On this emulated PC you can install
basically any PC operating system you want. The disadvantage of such a solution is that there is a
performance loss when comparing performance to running the same OS on a native PC. How large
this loss is, is dependent on a large number of factors.
PC emulator example
Bochs is an open source PC emulator that works completely in software: Every CPU instruction is
completely handled by the Bochs software. This makes it possible to run Bochs under any POSIX
compatible operating system. There is an extreme performance loss using Bochs in a production
situation is therefore only recommended for really fast workstations with really low performance
requirements regarding the Windows application.
Virtual machines takes the concept of a system emulator and expands the functionality, efficiency,
and usability. Acting in concert with a system software virtualization layer called a hypervisor, and
some special hardware features, a virtual machine can effectively partition a machine to allow for
multiple OS environments to co-exist.
VMWare is a commercial virtualization software that makes use of special features in modern
CPUs. These features allow VMWare to let the CPU itself execute most CPU instructions, instead
of emulating these CPU instructions in software.
Uempty
VMWare screenshot
The visual shows VMWare in action. When started, it opens a window, and this window is the
console to you virtual machine. Once started, the BIOS takes control and proceeds to boot the
operating system from the virtual hard disk.
Uempty
Windows emulators
• WINE (a compatibility layer) (http://www.winehq.com)
ƒ Open source product
ƒ Does not need a Windows license if only WINE or third party DLLs are
used
ƒ Can use Windows DLLs (beware of license!)
ƒ To see if your application is supported, go to Web site
• CrossOver Office (http://www.codeweavers.com)
ƒ Commercial extension to WINE
On the other side of the spectrum is the software that can emulate an operating system
environment. This solution to running Windows programs under Linux is more lightweight, therefore
impacting performance less. Most Windows emulators will require a Windows license since they
access certain proprietary DLLs. OS-level emulators have mostly fallen out of favor because of
their laborious update schedules and their loss of performance edge versus virtual machines.
Although not strictly an emulator, WINE can be grouped in this category. WINE is an open source
Windows compatibility layer, which allows you to run any Windows application without a Windows
license; however, some Windows DLLs are still needed for some functions. With native WINE, you
need to make all configuration settings to run a particular Windows application yourself.
CrossOver Office is a commercial extension to WINE, developed by CodeWeavers
(http://www.codeweavers.com). It contains all the necessary settings for a lot of Windows
applications, and that makes installation of these applications much smoother.
Uempty
WINE screenshot
The visual shows Wine in action. An application running under Wine works just like any other
application under Linux. Note that in some cases there are minor graphical glitches. Windows
application performance under Wine is generally close to native speeds.
Uempty
In a Windows environment, your data frequently resides on a Windows server, or you need to
access printers that are connected to Windows servers. To be able to do this, you need to act like a
Windows client to the server. This can be done using the client tools from the Samba product.
Samba is an open source product which implements the SMB/CIFS networking protocol. It can be
run on any UNIX machine and used to replace Windows servers, which use SMB/CIFS for common
networking. The server side of Samba is not covered in this course.
Samba includes a number of client tools, which were originally used to test the server side of
Samba, but have grown to be an excellent solution when you want to integrate Linux in a Windows
environment.
These tools are important in this respect:
• smbclient allows you to retrieve information about a Windows server, and to access files on that
server using an FTP-like interface.
• mount.cifs allows you to mount a Windows share and access it as if it were local files.
Uempty
smbclient examples
• Options
ƒ -L: Lists the shares on the server
ƒ -N: Guest access
ƒ -U: Qualified access
The smbclient tool allows you to do interact with a Windows server. The first thing is to retrieve
information about a Window server. This is done with the -L <servername> option. The -N option
allows you to set up anonymous connections, and the -U <username> or -U
<username>%<password> allows you to retrieve information as a specific user.
Note
If you use the <username>%<password> notation, you need to realize that everybody on the system
can read your password with a simple ps command! You can also access your files using smbclient.
This is done by specifying the share as //winserver/share. (Note that we are using forward
slashes here, because the backslash has a special meaning for the shell. We can use backslashes
too, but we need to escape them from the shell. The full command is then smbclient
\\\\winserver\\share -U user%pw.) When the connection has been made, we can then access
the files on the share with the ftp-style commands get, put and so forth.
Uempty
mount.cifs examples
• To mount a share as a file system:
# mount.cifs //winserver/sharename /mnt/winC
...or
# mount -t cifs //winserver/sharename /mnt/winC
The Linux kernel has support for the cifs filesystem built-in. We can therefore mount a Windows
share as any other file system. This is done with the mount.cifs command. The -o option allows
you to specify the username and password to be used.
If you want to make this permanent, you can add the share to your /etc/fstab file. It is then
automatically be mounted when your system boots. Note again that if you put the password on the
command line or in the /etc/fstab file, everybody on the system is able to see the password
through a ps command or by viewing the contents of /etc/fstab!
Note that smbclient is a command from the Samba suite, and will happily accept an IP address,
DNS hostname or NetBIOS hostname. mount.cifs will only accept an IP address or DNS
hostname, but no NetBIOS hostname.
Uempty
Most native office applications for Linux, such as OpenOffice/LibreOffice, koffice and AbiWord can
read, and in most cases also write documents in Microsoft Windows native formats. Note, however,
that not all document features might be supported. As an example, if you try to open a PowerPoint
presentation that has a video clip in it in kpresenter, the presentation is read correctly, but the video
clip does not play. This is simply because kpresenter as of yet does not have the ability to play
video clips.
At the moment, the most advanced office suite is LibreOffice. LibreOffice is a fork of OpenOffice
which happened when Oracle purchased Sun (the official owner of OpenOffice). Most OpenOffice
developers migrated to the LibreOffice development team, with the result that OpenOffice
development virtually halted.
The latest developments are that Oracle has donated the OpenOffice code to the Apache
foundation. In the future, OpenOffice might or might not merge back with the LibreOffice project.*
Note
Uempty
There are a few other programs that might be useful if you try to integrate your Linux workstation in
a Windows environment:
• rdesktop is a program that runs under Linux and allows you to connect to a Windows terminal
server. This essentially allows you to run applications on the Windows server, with the output
displayed in the rdesktop window on your Linux workstation.
• VNC (Virtual Network Computing) allows you to take over the screen of another computer. This
screen is then displayed locally on your own GUI. VNC works with virtually all operating
systems, including Linux and Windows.
• dos2unix and unix2dos are little programs that convert text files in Windows format (using the
CR/LF end-of-line standard) to UNIX format (using the single LF end-of-line standard) and vice
versa.
• cygwin is a library that implements the UNIX API, combined with a set of Linux tools, that run
under Windows. This means that all the tools that you learned how to use in this course,
including vi, are now available under Windows as well.
Uempty
Keywords
• Windows-based
• Unified file system
• drive letter separation
• primary partition
• mtools
• emulation
• WINE
• Bochs
• Xen
• KVM
• QEMU
• VMware
• VirtualBox
These keywords are provided as a reminder of key subjects discussed in this unit.
Uempty
Unit summary
• Access Windows-based file systems
• Run Windows programs
• Access Windows servers
• Read Windows document formats
Uempty
Review questions
1. True or false: To make a mount of a Windows file system
permanent, you need to add it to /etc/fstab.
Uempty
Review answers
1. True or false: To make a mount of a Windows file system
permanent, you need to add it to /etc/fstab.
The answer is true.
Uempty
Uempty
Exercise introduction
• Access Windows file systems
• Access Windows servers
backpg