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 [email protected] 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 块可以输出最终结果
标签:执行,30,线程,进程,四周,root,rocky8
From: https://www.cnblogs.com/LKzzZ/p/17610272.html