awk(输出文本指定内容),sed(修改文件内容),at(计划将来的任务),crontab(周期性作业),tuned(调优系统性能),ACL(控制对文件的访问)

awk

awk -F: ‘{print $1,$3}’ passwd | head #把 passwd 第一个字段域和第三个字段域的内容输出,输入时用到的字段分隔符为:
passwd不知道在哪?
有两种passwd: /usr/bin/passwd(二进制乱码)
/etc/passwd (我们需要看到的)
cd /etc
格式化输出:printf “FORMAT”,item1,item2,…
  1、必须指定FORMAT
  2、不会自动换行,需要显式给出换行控制符\n;
  3、FORMAT中需要分别为后面每个item指定格式符;
格式符:与item一一对应
  %d,%i 显示十进制整数
  %s 显示字符串 #%-15s
\t 制表符
修饰符:
  #.# 第一个数字控制显示的宽度;第二个#表示小数点后精度;
  - 左对齐(默认右对齐);例如**:%-15s 表示长度为15,为了更加美观,让空格更多,实则并不重要。**
  + 显示数值的正负符号;例如:%+d

在这里插入图片描述
上图格式化是让第一列和第六列字符串长度为15,更加美观
awk [options] ‘program’ file…
  options(选项):
   -F 指明输入时用到的字段分隔符(间隔符号)
分割符、域和记录:
  awk执行时,由分隔符分隔的字段(域);标记$1, 2.. 2.. 2..n称为域标识。 0 为 所 有 域 ; 注 意 : 和 s h e l l 中 变 量 0为所有域;注意:和shell中变量 0shell符含义不同;文件的每一行称为记录;省略action,则默认执行print $0 的操作
print输出,printf格式化输出,比如%d(十进制)
df -Th --block-size=m| awk ‘/^/dev/ {print $0}’|awk ‘{if($4>2500M) printf “%-15s\t\n”,$4}’
/^/dev/表示以/dev/开头,
在这里插入图片描述

在这里插入图片描述
在这里插入图片描述
第二行第三列的数据

**

sed工作原理及功能

**
sed的编辑命令
  1,3d  删除模式空间匹配的行;
  p  显示模式空间中被地址定界匹配到的行的内容
  a\text 会在指定行后增加一个新行;支持使用\n实现多行追加,append
  i\text  会在指定行前增加一个新行;支持使用\n实现多行插入
  c\text 把指定到的行替换为此处指定的文本“text”
sed ‘1,3d’ abc.txt #看 删除文件的一到三行 后的内容,并未真的删,如果真要修改,就sed -i ‘1,3d’ abc.txt

在这里插入图片描述
在这里插入图片描述
真实修改文件内容
在这里插入图片描述
在这里插入图片描述
查找和替换
-i 修改原始文件
s#search#replace#g s寻找,g全局修改
3,$

在这里插入图片描述
显示行号,以root开头,用^
在这里插入图片描述
sed -i ‘1s#root#abc#g’ /etc/passwd #1表示第一行,s表示查找,g表示全局
把第一行的root都改为abc

计划将来的任务(at)

目标
规划任务(Job/Task)在将来自动执行
管理临时任务(at)
启动atd.service
systemctl start atd.service
在这里插入图片描述

两分钟后在tmp目录下创建文件text1
at now+2min #两分钟后
/usr/bin/touch /tmp/text1 #touch为创建文件,在tmp目录下创建文件text1
按Ctrl+D结束
在这里插入图片描述
定义时间的方式:

at now +2hour
at now +2day
at now +2day
at 2pm Apr 18 2021
at “22:33 2021-4-24”
在这里插入图片描述

at -l #查看编号
at -c 2 #用编号来查看具体的任务
在这里插入图片描述
查看at下的具体任务
cd /var/spool
cd at
在这里插入图片描述
cron周期性作业 (这个作业循环执行多次,每周每天每月做)
cronie软件包提供crond系统守护进程

与守护进程交互的命令行工具–crontab
dnf whatprovides crontab
它默认已安装并启用crond守护进程
crontab -[e|l] -u username #-e表示编辑,-u表示给哪个用户去创建作业,-l查看,list
在这里插入图片描述
*表示始终,一直要做的事情
1表示星期一,2表示星期二,7表示周日
x-y 表示x到y
x,y x和y
*/7 表示每7分钟运行一次作业
crontab -e #编辑周期性作业

#在每年2月2日上午9点准时执行命令/usr/local/bin/yearly_backup
00 9 2 2 * /usr/bin/touch /tmp/test

#在七月每周五的上午9点和下午5点间,每5分钟输出echo “Chime”
*/5 00 9-17 * 7 5 /usr/bin/echo “Chime”

#该作业只能在周一到周五运行,周六或周日不能运行
在上午8点到晚上9点之间每2分钟一次将当前日期和时间附加到
/home/student/my_first_cron_job.txt
*/2 00 8-9 * * 1-5 /home/student/my_first_cron_job.txt

格式为* * * * * shell ,如果对每几分钟有要求,则*/n,则格式需要六个*,几点一定要00

tuned(调优系统性能)
top #查看进程
ps axo user,pid,pcpu,nice,comm |grep student
NI 值越大,优先级越低
systemctl status tuned.service
tuned-adm --help #查看用法
以student身份调优配置文件变更为powersave
在这里插入图片描述
在这里插入图片描述

更改现有进程的NICE级别
top #显示进程
按 u 挑选一个用户,输入用户名,enter
按 r 修改nice值,选一个pid
输入一个数字, enter
在这里插入图片描述

在这里插入图片描述

getfacl与setfacl的参数选项基本相同。
(1)getfacl [-aceEsRLPtpndvh] file…
-a , --access:显示文件或目录的访问控制列表。

-d , --default:显示文件或目录的默认(缺省)的访问控制列表。

-c , --omit-header:不显示默认的访问控制列表。

-R , --recursive:操作递归到子目录。

-t , --tabular:使用列表输格式出ACL设置信息。

-n , --numeric:显示ACL信息中的用户和组的UID和GID。

-p , --absolute-names:

-v , --version:显示命令的版信息

-h , --help:显示命令帮助信息。

(2)setfacl [-bkndRLP] { -m|-M|-x|-X … } file …
-m, --modify=acl:修改文件或目录的扩展ACL设置信息。

-M, --modify-file=file:从一个文件读入ACL设置信息并以此为模版修改当前文件或目录的扩展ACL设置信息。

-x, --remove=acl:从文件或目录删除一个扩展的ACL设置信息。

-X, --remove-file=file:从一个文件读入ACL设置信息并以此为模版删除当前文件或目录的ACL设置信息。

-b, --remove-all:删除所有的扩展的ACL设置信息。

-k, --remove-default:删除缺省的acl设置信息。

–set=acl:设置当前文件的ACL设置信息信息。
–set-file=file:从文件读入ACL设置信息来设置当前文件或目录的ACL设置信息。
–mask:重新计算有效权限,即使ACL mask被明确指定。
-n, --no-mask:不要重新计算有效权限。setfacl默认会重新计算ACL mask,除非mask被明确的制定。

-d, --default:设置默认的ACL设置信息(只对目录有效)。

-R, --recursive:操作递归到所有子目录和文件。

-L, --logical:跟踪符号链接,默认情况下只跟踪符号链接文件,跳过符号链接目录。

-P, --physical:跳过所有符号链接,包括符号链接文件。

–restore=file:从文件恢复备份的acl设置信息(这些文件可由getfacl -R产生<—针对目录)。通过这种机制可以恢复整个目录树的acl设置信息。此参数不能和除–test以外的任何参数一同执行。
–test:测试模式,不会改变ACL设置信息。
-v, --version:显示程序的版信息。

-h, --help:显示帮助信息。

ACL设置信息
setfacl命令可以识别以下的设置信息格式。
setfacl [d[efault]:] [u[ser]:]uid [:perms]:指定用户的权限,文件所有者的权限(如果uid没有指定)。
setfacl [d[efault]:] g[roup]:gid [:perms]:指定群组的权限,文件所有群组的权限(如果gid未指定)
setfacl [d[efault]:] m[ask][:] [:perms]:有效权限掩码
setfacl [d[efault]:] o[ther] [:perms]:其他的权限

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值