10、Linux--find、正则、文本过滤器grep

笔记

1、晨考

1、每个月的3号、5号和15号,而且这天是星期六时执行
	00 00 3,5,15 * 6 
	
2、每天的3点到15点,每隔3分钟执行一次
	*/3 3-15 * * *
	
3、每周六早上2点半执行
	30 02 * * 6
	
4、每隔两个月的一号下午10点执行
	00 22 01 */2 * 

5、root密码忘记了的解决办法
	1、重启
	2、在启动选择系统内核界面,按 e 键进入单用户模式
	3、找到 linux16 开头行,删除 ro , 并且在 ro 处添加 rw init=/sysroot/bin/sh
	4、按 ctrl + x 进行系统重新引导
	5、执行 chroot /sysroot
	6、执行 passwd root
	7、执行 touch /.autorelabel
	8、执行 Ctrl + D 重启系统

6、yum私有仓库的搭建步骤

	1、安装工具
		yum install createrepo yum-utils nginx -y
	
	2、创建目录
		mkdir /opt/test
		
	3、创建包目录
		mkdir /opt/test/Packages
	
	4、下载安装包
		下载到Packages目录中
		https://repo.huaweicloud.com/centos/7/os/x86_64/Packages/zsh-5.0.2-34.el7_8.2.x86_64.rpm

	5、初始化仓库
		createrepo /opt/test

	7、修改nginx的配置文件
		[root@localhost /mnt]# vim /etc/nginx/nginx.conf
		# include /etc/nginx/conf.d/*.conf;
		root         /opt/test;
		autoindex on;

	8、启动Nginx
	 systemctl start nginx 

	9、添加yum源
		yum-config-manager --add-repo=http://192.168.15.101

	10、测试
		yum install zsh -y 

2、昨日问题

3、今日内容

1、find
2、正则表达式
3、linux三剑客之grep

4、find

根据文件的名称或者属性查找文件。

语法格式:
	find   [查找范围]  [参数]

参数:
	-name : 按照文件的名字查找文件
		* :通配符
	-iname :  按照文件的名字查找文件(忽略大小写)
	-size : 按照文件的大小查询文件
		+	: 大于
		-	: 小于
		没符号 : 等于

	-mtime : 按照修改时间去查询
		+(可以省略) : n 天以前
		- 			: n 天以内
	-atime
	-ctime 

	-user :按照用户的属主查询
	-group : 按照用户的属组查询
	-type : 按照文件的类型查询
		d : 文件夹
		l : 链接文件
		s : 套接字文件
		p : 管道文件
		c : 字符文件
		b :磁盘文件
		f : 普通文件

	-perm : 按照文件的权限查询
	-inum : 根据index node号码查询

	-a : 并且(可以省略,默认时并且)
	-o : 或者
	-maxdepth : 查询的目录深度(必须放置与第一个参数位) 

	-exec : 将find处理好的结果交给其他命令继续处理。

知识储备:
	dd : 生成文件
		if 		:从什么地方读
		of 		: 写入到什么文件
		bs 		: 每次写入多少内容
		count 	: 写入多少次

案例:
	案例1:查询/etc目录下hosts文件
        [root@localhost ~]# find /etc/ -name 'hosts'
        /etc/hosts
    案例2:查询/etc目录下名称中包含hosts文件
    	[root@localhost ~]# find /etc/ -name '*hosts*'

    案例3:要求把/etc目录下,所有的普通文件打包压缩到/tmp目录
		[root@localhost /tmp]# tar -czPf /tmp/etcv2.tar.gz `find /etc/ -type f | xargs`

知识储备
	| : 前面一个命令的结果交给后面一个命令处理
	xargs : 把处理的文本变成以空格分割的一行
	`` : 提前执行命令,然后将结果交给其他命令来处理

5、grep

linux三剑客之一,文本过滤器(根据文本内容过滤文件)。

语法格式:
	grep [参数] [匹配规则] [操作对象]

参数:
	-n : 过滤文本时,将过滤出来的内容在文件内的行号显示出来
	-A : 匹配成功之后,将匹配行的后n行显示出来
	-B : 匹配成功之后,将匹配行的前n行显示出来
	-C : 匹配成功之后,将匹配行的前后各n行显示出来
	-c :  只显示匹配成功的行数
	-o :  只显示匹配成功的内容
	-v :  反向过滤
	-q :  静默输出
	-i : 忽略大小写
	-l :  匹配成功之后,将文本的名称打印出来
	-R|-r : 递归匹配 

	-E : 使用拓展正则   等价于  egrep

知识储备:
	$? : 上一行命令执行的结果,0代表执行成功,其他数字代表执行失败。
	wc :  匹配行数
		-l : 打印匹配行数
		-c : 打印匹配的字节数
	

在/etc目录下,有多少个文件包含root。
	grep -rl 'root' /etc/ | wc -l

6、正则表达式

1、正则表达式的分类(grep)
	1、普通正则表达式
	2、拓展正则表达式

2、普通正则表达式
	
	^ : 以某字符开头
	$ : 以某字符结尾
	. : 匹配除换行符之外的任意单个字符
	* :匹配前导字符的任意个数
	[] : 某组字符串的任意一个字符
	[^]      : 取反
	[a-z]    : 匹配小写字母
	[A-Z]    : 匹配大写字母
	[a-zA-Z] : 匹配字母
	[0-9] 	 : 匹配数字
	\ 		: 取消转义
	()		: 分组
		\n : 代表第n个分组

3、拓展正则
	{}     :匹配的次数
		{n}		: 匹配n次
		{n,}	:至少匹配n次
		{n,m}	:匹配 n 到 m 次
		{,m}	:最多匹配m次
	+      :匹配至少有一个前导字符
	?      : 匹配一个或零个前导字符
	|      :或

案例:
	案例1:在/etc/passwd文件中,匹配以ftp开头的行
		grep '^ftp' /etc/passwd

	案例2:在/etc/passwd文件中,匹配以bash结尾的行
		grep 'bash$' /etc/passwd

	案例3:匹配本机中有哪些ip
		ip a | grep -oE '([0-9]{1,3}\.){3}[0-9]{1,3}'

	案例4:要求将/etc/fstab中的去掉包含 # 开头的行,且要求 # 后至少有一个空格
		grep -vE '^#\ +' /etc/fstab

	案例5:找出文件中至少有一个空格的行
		grep -E '\ +' xxx

	案例6:将 nginx.conf 文件中以#开头的行和空行,全部删除 
		grep -vE '^\ *#|^$' /etc/nginx/nginx.conf
上一篇:php生成唯一的ID使用uniqid(),注意是13位


下一篇:Linux基础命令通配符 正则 扩展正则