温故知新

1关闭selinux的方式

• 临时关闭 setenforce 0

• 永久关闭 vim /etc/selinux/config

2.关闭firewalld的几种方式

systemctl stop firewalld

systemctl disable --now firewalld

3.设置系统编码的方式

LANG=zh_CN.UTF-8

vim /etc/locole.conf

localectl set-locale en_US.utf-8(推荐)

4.用户登录系统的方式

ssh test@192.168.15.200

su test

sy -test

5.查看当前用户的命令

sh-4.2# whoami
root

6.设置密码的方式

passwd test

echo 123456 | passwd --stdin test

7.查看selinux的状态和firewalld的状态

• getenforce

• systemctl status firewalld


今日内容

1.查找文件——find命令

在linux系统中,按照我们的要求去查找文件,如按创建的日期查找文件,查询出所有的目录或文件夹,查询出权限为644的文件,查询出属主为test的文件,我们需要用到find命令.
1.格式:find [查询的路径] [匹配模式] [匹配规则]
2.匹配模式:
-name:按名字去匹配
*:匹配任意数量的任意字符(匹配零个或多个任意字符)
?:匹配任意一个字符
-type:按照文件的类型匹配
常见的文件类型:
f:普通文件
d:普通文件夹
b:块设备文件
c:字符设备文件
s:socket文件
l:链接文件
-perm :按文件的权限来查询
常见的文件权限:755:文件夹的默认权限
644:文件的默认权限
-user:按照文件的属主来查询
-nouser:查询用户被删除了的文件
-group:按照文件的属组来查询
-nogroup:查询没有属组的文件
知识储备:删除用户:userdel
删除用户组:groupdel
-size:按照文件的大小来查询
+ 查询超过n的文件
- 查询小于n的文件
知识储备:stat:查看文件的各种时间
-mtime:按照修改文件的时间来查询
-ctime:按照文件的创建时间来查询
-atime:按照访问时间来查询文件
-a(默认):并且(and)
-o:或者(or)
-exec(xargs):处理匹配之后的内容


案例:

案例1:查询出/etc目录下的hosts文件  
[root@localhost ~]# find /etc -name "hosts"

案例2:查询出/etc目录下的以ifcfg开头的文件
[root@localhost ~]# find /etc/ -name "ifcfg*"

案例3:查询出/etc目录下以.conf结尾的文件

[root@localhost ~]# find /etc/ -name "*.conf"

案例4:查询出/etc目录下,文件名中包含host的文件有哪些

[root@localhost ~]# find /etc/ -name "*host*"

案例5:查询出/etc目录下,所有的普通文件。

[root@localhost ~]# find /etc/ -type f

案例6:查询出/etc目录下,所有的文件夹

[root@localhost ~]# find /etc/ -type d

案例7:查询出/dev/目录中的所有的块设备文件

[root@localhost ~]# find /dev/ -type b

案例8:查询出/dev目录中所有的字符设备文件

[root@localhost ~]# find /dev/ -type c

案例9:查询出/etc目录中文件名包含nginx的普通文件

[root@localhost ~]# find /etc/ -name "*nginx*" -type f

案例10:查询出/root目录下,权限为755的文件

[root@localhost ~]# find /root/ -perm 755

案例11:查询出属主为test01的文件

[root@localhost ~]# find /root/ -user test01

案例12:查询属主被删除了的文件

[root@localhost ~]# find /root/ -nouser

案例13:查询属组为test的文件

[root@localhost ~]# find /root/ -group test

案例14:查询属组被删除了的文件
[root@localhost ~]# find /root/ -nogroup

案例15:查询2天以前修改过的文件

[root@localhost ~]# find /root/ -mtime +2

案例16:查询2天以内创建的文件

[root@localhost ~]# find /root/ -ctime -2

案例17:查询2天以内访问过的文件

[root@localhost ~]# find /root/ -atime -2

案例18:查询大于1M的文件

[root@localhost ~]# find /root/ -size +1M

案例19:查询小于1M的文件

[root@localhost ~]# find /root/ -size -1M

案例20:查询在3天以内创建的文件,并删除

[root@localhost tmp]# find /tmp/ -ctime -3 -type f -exec rm -rf {} \;

-exec : 处理查询之后的内容
{} : 代表的是查询到的内容、
\; : 固定搭配

知识储备:
xargs :将所有的内容格式化成一行,我们可以通过管道或标准输入给命令传递参数,但这意味着给命令的参数可能包含换行,而有些命令是不能接受换行的,所以可以通过xargs将参数过滤,将换行换成空格

[root@localhost tmp]# find /tmp/ -ctime -3 -type f | xargs -I {} rm -rf {}