OS Lab - Week 3
OS Lab - Week 3
OS Lab - Week 3
Package management is a method of installing and maintaining software on the system. Today, most
people can satisfy all of their software needs by installing packages from their Linux distributor. This contrasts
with the early days of Linux, when one had to download and compile source code to install software. There
isn’t anything wrong with compiling source code; in fact, having access to source code is the great wonder of
Linux. It gives us (and everybody else) the ability to examine and improve the system. It's just that having a
precompiled package is faster and easier to deal with.
Packaging Systems
Different distributions use different packaging systems, and as a general rule, a package intended for one
distribution is usually not compatible with another distribution.
Most distributions fall into one of two camps of packaging technologies: the Debian .deb camp and the Red
Hat .rpm camp.
Managing Linux Software
Package Files
The basic unit of software in a packaging system is the package file. A package file is a compressed collection
of files that comprise the software package. A package may consist of numerous programs and data files that
support the programs. In addition to the files to be installed, the package file also includes metadata about
the package, such as a text description of the package and its contents.
Repositories
While some software projects choose to perform their own packaging and distribution, most packages today
are created by the distribution vendors and interested third parties. Packages are made available to the users
of a distribution in central repositories that may contain many thousands of packages, each specially built and
maintained for the distribution.
Dependencies
Programs are seldom “standalone”; rather they rely on the presence of other software components to get
their work done. Common activities, such as input/output for example, are handled by routines shared by
many programs. These routines are stored in what are called shared libraries, which provide essential services
Managing Linux Software
High and Low-level Package Tools
Package management systems usually consist of two types of tools:
1. Low-level tools which handle tasks such as installing and removing package files
2. High-level tools that perform metadata searching and dependency resolution
Syntax:
dpkg [options] [package]
● List all installed packages, along with package version and short
description : dpkg -l
Syntax:
apt [options] [package]
User accounts can belong to one or more groups. Typically, each username has a corresponding private group
name. By default, each user belongs to that corresponding private group, but you can define other groups for
the purpose of providing access to specific files and directories based on group membership.
User and group ownerships of files ensure that only the right people (or the right processes) can access
certain files and directories. Managing the user and group accounts is a typical task in system administration.
It’s not hard to do this part of the job, given the tools that come with Linux, as you discover in this chapter.
Important files
Syntax:
useradd [options]
● Create new user then add the user to the specified group: useradd -G
newGroup
● Create a user with a short description about it (usually used for the
full name : useradd -c Example
Command: passwd
passwd command in Linux is used to change the user account passwords. The root
user reserves the privilege to change the password for any user on the system, while
a normal user can only change the account password for his or her own account.
Syntax:
passwd [options] [username]
Syntax:
usermod [options] [username]
● Lock the user’s password, preventing it from being used for login:
usermod -L user
Syntax:
userdel [options] [username]
● Delete a user account from the system and remove the user’s home
directory: userdel -r user
● Force delete a user account even in the account is logged in, implies -
f : userdel -f user
Command: su
su is a command used to switch to another user.
Syntax:
su [options] [username]
● Switch to another user with the new user default login environment:
su - user
Syntax:
groupadd [options] [group name]
Syntax:
groupdel [group name]
What exactly does this mean? It means that more than one person can be using the computer at the same
time. While a typical computer will likely have only one keyboard and monitor, it can still be used by more
than one user. For example, if a computer is attached to a network or the Internet, remote users can login via
ssh (secure shell) and operate the computer.
The multi-user capability of Linux is not a recent "innovation," but rather a feature that is deeply embedded
into the design of the operating system. Considering the environment in which Unix was created, this makes
perfect sense.
Years ago, before computers were "personal," they were large, expensive, and centralized. A typical university
computer system, for example, consisted of a large central computer located in one building and terminals
that were located throughout the campus, each connected to the large central computer. The computer would
support many users at the same time. To make this practical, a method had to be devised to protect the users
from each other. After all, the actions of one user could not be allowed to crash the computer, nor could one
user interfere with the files belonging to another user.
Owners, Group Members, and
Everybody Else
In the Unix security model, a user may own files and directories. When a user owns a file or directory, the user
has control over its access. Users can, in turn, belong to a group consisting of one or more users who are
given access to files and directories by their owners. In addition to granting access to a group, an owner may
also grant some set of access rights to everybody, which in Unix terms is referred to as the world.
When user accounts are created, users are assigned a number called a user ID (uid) which is then, for the
sake of the humans, mapped to a username. The user is assigned a primary group ID (gid) and may belong to
additional groups.
User accounts are defined in the /etc/passwd file and groups are defined in the /etc/group file. When user
accounts and groups are created, these files are modified along with /etc/shadow which holds information
about the user's password. For each user account, the /etc/passwd file defines the user (login) name, uid, gid,
account's real name, home directory, and login shell. If we examine the contents of /etc/passwd and
/etc/group, we notice that besides the regular user accounts, there are accounts for the superuser (uid 0) and
various other system users.
While many Unix-like systems assign regular users to a common group such as “users”, modern Linux
practice is to create a unique, single-member group with the same name as the user. This makes certain
types of permission assignment easier.
Reading, Writing, and Executing
Access rights to files and directories are defined in terms of read access, write access, and execution access.
If we look at the output of the ls command, we can get some clue as to how this is implemented:
root@lwd:/tmp# ls -l file1.txt
-rw-r--r-- 1 root root 0 Oct 13 22:41 file1.txt
The first 10 characters of the listing are the file attributes. The first of these characters is the file type (File,
Directory, Symbolic Link, Character Special file or block special file)
The remaining nine characters of the file attributes, called the file mode, represent the read, write, and
execute permissions for the file's owner, the file's group owner, and everybody else.
Attribut
Files Directories
e
Syntax:
chmod [reference][operator][mode] file...
● Let’s change the file.txt permission so that the owner cannot write(w)
in the file but can only read it: chmod u=r file.txt
● Let’s restrict the permission such that the user cannot search the
directory CLASS: chmod u=rw CLASS
● Let’s change the file.txt permission so that the owner can execute it:
chmod u+x file.txt
● Let’s give owner full permissions on file.txt will limiting the group and
others to read only: chmod 744 file.txt
Command: chmod
Command: chown
chown command is used to change the file Owner or group. Whenever you want to
change ownership you can use chown command.
Syntax:
chown [OPTION]… [OWNER][:[GROUP]] FILE…