Used for displaying or manipulating disk partition tables
Synopsis:
```
Usage:
sfdisk [options] <dev> [[-N] <part>]
sfdisk [options] <command>
Commands:
-A, --activate <dev> [<part> ...] list or set bootable (P)MBR partitions
-d, --dump <dev> dump partition table (usable for later input)
-J, --json <dev> dump partition table in JSON format
-g, --show-geometry [<dev> ...] list geometry of all or specified devices
-l, --list [<dev> ...] list partitions of each device
-F, --list-free [<dev> ...] list unpartitioned free areas of each device
-r, --reorder <dev> fix partitions order (by start offset)
-s, --show-size [<dev> ...] list sizes of all or specified devices
-T, --list-types print the recognized types (see -X)
-V, --verify [<dev> ...] test whether partitions seem correct
--delete <dev> [<part> ...] delete all or specified partitions
--part-label <dev> <part> [<str>] print or change partition label
--part-type <dev> <part> [<type>] print or change partition type
--part-uuid <dev> <part> [<uuid>] print or change partition uuid
--part-attrs <dev> <part> [<str>] print or change partition attributes
--disk-id <dev> [<str>] print or change disk label ID (UUID)
--relocate <oper> <dev> move partition header
```
```
Usage: dosfsck [OPTIONS] DEVICE
Options:
-a automatically repair the filesystem
-A toggle Atari variant of the FAT filesystem
-b make read-only boot sector check
-c N use DOS codepage N to decode short file names (default: 850)
-d PATH drop file with name PATH (can be given multiple times)
-f salvage unused chains to files
-F NUM specify FAT table NUM used for filesystem access
-l list path names
-n no-op, check non-interactively without changing
-p same as -a, for compat with other *fsck
-r interactively repair the filesystem (default)
-S disallow spaces in the middle of short file names
-t test for bad clusters
-u PATH try to undelete (non-directory) file that was named PATH (can be
given multiple times)
-U allow only uppercase characters in volume and boot label
-v verbose mode
-V perform a verification pass
--variant=TYPE handle variant TYPE of the filesystem
-w write changes to disk immediately
-y same as -a, for compat with other *fsck
--help print this message
```
Used for creating MS-DOS (FAT12, FAT16 and FAT32) file system in Linux
Synopsis:
```
Usage: mkdosfs [OPTIONS] TARGET [BLOCKS]
Options:
-a Disable alignment of data structures
-A Toggle Atari variant of the filesystem
-b SECTOR Select SECTOR as location of the FAT32 backup boot sector
-c Check device for bad blocks before creating the filesystem
-C Create file TARGET then create filesystem in it
-D NUMBER Write BIOS drive number NUMBER to boot sector
-f COUNT Create COUNT file allocation tables
-F SIZE Select FAT size SIZE (12, 16 or 32)
-g GEOM Select disk geometry: heads/sectors_per_track
-h NUMBER Write hidden sectors NUMBER to boot sector
-i VOLID Set volume ID to VOLID (a 32 bit hexadecimal number)
-I Ignore and disable safety checks
-l FILENAME Read bad blocks list from FILENAME
-m FILENAME Replace default error message in boot block with contents of FILENAME
-M TYPE Set media type in boot sector to TYPE
.........
```
View and manipulate (add, remove and modify) disk partition tables
Synopsis:
```
Usage:
fdisk [options] <disk> change partition table
fdisk [options] -l [<disk>...] list partition table(s)
Display or manipulate a disk partition table.
Options:
-b, --sector-size <size> physical and logical sector size
-B, --protect-boot don't erase bootbits when creating a new label
-c, --compatibility[=<mode>] mode is 'dos' or 'nondos' (default)
-L, --color[=<when>] colorize output (auto, always or never) colors are enabled by default
-l, --list display partitions and exit
-x, --list-details like --list but with more details
-n, --noauto-pt don't create default partition table on empty devices
-o, --output <list> output columns
-t, --type <type> recognize specified partition table type only
-u, --units[=<unit>] display units: 'cylinders' or 'sectors' (default)
-s, --getsz display device size in 512-byte sectors [DEPRECATED]
--bytes print SIZE in bytes rather than in human readable format
--lock[=<mode>] use exclusive device lock (yes, no or nonblock)
-w, --wipe <mode> wipe signatures (auto, always or never)
-W, --wipe-partitions <mode> wipe signatures from new partitions (auto, always or never)
-C, --cylinders <number> specify the number of cylinders
-H, --heads <number> specify the number of heads
-S, --sectors <number> specify the number of sectors per track
```
Used for checking and repairing Linux file systems. Actually a wrapper to several other file system specific utilities (e.g. fsck.ext3, fsck.ext2 and so on).
Synopsis:
```
Usage:
fsck [options] -- [fs-options] [<filesystem> ...]
Check and repair a Linux filesystem.
Options:
-A check all filesystems
-C [<fd>] display progress bar; file descriptor is for GUIs
-l lock the device to guarantee exclusive access
-M do not check mounted filesystems
-N do not execute, just show what would be done
-P check filesystems in parallel, including root
-R skip root filesystem; useful only with '-A'
-r [<fd>] report statistics for each device checked;
file descriptor is for GUIs
-s serialize the checking operations
-T do not show the title on startup
-t <type> specify filesystem types to be checked;
<type> is allowed to be a comma-separated list
-V explain what is being done
```
Used for adjusting tunable file system parameters on ext2/ext3/ext4 file systems. The filesystem must not be mounted write when this operation is performed.
In this exercise you will create additional partitions on your hard disk. During the initial installation you left some free space. You will create partitions on this space.
Partitioning a disk allows the disk to be regarded as a group of independent storage areas.
Partitions also make backups easier and help to restrict and confine potential problem areas.
Hard disk space is not infinite and one of your duties administrator is managing the available finite space. For instance, a simple way to restrict the total storage area on a disk where users can store their personal files is to create a separate partition for the users’ home directory (quotas can also be used).
From the sample output above under the Used column, you can see that the primary partition ( /dev/vda1) on which our root (/) directory is mounted on is completely (100%) filled up.
Your output might be different if you have a different sized disk or if you didn’t follow the partitioning scheme used during the OS install.
We don't want you to accidentally alter the local hard disk on your system and make it inoperable, so we'll complete the following exercises on a pseudo-device that behaves and mimics an actual block device. This will be done by creating a reasonably sized [sparse] file and associating it with a pseudo-device. On Linux systems, these pseudo-devices are referred to as loop devices. A loop device is a pseudo-device that makes it possible to treat [and access] a regular data file as if it were a block device.
(This step is roughly equal to the same decisions you must make about purchasing actual disks/storage for a server. Decisions like - type, make, size, interface, form-factor and so on)
While still logged into the system as the root user, use the losetup utility to create a sparse 10GB file. Type:
You will create a new partition using the fdisk program. fdisk runs interactively, so you'll have many question-and-answer style prompts to complete specific tasks.
Start by passing the name of the loop block device as an argument to the fdisk. Type:
The new partition you created is the one on /dev/loop0p1 above. You will notice that the partition type is “83”.
Everything looks good. Write all the changes to the partition table by typing the w sub command of fdisk:
Command(mforhelp):w
You'll likely see a warning about a failure to re-read the partition table.
The wfdisk command will also exit the fdisk program and return the shell prompt.
Per the warning message you may have gotten after writing the partition table to disk in the previous step, you may sometimes need to take extra steps to urge the kernel to acknowledge the new hard disk changes. Use the partprobe command to do this:
[root@localhost~]# partprobe
Tip
When using fdisk, the default partition type for newly created partitions is Linux (0x83). You can use the fdiskt command to change the type. For example to change the partition type to the LVM (0x8e) type you would do the following:
Type t to change the partition type:
Command(mforhelp):t
Then input the hexcode (0x8e) for the LVM type partitions at the prompt:
Hexcodeoralias(typeLtolistall):8e
Write all the changes to the partition table by typing the wfdisk command:
To help demonstrate some of the subtle differences between the traditional method of managing block devices and the more modern approaches like the volume manager approach, we'll create a new pseudo-block device and attempt to prepare it (similar to partitioning) for use with a file system.
In the following steps we are going to create a new loop device backed by another regular file. And then we'll go on to setting up the device for the Logical Volume Manager (LVM) system.
While logged in as a user with administrator privileges, create a sparse 10GB file called 10G-fake-lvm-disk.img. Type:
In this section, you will learn how to assign a PV device to an existing volume group. This has the net effect of increasing the storage capacity of an existing volume group.
You'll add the /dev/loop1 physical volume (PV) that was prepped and created above to the existing rl Volume Group (VG).
Use the vgdisplay command to view the currently configured volume groups. Type:
From the output above:
- The volume group name is rl
- The size of the VG is 98.41 GiB
- There are 0 (zero) physical extents (PE) that are free in the VG, which is equivalent to 0MB of space.
Assign the new PV (/dev/loop1) to the existing rl volume group. Use the vgextend command, type:
[root@localhost~]# vgextend rl /dev/loop1
OUTPUT
Volumegroup"rl"successfullyextended
Run the vgdisplay command again to view your changes. Type:
In this section, you will create a brand new standalone volume group named "scratch". The scratch VG will get it's space entirely from the /dev/loop1 pseudo block device.
Review your vgdisplay output. What are the values for "Free PE / Size"? And how are these values different from the earlier section when you added the /dev/loop1 PV to the existing rl volume group?
With the additional free space we have been able to add to the rl volume group (VG), it is now possible to add a Logical volume that can be used to store data after formatting.
Use the lvdisplay command to view the currently configured logical volumes. Type:
[root@localhost~]# lvdisplay
Questions
From your output answer the following questions:
How many logical volumes (LVs) are defined?
What are the names of the LVs?
What are the various LVs being used for on your system?
Use the lvs command to similarly display the logical volumes, but this time filter the output to show specific fields. Filter to view the lv_name (logical volume name), lv_size (logical volume size), lv_path, vg_name (volume group name) fields. Type:
To make the traditional partition and LVM-style volumes created earlier usable by the operating system, you need to create file systems on it. Writing a file system to a device is also known as formatting the disk.
This exercise covers file system creation as well the use of some common file system maintenance tools.
To make the logical volumes that were created earlier usable by the operating system, you need to create file systems on them. Writing a file system to a device is also known as formatting the disk.
Here you will use the mke2fs program to create an EXT4 file system on the new scrtach2 volume.
Use the mkfs.ext4 utility to create an EXT4 type filesystem on the /dev/scratch/scratch2 volume. Type:
Here we will walk through the use of some common filesystem utilities that can be used in maintaining the filesystem, fixing filesystem problems, debugging filesystem issues etc.
Find out the value of the current “maximal mount count” on the scratch2 volume. Type:
The previous exercises walked through preparing a block/storage device for use on a system. After going through all the motions of partitioning, formatting and so on, the final step in making the file system available to users for storing data is known as mounting.
This exercise will cover how to mount and umount the file systems that we created in the previous exercise.
[root@localhost~]# mount /dev/loop0p1 /mnt/10gb-scratch1-partition
Use the mount command to display all VFAT file systems on the system. Use grep to filter the output for the word scratch. Type:
[root@localhost~]# mount -t vfat | grep scratch
Use the df command to view a report of the file system disk space usage on the server. Type:
[root@localhost~]# df -ht vfat | grep scratch
Use the --bind option with the mount command to make the /mnt/10gb-scratch1-partition file-system also appear under a simpler or more user friendly name/path such as /mnt/scratch1. Type:
[root@localhost~]# mount --bind /mnt/10gb-scratch1-partition /mnt/scratch1
Use the df command again to view the effect of the bind mount.
With real disk or storage devices, the previous steps will be enough to make the system automatically and correctly mount all the new file systems and apply any special mount options.
BUT, because we've been using special pseudo-block devices (loop devices) in this lab, we must complete an additional important task to ensure that the correct loop devices are automatically recreated after the system reboots.
To do this we'll create a custom systemd service unit to help with this.
Use any text editor that you are comfortable with to create the /etc/systemd/system/loopdevices.service file.
For no good reason, the user named “unreasonable” has decided to create an extremely LARGE file on a system shared with other users!!
The file has taken up a lot of space on the local hard disk.
As an administrator, you can find and delete the offending file and carry on with your day and hope it's a one time occurrence, OR you can find and delete the file to free up disk space and devise a plan to prevent a reoccurrence. We will attempt the latter solution in later exercise.
Unreasonable user accidentally notices that new scratch file systems have been made available on the server overnight. "This is great!" he says to himself.
He then proceeds to fill up the volume with an arbitrarily large file.
Log into the system as the unreasonable user.
Check the system to see if there are any new file systems that you can abuse. Type:
[unreasonable@localhost~]$df-h
Proceed immediately to fill up the available shared file system with garbage. Type
After kicking off the dd process, go for a walk and return when the command completes or when it errors out because it can’t go any further. Or go and find the Administrator and complain about the disk space being full on the system.
Explore further unreasonable/senseless/annoying things can be done on the system. You are unreasonable user.
Implementing and enforcing the use of disk quotas provides a way to ensure that the system has enough disk space and that users stay within their allotted disk space. Before implementing quotas you need to:
Decide which partitions or volumes that you want to implement disk quotas on.
Decide the level at which to enforce the quotas – i.e. per user, per group or both.
Decide what your soft and hard limits will be.
Decide what the grace periods will be (i.e. if there will be any at all).
Hard Limit
The hard limit defines the absolute maximum amount of disk space that a user or group can use. Once this limit is reached, no further disk space can be used.
Soft Limit
The soft limit defines the maximum amount of disk space that can be used. However, unlike the hard limit, the soft limit can be exceeded for a certain amount of time. That time is known as the grace period.
Grace Period
The grace period is the time during which the soft limit may be exceeded. The grace period can be expressed in seconds, minutes, hours, days, weeks, or months, thus giving the system administrator a great deal of freedom in determining how much time to give users to get their disk usage below their soft limit.
These are the high-level steps involved in implementing quotas.
You have decided to implement EXT4 style quotas on the “/dev/rl/scratch2" volume. You have also decided to implement quotas both at the user and group level.
Review the /etc/fstab file with your editor of choice. Below is the relevant entry in the file before we make any changes to the file.
As a part of implementing quotas, some new quota related mount options need to be added to the scratch2 volume entry. The scratch2 volume entry needs to be update to the new line here:
You can also check the mount options that are in use for any file system by using the mount command. For the previous example you can view the mount options for the ext4 formatted scratch2 volume by running:
[root@localhost~]# mount -t ext4 | grep scratch2
OUTPUT
/dev/mapper/scratch-scratch2 on /mnt/2gb-scratch2-volume type ext4 (rw,relatime,quota,usrquota,grpquota)
Question
Write down the commands to separately unmount a given filesystem and then mount it back?
You now need to make the file system ready to support quotas. Create the quota files and also generate the table of current disk usage per file system. Type:
After the above command has executed you will notice two new files created under the “/mnt/2gb-scratch2-volume" directory. List the files here?
Tip
To get up-to-date status of the quota file system you should run the quotacheck -avcug command periodically while quota is turned off on the file system.
To enable user and group quotas on all the file systems specified in “/etc/fstab” type:
You have decided to assign a soft limit of 90 MB and a hard limit of 100 MB for each user on the system with a grace period of 5 minutes.
This means that all users for which we apply the quota cannot exceed the hard limit of 100 MB, but they have about 5 minutes to exceed their soft limit of 90 MB but still stay under their hard limit.
You will create the limits using a prototype user. The user called “me” will be your prototype user. Use the edquota command to create the limits. Type:
[root@serverXYroot]# edquota -u me
The above command will bring up your default editor with the contents below:
From the output above under the grace column for user unreasonable, how much grace period does the user have left?
From the report, you notice that unreasonable user has exceeded their quota limits on the server. You search for the offending file and help unreasonable user "clean it up" and get them back in compliance. Type:
Use the su command to temporarily assume the identity of the unreasonable user and try creating additional files or directories as that user. Type:
[root@localhost~]# su - unreasonable
While logged on as the user unreasonable, you check and notice that the /mnt/2gb-scratch2-volume/LARGE-USELESS-FILE.tar file that you created in a previous exercise is missing! Irritated you decide to create it again. Type:
Frustrated with ignorance the unreasonable user types:
[unreasonable@localhost~]$manquota
Note
The “unreasonable” user will be forced to do something about the “LARGE-USELESS-FILE.tar” that he created. Until that user brings his total file size under his limit he will not be able to do a whole lot else.