This is the 14th day of my participation in the August More Text Challenge
Here are my study notes for learning Linux from the ground up, which will be updated later.
Record their own technology growth, also hope to share with you, welcome to follow ~
This is a study note for Linux for Developers on Coursera
Learning goals
- Understand how the system boots, the role of GRUB and the contents of the /boot directory
- Discuss the next steps of launching essential functions using systemd and its predecessors, SysVinit and Upstart
- Kill the graphical desktop interface and enter a pure text-based terminal
- Analyze memory usage and the role of swap space, and how the system reacts to running out of memory
- Discuss how the system works with network devices and how they are identified and named
- Configure and bring up or down network interfaces and networks
In this module, let’s discuss some of the important components of the system. In particular, we’re going to talk about system initialization, we’re going to talk about memory, we’re going to talk about network interfaces.
When the system starts up, it goes through several phases. The first is your early boot phase, which is quite hardware dependent and involves booting the Linux kernel. On most Linux systems, this involves using something called GRUB, which allows you to select other operating systems, kernel options, and so on at boot time. On an embedded system, you will perform other operations, such as Das U-boot. The next phase has to do with the actual initialization of various system services, which is really a matter of system administration rather than early startup. The second thing we’re going to talk about is memory. We want to talk about how your system uses memory and what to do when you run out of memory and have to use what’s called swap space. At this point, you may find your OOM killer called, which determines how transactions are handled when there is no Memory available. The third thing we’re going to talk about is networking and networking devices. We want to talk about how to enable network devices, make sure they go up or down as needed and how to name them. So let’s start with these three themes.
A. The System Initialization
1. The system starts
All x86-based physical Linux systems (including laptops, most workstations, etc.) use a software system called GRUB, which stands for GRand Unified Bootloader and handles the earliest stages of system boot. GRUB now has a number of important features that you can boot to other operating systems, selecting at boot time. This is called a boot loader.
There may be one computer with Windows, one computer with more than one Linux distribution, one Red Hat, one Ubuntu, one Debian, and so on. Therefore, you can choose at the beginning. On a given operating system, you can choose which kernel to boot, use the other initial Ramdisks discussed later, and specify different options for the system. In addition, if desired, you can change what happens when the system starts up by entering an interactive system that allows you to change the options and other variables used when the system starts up without actually changing the configuration file on the computer.
In GRUB 2, there is really only one configuration file, which in the important boot directory is called “grub.cfg”. The exact location depends on your system type. Under “/etc/grub.d,” there are a number of files that control how GRUB works, and under “/etc/default,” there is one called “grub,” which contains the basic parameters required for GRUB. These files can be manually edited and used to generate “grub.cfg”.
When the system boots up, it starts with what’s called BIOS space, the basic I/O system or CMOS, which is used to identify, initialize the most important systems and connect peripherals, for example, as input to the keyboard and initial hard drive so that you can actually load the kernel. You can select options in BIOS for boot peripherals, such as USB drives **. The kernel itself can have a different name, usually “vmlinuz”, followed by a version number. ** “z” indicates that the kernel is compressed and will be uncompressed automatically upon loading.
2. The/boot directory
The/boot directory has multiple possible kernels that can be booted, each with four files associated with it:
- Vmlinuz is a compressed kernel
- Initramfs contains a complete initial root file system (loaded as a ramdisk), along with the necessary kernel modules (usually device drivers) and the programs needed to load them, which are then discarded when the actual file system is loaded
- Config contains all the details about how the kernel is compiled; Not required for system operation
- System.map lists the complete kernel symbol table; It is used for debugging purposes only
3. Using GRUB (demo)
We will demonstrate how to use GRUB to select a different operating system. Let’s start a CentOS 7 VIRTUAL machine using VMWare.
You can select the kernel to boot from the GRUB screen. You can choose whether to enter the centos system on the graphical interface.
I use the following method:
To set the default startup mode of the centos system as user root, run the following command:
Target // Set the command mode to systemctl set-default graphical. Target // Set the command mode to graphicalCopy the code
Restart the system.
4. Initialize the system
We’ll consider what happens after the kernel starts and the system starts running. The first program you run on your system is called init. Typically, it has a process ID of 1, with subsequent processes having a higher process ID. How long it takes to start up is very important.
In SystemV initialization systems, there are different runlevels from 0 to 6. We’ll show you a table that defines them in detail. But a complete graphics system is generally considered runlevel 5. Run level 1 is single-user or emergency mode. For servers without a graphical interface, the default level is usually 3. This is for special purposes, for example, when only one user is there to repair the system.
You can simply display the current runlevel using the runlevel command, as shown below:
Some distributions retain the concept of runlevels defined according to systemd goals, so you can use commands such as telinit. Telinit can be used to change the running level of the system. For example, to move from runlevel 3 to runlevel 5, type:
$ sudo /sbin/telinit 5
Copy the code
2. The Memory
1. The memory
Linux, like all modern operating systems, uses a virtual memory system (VM) : virtual memory is greater than physical memory.
Each process has its own protected address space. Addresses are virtual, and the kernel must translate them to physical addresses whenever a process needs to access memory. ** The kernel itself also uses virtual addresses. ** However, conversions can be as simple as offsets, depending on the architecture and the type of memory used. The kernel allows a fair share of memory to be allocated to each running process and coordinates the timing of memory sharing between processes. In addition, maps can be used to link files directly to a process’s virtual address space.
Use free-m or free-mt to check memory usage (in MB)
This system has 972M of RAM and 511m of swap, and a lot of the memory that is being used is in the cache, most of which is used to cache the contents of recently accessed files. If this cache is released, memory usage is greatly reduced. This can be done (as root) by:
2. Release memory
Because the system already manages the memory very well. Sometimes, the memory will be used up by cache, affecting the system performance. For example, if you frequently access files in Linux, the physical memory will be used up quickly. After the program ends, the memory will not be released, but continues as caching. At this point, the operation of freeing memory (clearing the cache) needs to be performed. You can manually free memory:
sudo sh -c 'echo 1 > /proc/sys/vm/drop_caches'
sudo sh -c 'echo 2 > /proc/sys/vm/drop_caches'
sudo sh -c 'echo 3 > /proc/sys/vm/drop_caches'
Copy the code
1: release the page cache. 2: release dentries and inodes. 3: release all caches
If we need to release all caches, enter the following command: echo 3 > /proc/sys/vm-drop_caches
The results after release are as follows:
** Applications cannot write directly to storage media such as disks. They connect to a virtual memory system and typically first place written blocks of data into a cache or buffer and then flush them to disk when convenient or necessary. ** Therefore, on most systems, more memory is used in this buffer/cache layer than is used directly by the application for other purposes.
3.swap
Linux employs a virtual memory system in which the operating system can operate as if it actually has more memory. This memory overuse works in two ways:
One: many programs do not use all the memory they are granted permission to use. Sometimes this is because the child process inherits a copy of the parent’s memory region using COW (copy-on-write) techniques, in which the child process only gets a unique copy (page by page) if there are changes.
Another: When memory stress becomes important, less active memory areas can be swapped out to disk so that they can be called again only when needed. This exchange is typically for one or more dedicated partitions or files; Linux allows for multiple swap areas, so requirements can be adjusted dynamically. Each region has a priority, and the lower priority region is not used until the higher priority region is populated.
You can run the following command to query the swappable area:
[root@localhost ayuan]# cat /proc/swaps
Filename Type Size Used Priority
/dev/sda2 partition 524284 7432 -2
Copy the code
Out of 524,284, 7,432 have been used.
The only commands that involve swapping are mkswap for formatting swap files or partitions, SWapon for enabling one (or all) swap areas, and swapoff for disabling one (or all) swap areas.
At any given time, most of the memory is used to cache the contents of the file to prevent actual more times or suboptimal order or time than is actually needed. Such memory pages are never swapped because the backup storage is the file itself, so it makes no sense to write the swap.
Unlike other operating systems, the Linux memory used by the kernel itself (rather than application memory) is never swapped.
4. Thread model
In addition to the actual executing program, there is additional information, such as environment variables, additional memory areas, what the current directory and files are being used, and so on. If there are multiple threads in a process, they share this information. A process is simply a running instance of a program.
It would be nice to have multithreaded programs for two reasons. For example, you might perform the same task many times at once. For example, you could have a server that is handling many clients, and for each client you would create a thread to handle that client, or you might have a process that is doing multiple things.
There are several ways to code multithreaded programs, but the portable approach is to use the so-called POSIX threading library or PThreads library. The ideal option to write once and use it anywhere, with complete portability, is just an ideal that is hard to achieve.
5.OOM Memory shortage killer
When the Linux kernel is under extreme memory pressure, it calls the dreaded OOM killer. This attempts to select and kill the “best” process to help the system recover properly.
We will force the system to see what happens when it is out of memory. The first thing to do is open a terminal window and type: $sudo tail -f /var/log/messages
You can close the swap area and then open the swap area
$ sudo /sbin/swapoff -a
$ sudo /sbin/swapon -a
Copy the code
Now we run a program that consumes a lot of memory
/* simple program to defragment memory, J. Cooperstein 2/04 @*/ #include <stdio.h> #include <stdlib.h> #include <unistd.h> #include <string.h> #define MB (1024*1024) int main(int argc, char **argv) { int j, m; char *c; if (argc < 2) { fprintf(stderr, "You must give the memory in MB to waste, aborting\n"); exit(EXIT_FAILURE); } m = atoi(argv[1]); for (j = 0; j < m; J++) {/* yes we know this is a memory leak, no free, that's the idea! */ c = malloc(MB); memset(c, j, MB); printf("%5d", j); fflush(stdout); } printf("All memory allocated, pausing 5 seconds\n"); sleep(5); printf("Quitting and releasing memory\n"); exit(EXIT_SUCCESS); }Copy the code
How many MB is consumed as a parameter.
Three Networking.
1. Network and network interfaces
Most network programming in Linux is done using the Socket interface. As a result, standards-compliant programs can work on Linux with very little information.
There are many enhancements and new features in Linux networking implementations, such as a new family of addresses and protocols. For example, Linux provides the NetLink interface, which allows you to open socket connections between kernel subsystems and applications (or other kernel subsystems). It has been effectively deployed to implement firewall and routing applications.
The names of wired Ethernet network devices have been called eth0, eth1, etc., while the names of wireless devices have been called Wlan0, Wlan1, etc.
Collect basic information about the active network interface on the system through the Ifconfig utility:
[root@localhost ayuan]# /sbin/ifconfig ens32: Flags = 4163 < UP, BROADCAST, RUNNING, MULTICAST > mtu 1500 inet 192.168.126.158 netmask 255.255.255.0 BROADCAST 192.168.126.255 inet6 fe80::31bb:a215:3b5a:3505 prefixlen 64 scopeid 0x20<link> ether 00:0c:29:5f:00:d9 txqueuelen 1000 (Ethernet) RX Packets 1191 bytes 546739 (533.9 KiB) RX errors 0 dropped 0 Overruns 0 frame 0 TX packets 638 bytes 55460 (54.1 KiB) TX errors 0 dropped 0 overruns 0 carrier 0 collisions 0 lo: Flags =73<UP,LOOPBACK,RUNNING> MTU 65536 inet 127.0.0.1 netmask 255.0.0.0 inet6 ::1 prefixLen 128 scopeid 0x10<host> loop Txqueuelen 1000 (Local Loopback) RX packets 76 bytes 6624 (6.4 KiB) RX errors 0 Dropped 0 Overruns 0 frame 0 TX packets 76 bytes 6624 (6.4 KiB) TX errors 0 Dropped 0 Overruns 0 carrier 0 collisions 0 virbr0: Flags =4099<UP,BROADCAST,MULTICAST> MTU 1500 INET 192.168.122.1 Netmask 255.255.255.0 BROADCAST 192.168.122.255 ether 52:54:00: D9: D6:5a TXQueuelen 1000 (Ethernet) RX packets 0 bytes 0 (0.0b) RX errors 0 Dropped 0 Overruns 0 frame 0 TX Packets 0 bytes 0 (0.0b) TX errors 0 dropped 0 Overruns 0 carrier 0 collisions 0 // inet: INDICATES the IP address of a NIC. // netmask: indicates the network mask. // broadcast: indicates the broadcast address. Inet 192.168.1.135 netmask 255.255.255.0 broadcast 192.168.1.255 // IPv6 address of the nic inet6 fe80::2aa: BBFF :fecc:ddee prefixlen 64 Scopeid 0x20<link> Ethernet (Ethernet) HWaddr (hardware MAC address) // txQueuelen (transmission queue length set by the NIC) ether 00: AA: BB :cc: DD: EE TXQueuelen 1000 (Ethernet) // RX Packets Indicates the correct number of received packets. // RX bytes Indicates the amount of data received. // RX errors Indicates the number of packets that generate errors when receiving packets. // RX Dropped The number of discarded data packets. // RX overruns Indicates the number of packets lost due to excessive speed when receiving packets. // RX Frame Number of packets lost due to frame error.Copy the code
The information displayed includes information about the hardware MAC address, MTU (maximum transmission unit), and IRQ bound to the device. It also displays the number of packets and bytes that were sent, received, or caused errors. As you can see, there is a network adapter bound to eth32 and a loopback interface lo that handles the network traffic bound to the computer.
You can view statistics ** in abbreviated form by viewing ** /proc/net/dev
2.Using Predictable Network Interface Device Names
We will consider how to actually name network interface devices.
There was a time when this was a very static situation. Your computer is connected to one or more network devices that do not change over time and are usually wired rather than wireless. Therefore, assign it a specific name, stick with it, and use that name is acceptable in all of your system administration scripts.
When you think about wireless, you probably have many wireless networks available, and you have to choose one, and so on. Also, in terms of Ethernet connections or network cards, you may have more than one network card connected to your computer. If you don’t know the order in which these devices are found, there may be problems.
All distributions follow a modern approach called the Predictable network interface Device scheme. They can use the actual geographic description, or they can use the actual connection location (the so-called MAC address) of the hardware device you own, whether it’s a wireless card or an Ethernet card. Or you can go back to the original simple order of its file systems like eth0, eth1, wlan0, wlan1, etc. ** All of these can be changed by administration. ** You can decide what you want. In order to administer systems on network devices, you must know their names.
3.Networking and Network Interfaces
To bring a network connection up and assign a static address, you can do:
$sudo /sbin/ifconfig eth0 up 192.***.1.100Copy the code
To bring it up and get it an assigned address from a DHCP server, you can do:
***.1.100 // Set the IP address and subnet mask. Ifconfig eth0 192.*** Configure the IP address, subnet mask, and broadcast address ifconfig eth0 192.***.1.100 netmask 255.255.255.0 broadcast 192Copy the code
Although ifconfig has been reliably used for many years, the IP utility is newer (and more versatile). Technically, it is more efficient because it uses netlink socket ** instead of ioctl** system calls.
IP addresses can be configured using IP and ifconfig
$IP link % Displays information about all network interfaces $IP -s link show eth0 % Displays information about the eth0 network interface $sudo IP addr add 192.***.1.7 dev eth0 % Sets the IP address of eth0Copy the code
Now that you’ve seen this, why not give it a thumbs up