第四周

1、自定义写出10个定时任务的示例:

例1:每周三凌晨三点执行data命令

[20:26:34 root@rocky8 ~]#crontab -l
* 3 * * */3 date

例2:每周的工作日1:30,将/etc备份至/backup目录中,保持的文件名称为“etcbackup-yyyy-mm-dd-HH.tar.xz”

[20:37:19 root@rocky8 ~]#cat etcback.sh 
#!/bin/bash

DIR=etcbak-`date -d ' -1 day ' +%Y-%m-%d-%H`
tar -jcvf /backup/${DIR}.tar.xz /etc/ &> /dev/null

[20:37:26 root@rocky8 ~]#crontab -l
30 1 * * 1-5 bash etcback.sh

例3:每10天的6点30分执行ls命

[20:40:45 root@rocky8 ~]#crontab -l
30 6 */10 * * ls

例4:每周六1点10分以ju的用户身份重启http服务

[20:46:30 root@rocky8 ~]#crontab -l 
10 1 * * 6 systemctl restart httpd

例5:每30分钟执行一次磁盘检查disk_check.sh脚本

[20:49:57 root@rocky8 ~]#crontab -l
*/30 * * * * bash disk_check.sh

例6:6月30号23:30分重启主机

[20:53:11 root@rocky8 ~]#crontab -l
30 23 30 6 * reboot

例7:每天早上8点到下午18点每隔2小时的每30分钟 查看系统时间

[20:57:25 root@rocky8 ~]#crontab -l
*/30 8-18/2 * * * date

例8:每天3点30分和12点30分执行/tmp下的hello.sh脚本

[21:01:58 root@rocky8 ~]#crontab -l
30 3,12 * * * /tmp/hello.sh

例9:每隔2个小时清理一次

[21:05:09 root@rocky8 ~]#crontab -l
*/2 * * * * rm -rf /var/www/html

例10:每天23点关闭sshd服务

[21:06:57 root@rocky8 ~]#crontab -l
0 23 * * * systemctl stop sshd

2、图文并茂说明Linux进程和内存概念

进程:process运行中的程序的一个副本,是被载入内存的一个指令集合,是资源分配的单位

进程具有三种基本状态:        

1、就绪状态。某些进程“万事俱备”(必要资源),只差CPU。(就绪队列)      

2、执行状态。某进程占有CPU并在CPU上执行其程序。        

3、阻塞状态。某些进程由于某种原因不能继续运行下去,等待处 理问题。也称为等待状态或封锁状态。如:请求I/O。(多个等待队列) 

进程具有特征:

动态性:进程是程序的一次执行过程,是临时的,有生命期的,是动态产生,动态消亡的。

并发性:任何进程都可以同其他进程一起并发执行。

独立性:进程是系统进行资源分配和调度的一个独立单位。

结构性:进程是由程序、数据和进行控制块三部分组成。

线程:线程是程序执行中一个单一的顺序控制流程,是程序执行流的最小单元,是处理器调度和分派的基本单位。一个进程可以有一个或多个线程,各个线程之间共享程序的内存空间(也就是所在进程的内存空间)。一个标准的线程由线程ID、当前指令指针(PC)、寄存器和堆栈组成。而进程由内存空间(代码、数据、进程空间、打开的文件)和一个或多个线程组成。
进程和线程的区别:

线程是程序的最小单位,而进程是操作系统分配的最小单位;

一个进程可以有一个或多个线程组成,线程是一个进程中代码的不同执行路线;

进程之前相互独立,但同一进程下的各个线程之间共享程序的内存空间(包括代码段、数据集、堆等)及一些进程的资源(如打开文件和信号),某进程内的线程在其他进程不可见;

调度和切换:线程上下文切换比进程上下文切换要快得多。

3、图文并茂说明Linux启动流程

Centos 6启动流程

1.加载BIOS的硬件信息,获取第一个启动设备

2.读取第一个启动设备MBR的引导加载程序(grub)的启动信息

3.加载核心操作系统的核心信息,核心开始解压缩,并尝试驱动所有的硬件设备

4.核心执行init程序,并获取默认的运行信息

5.init程序执行/etc/rc.d/rc.sysinit 文件,重新挂载根文件系统

6.启动核心的外挂模块

7.init执行运行的各个批处理文件(scripts)

8.init执行/etc/rc/d/rc.local

9.执行/bin/login程序,等待用户登录

10.登录之后开始以shell控制主机
grub功能和组成

bootloader:引导加载器,引导程序

Windows:ntloader,仅是启动OS

linux:功能丰富,提供菜单,允许用户选择要启动系统或不同的内核版本,把用户选定的内核装载到内存中的特定空间中,解压,展开,并把系统控制权移交给内核

linux的bootloader

lilo:linux loader,早期的bootloader,功能单一

grub:guand unified bootloader,centos 5,6 grub 0.97:grub legacy,centos 7以后使用grub 2.02

grub启动阶段

primary boot loader

1st stage :MBR的前446个字节

1.5 stage:MBR之后的扇区,让stage1中的BootLoader能识别stage2所在的分区上的文件系统

secondary bootloader:2nd stage,分区文件/boot/grub/
centos 7以后启动流程

1.UEFi或BIOS初始化,运行POST开机自检

2.选择启动设备

3.引导装载程序,centos 7是grub2,加载装载程序的配置文件

        /etc/grub.d/

        /etc/default/grub

        /boot/grub2/grub.cfg

4.加载initramfs驱动模块

5.加载内核选项

6.内核初始化,centos 7使用systemd代替init

7.执行initrd.garget所有单元,包括挂载 /etc/fstab

8.从initramfs根文件系统切换到磁盘根目录

9.systemd执行默认target配置,配置文件/etc/systemd/system/default.target

10.systemd执行sysinit.target初始化系统及basic.target准备操作系统

11.systemd启动multi-user.target下的本机与服务器服务

12.systemd执行multi-user.target下的/etc/rc.d/rc.local

13.systemd执行multi-user.target下的getty.target及登录服务

14.systemd执行graphical需要的服务

运行级别

4、自定义一个systemd服务定时去其他服务器上检查/tmp/下文件的个数,如果发现数量有变化就记录变化情况到文件中。

[21:39:24 root@rocky8 system]#cat /lib/systemd/system/find.service
[Unit]
Description=check tmp
[Service]
TimeoutStartSec=0
ExecStart=/bin/sh -c  "ssh root@192.168.50.131  sh /shell/check_tmp.sh"   #基于key验证
ExecStop=ps auxf | grep [check]_tmp.sh |awk '{print $2}' |xargs kill -9 2>/dev/null
ExecReload=/bin/kill -s HUP $MAINPID
[Install]
Wantedby=multi-user.target

systemctl daemon-reload
systemctl enable --now find.service

5、写Linux内核编译安装博客

下载linux内核 https://www.kernel.org/
将下载的内核包上传到linux

 
yum -y install gcc make ncurses-devel flex bison openssl-devel 
elfutils-libelf-devel bc perl
tar xf linux-5.18.9.tar.xz -C /usr/local/src
cd /usr/local/src/linux-5.18.9
cp /boot/config-$(uname -r) .config
vim .config
#修改下面三行
# CONFIG_MODULE_SIG=y #注释此行
CONFIG_SYSTEM_TRUSTED_KEYS="" #修改此行
# CONFIG_DEBUG_INFO_BTF=y     
#更改内核版本名称make menuconfigGeneral setup  ➡️  Local version - append to kernel release ➡️ -m67-magedu ➡️ savemake -j 8    #多少核就写多少,此处很慢
make modules_install
make installreboot

6、总结5个自我觉得比较有用的awk的使用场景,比如在什么情况下用awk处理文本效率最高,发散题,至少写1个。

AWK的工作流程

1.通过关键字 BEGIN 执行 BEGIN 块的内容,即 BEGIN 后花括号 {} 的内容。

2.完成 BEGIN 块的执行,开始执行body块。

3.读入有 \n 换行符分割的记录。

4.将记录按指定的域分隔符划分域,填充域,$0 则表示所有域(即一行内容),$1 表示第一个域,$n 表示第 n 个域。

5.依次执行各 BODY 块,pattern 部分匹配该行内容成功后,才会执行 awk-commands 的内容。

6.循环读取并执行各行直到文件结束,完成body块执行。

7.开始 END 块执行,END 块可以输出最终结果
posted @ 2023-08-06 22:43  CuriouszzZ  阅读(31)  评论(0)    收藏  举报