mirror of
https://github.com/LCTT/TranslateProject.git
synced 2025-01-25 23:11:02 +08:00
136 lines
7.1 KiB
Markdown
136 lines
7.1 KiB
Markdown
|
[#]: collector: (lujun9972)
|
|||
|
[#]: translator: ( )
|
|||
|
[#]: reviewer: ( )
|
|||
|
[#]: publisher: ( )
|
|||
|
[#]: url: ( )
|
|||
|
[#]: subject: (InitRAMFS, Dracut, and the Dracut Emergency Shell)
|
|||
|
[#]: via: (https://fedoramagazine.org/initramfs-dracut-and-the-dracut-emergency-shell/)
|
|||
|
[#]: author: (Gregory Bartholomew https://fedoramagazine.org/author/glb/)
|
|||
|
|
|||
|
InitRAMFS, Dracut, and the Dracut Emergency Shell
|
|||
|
======
|
|||
|
|
|||
|
![][1]
|
|||
|
|
|||
|
The [Linux startup process][2] goes through several stages before reaching the final [graphical or multi-user target][3]. The initramfs stage occurs just before the root file system is mounted. Dracut is a tool that is used to manage the initramfs. The dracut emergency shell is an interactive mode that can be initiated while the initramfs is loaded.
|
|||
|
|
|||
|
This article will show how to use the dracut command to modify the initramfs. Some basic troubleshooting commands that can be run from the dracut emergency shell will also be demonstrated.
|
|||
|
|
|||
|
### The InitRAMFS
|
|||
|
|
|||
|
[Initramfs][4] stands for Initial Random-Access Memory File System. On modern Linux systems, it is typically stored in a file under the /boot directory. The kernel version for which it was built will be included in the file name. A new initramfs is generated every time a new kernel is installed.
|
|||
|
|
|||
|
![A Linux Boot Directory][5]
|
|||
|
|
|||
|
By default, Fedora keeps the previous two versions of the kernel and its associated initramfs. This default can be changed by modifying the value of the _installonly_limit_ setting the /etc/dnf/dnf.conf file.
|
|||
|
|
|||
|
You can use the _lsinitrd_ command to list the contents of your initramfs archive:
|
|||
|
|
|||
|
![The LsInitRD Command][6]
|
|||
|
|
|||
|
The above screenshot shows that my initramfs archive contains the _nouveau_ GPU driver. The _modinfo_ command tells me that the nouveau driver supports several models of NVIDIA video cards. The _lspci_ command shows that there is an NVIDIA GeForce video card in my computer’s PCI slot. There are also several basic Unix commands included in the archive such as _cat_ and _cp_.
|
|||
|
|
|||
|
By default, the initramfs archive only includes the drivers that are needed for your specific computer. This allows the archive to be smaller and decreases the time that it takes for your computer to boot.
|
|||
|
|
|||
|
### The Dracut Command
|
|||
|
|
|||
|
The _dracut_ command can be used to modify the contents of your initramfs. For example, if you are going to move your hard drive to a new computer, you might want to temporarily include all drivers in the initramfs to be sure that the operating system can load on the new computer. To do so, you would run the following command:
|
|||
|
|
|||
|
```
|
|||
|
# dracut --force --no-hostonly
|
|||
|
```
|
|||
|
|
|||
|
The _force_ parameter tells dracut that it is OK to overwrite the existing initramfs archive. The _no-hostonly_ parameter overrides the default behavior of including only drivers that are germane to the currently-running computer and causes dracut to instead include all drivers in the initramfs.
|
|||
|
|
|||
|
By default dracut operates on the initramfs for the currently-running kernel. You can use the _uname_ command to display which version of the Linux kernel you are currently running:
|
|||
|
|
|||
|
```
|
|||
|
$ uname -r
|
|||
|
5.0.5-200.fc29.x86_64
|
|||
|
```
|
|||
|
|
|||
|
Once you have your hard drive installed and running in your new computer, you can re-run the dracut command to regenerate the initramfs with only the drivers that are needed for the new computer:
|
|||
|
|
|||
|
```
|
|||
|
# dracut --force
|
|||
|
```
|
|||
|
|
|||
|
There are also parameters to add arbitrary drivers, dracut modules, and files to the initramfs archive. You can also create configuration files for dracut and save them under the /etc/dracut.conf.d directory so that your customizations will be automatically applied to all new initramfs archives that are generated when new kernels are installed. As always, check the man page for the details that are specific to the version of dracut you have installed on your computer:
|
|||
|
|
|||
|
```
|
|||
|
$ man dracut
|
|||
|
```
|
|||
|
|
|||
|
### The Dracut Emergency Shell
|
|||
|
|
|||
|
![The Dracut Emergency Shell][7]
|
|||
|
|
|||
|
Sometimes something goes wrong during the initramfs stage of your computer’s boot process. When this happens, you will see “Entering emergency mode” printed to the screen followed by a shell prompt. This gives you a chance to try and fix things up manually and continue the boot process.
|
|||
|
|
|||
|
As a somewhat contrived example, let’s suppose that I accidentally deleted an important kernel parameter in my boot loader configuration:
|
|||
|
|
|||
|
```
|
|||
|
# sed -i 's/ rd.lvm.lv=fedora\/root / /' /boot/grub2/grub.cfg
|
|||
|
```
|
|||
|
|
|||
|
The next time I reboot my computer, it will seem to hang for several minutes while it is trying to find the root partition and eventually give up and drop to an emergency shell.
|
|||
|
|
|||
|
From the emergency shell, I can enter _journalctl_ and then use the **Space** key to page down though the startup logs. Near the end of the log I see a warning that reads “/dev/mapper/fedora-root does not exist”. I can then use the _ls_ command to find out what does exist:
|
|||
|
|
|||
|
```
|
|||
|
# ls /dev/mapper
|
|||
|
control fedora-swap
|
|||
|
```
|
|||
|
|
|||
|
Hmm, the fedora-root LVM volume appears to be missing. Let’s see what I can find with the lvm command:
|
|||
|
|
|||
|
```
|
|||
|
# lvm lvscan
|
|||
|
ACTIVE '/dev/fedora/swap' [3.85 GiB] inherit
|
|||
|
inactive '/dev/fedora/home' [22.85 GiB] inherit
|
|||
|
inactive '/dev/fedora/root' [46.80 GiB] inherit
|
|||
|
```
|
|||
|
|
|||
|
Ah ha! There’s my root partition. It’s just inactive. All I need to do is activate it and exit the emergency shell to continue the boot process:
|
|||
|
|
|||
|
```
|
|||
|
# lvm lvchange -a y fedora/root
|
|||
|
# exit
|
|||
|
```
|
|||
|
|
|||
|
![The Fedora Login Screen][8]
|
|||
|
|
|||
|
The above example only demonstrates the basic concept. You can check the [troubleshooting section][9] of the [dracut guide][10] for a few more examples.
|
|||
|
|
|||
|
It is possible to access the dracut emergency shell manually by adding the _rd.break_ parameter to your kernel command line. This can be useful if you need to access your files before any system services have been started.
|
|||
|
|
|||
|
Check the _dracut.kernel_ man page for details about what kernel options your version of dracut supports:
|
|||
|
|
|||
|
```
|
|||
|
$ man dracut.kernel
|
|||
|
```
|
|||
|
|
|||
|
--------------------------------------------------------------------------------
|
|||
|
|
|||
|
via: https://fedoramagazine.org/initramfs-dracut-and-the-dracut-emergency-shell/
|
|||
|
|
|||
|
作者:[Gregory Bartholomew][a]
|
|||
|
选题:[lujun9972][b]
|
|||
|
译者:[译者ID](https://github.com/译者ID)
|
|||
|
校对:[校对者ID](https://github.com/校对者ID)
|
|||
|
|
|||
|
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创编译,[Linux中国](https://linux.cn/) 荣誉推出
|
|||
|
|
|||
|
[a]: https://fedoramagazine.org/author/glb/
|
|||
|
[b]: https://github.com/lujun9972
|
|||
|
[1]: https://fedoramagazine.org/wp-content/uploads/2019/04/dracut-816x345.png
|
|||
|
[2]: https://en.wikipedia.org/wiki/Linux_startup_process
|
|||
|
[3]: https://access.redhat.com/documentation/en-us/red_hat_enterprise_linux/7/html/system_administrators_guide/sect-managing_services_with_systemd-targets
|
|||
|
[4]: https://en.wikipedia.org/wiki/Initial_ramdisk
|
|||
|
[5]: https://fedoramagazine.org/wp-content/uploads/2019/04/boot.jpg
|
|||
|
[6]: https://fedoramagazine.org/wp-content/uploads/2019/04/lsinitrd.jpg
|
|||
|
[7]: https://fedoramagazine.org/wp-content/uploads/2019/04/dracut-shell.jpg
|
|||
|
[8]: https://fedoramagazine.org/wp-content/uploads/2019/04/fedora-login-1024x768.jpg
|
|||
|
[9]: http://www.kernel.org/pub/linux/utils/boot/dracut/dracut.html#_troubleshooting
|
|||
|
[10]: http://www.kernel.org/pub/linux/utils/boot/dracut/dracut.html
|