We'll take a good look at disk-oriented aspects of Gentoo Linux and Linux in general, including Linux filesystems, partitions and block devices. Then, once you're familiar with the ins and outs of disks and filesystems, you'll be guided through the process of setting up partitions and filesystems for your Gentoo Linux installation.
To begin, we'll introduce
The block devices above represent an abstract interface to the disk. User programs can use these block devices to interact with your disk without worrying about whether your drives are IDE, SCSI or something else. The program can simply address the storage on the disk as a bunch of contiguous, randomly-accessible 512-byte blocks.
Although it is theoretically possible to use a full disk to house your Linux
system, this is almost never done in practice. Instead, full disk block devices
are split up in smaller, more manageable block devices. On Alpha systems,
these are called
As an example we use the following slice layout:
| Slice | Description |
|---|---|
If you are interested in knowing how big a partition should be, or even how
many partitions (or volumes) you need, read on. Otherwise continue now with
The number of partitions is highly dependent on your environment. For instance,
if you have lots of users, you will most likely want to have your
As you can see, it very much depends on what you want to achieve. Separate partitions or volumes have the following advantages:
However, multiple partitions have one big disadvantage: if not configured properly, you might result in having a system with lots of free space on one partition and none on another.
The following parts explain how to create the example slice layout described previously, namely:
| Slice | Description |
|---|---|
Change your slice layout according to your own will.
To figure out what disks you have running, use the following commands:
(For IDE disks) # dmesg | grep 'drive$'(For SCSI disks) # dmesg | grep 'scsi'
From this output you should be able to see what disks were detected and their
respective
Now fire up
# fdisk /dev/sda
We start with deleting all slices
Use
BSD disklabel command (m for help): p 8 partitions: # start end size fstype [fsize bsize cpg] a: 1 235* 234* 4.2BSD 1024 8192 16 b: 235* 469* 234* swap c: 1 5290* 5289* unused 0 0 d: 469* 2076* 1607* unused 0 0 e: 2076* 3683* 1607* unused 0 0 f: 3683* 5290* 1607* unused 0 0 g: 469* 1749* 1280 4.2BSD 1024 8192 16 h: 1749* 5290* 3541* unused 0 0 BSD disklabel command (m for help): d Partition (a-h): a
After repeating this process for all slices, a listing should show you something similar to this:
BSD disklabel command (m for help): p 3 partitions: # start end size fstype [fsize bsize cpg] c: 1 5290* 5289* unused 0 0
On Alpha based systems you don't need a separate boot partition. However, the
first cylinder cannot be used as the
We will create a swap slice starting at the third cylinder, with a total
size of 1 Gbyte. Use
BSD disklabel command (m for help): n Partition (a-p): a First cylinder (1-5290, default 1): 3 Last cylinder or +size or +sizeM or +sizeK (3-5290, default 5290): +1024M BSD disklabel command (m for help): t Partition (a-c): a Hex code (type L to list codes): 1
After these steps you should see a layout similar to the following:
BSD disklabel command (m for help): p 3 partitions: # start end size fstype [fsize bsize cpg] a: 3 1003 1001 swap c: 1 5290* 5289* unused 0 0
We will now create the root slice, starting from the first cylinder
Another problem is that there is currently a bug in
When the partition is created, we change the type to
D disklabel command (m for help): n Partition (a-p): b First cylinder (1-5290, default 1): 1004 Last cylinder or +size or +sizeM or +sizeK (1004-5290, default 5290): 5289 BSD disklabel command (m for help): t Partition (a-c): b Hex code (type L to list codes): 8
Your slice layout should now be similar to this:
BSD disklabel command (m for help): p 3 partitions: # start end size fstype [fsize bsize cpg] a: 3 1003 1001 swap b: 1004 5289 4286 ext2 c: 1 5290* 5289* unused 0 0
Save
Command (m for help): w
Now that your slices are created, you can now continue with
Now that your partitions are created, it is time to place a filesystem on them.
If you don't care about what filesystem to choose and are happy with what we use
as default in this handbook, continue with
Several filesystems are available. Most of them are found stable on the Alpha architecture.
ext2 is the tried and true Linux filesystem but doesn't have metadata journaling, which means that routine ext2 filesystem checks at startup time can be quite time-consuming. There is now quite a selection of newer-generation journaled filesystems that can be checked for consistency very quickly and are thus generally preferred over their non-journaled counterparts. Journaled filesystems prevent long delays when you boot your system and your filesystem happens to be in an inconsistent state.
ext3 is the journaled version of the ext2 filesystem, providing metadata journaling for fast recovery in addition to other enhanced journaling modes like full data and ordered data journaling. ext3 is a very good and reliable filesystem. It has an additional hashed b-tree indexing option that enables high performance in almost all situations. In short, ext3 is an excellent filesystem.
ReiserFS is a B*-tree based filesystem that has very good overall performance and greatly outperforms both ext2 and ext3 when dealing with small files (files less than 4k), often by a factor of 10x-15x. ReiserFS also scales extremely well and has metadata journaling. As of kernel 2.4.18+, ReiserFS is solid and usable as both general-purpose filesystem and for extreme cases such as the creation of large filesystems, the use of many small files, very large files and directories containing tens of thousands of files.
XFS is a filesystem with metadata journaling which comes with a robust feature-set and is optimized for scalability. We only recommend using this filesystem on Linux systems with high-end SCSI and/or fibre channel storage and an uninterruptible power supply. Because XFS aggressively caches in-transit data in RAM, improperly designed programs (those that don't take proper precautions when writing files to disk and there are quite a few of them) can lose a good deal of data if the system goes down unexpectedly.
JFS is IBM's high-performance journaling filesystem. It has recently become production-ready and there hasn't been a sufficient track record to comment positively nor negatively on its general stability at this point.
To create a filesystem on a partition or volume, there are tools available for each possible filesystem:
| Filesystem | Creation Command |
|---|---|
For instance, to have the root partition (
# mke2fs -j /dev/sdab
Now create the filesystems on your newly created partitions (or logical volumes).
# mkswap /dev/sdaa
To activate the swap partition, use
# swapon /dev/sdaa
Create and activate the swap now.
Now that your partitions are initialized and are housing a filesystem, it is
time to mount those partitions. Use the
# mount /dev/sdab /mnt/gentoo
We also need to mount the proc filesystem (a virtual interface with the kernel)
on
# mkdir /mnt/gentoo/proc # mount -t proc none /mnt/gentoo/proc
Now continue with