基于数据库查找----locate

优点----效率高(因为基于数据库查询)

缺点----数据库没更新时可能查询不正确

需要先安装 yum install -y mlocate

updatedb ---------手动更新数据库

❗/tmp 目录不作为updatedb数据库记录范围

所以/tmp 里的内容是用 locate 查找不到的

-r ----------------支持正则

locate lesson locate -r 'lessonoo.*' ( -r参数支持用正则通配符) locate -r '.iso$' 找以'.iso'结尾的文件


磁盘扫描查找--------find

优点:真实扫描磁盘来查找,查找方式丰富

缺点:慢

语法:

find 查找的路径 -查找的方式(name/size/type/perm/user/group/newer)

❗❗❗size 的单位不能混用 不能一个k一个m

例如 find -size +100k -a -size -1m /

这种用法是不可以的,应该把1M转化为1024k。

❗❗❗ 而且----- -a 可以不写

但是 或者---------- -o 必须写

-name 按照文件名查找文件 find / -name ".conf" find /var/ -size +20M -a -size -30M -a -name "pdf" 等上 find /var/ -size +20M -size -30M -name "*pdf"

find /var/  -size +1000M -o  -name "*.txt"

-perm 按照文件权限来查找文件。
#find / -perm 755 || find /tmp -perm 755 -ls

-user 按照文件属主来查找文件.
#find / -user student

-group 按照文件所属的组来查找文件。
#find / -group student
# find / -user vip01 ! -group upl_vip

-newer file1 查找更改时间比文件file1新但比文件file2旧的文件。 # find /home/ -newer /home/a_f_8 ----查找比/home/a_f_8 新的文件 # find /home/ ! -newer /home/a_f_8 ----查找比/home/a_f_8 老的文件

-type 查找某一类型的文件,诸如: b- 块设备文件。d - 目录。c - 字符设备文件。 p - 管道文件。l - 符号链接文件。f - 普通文件。 #find /dev/ -type b

-size n:[c] 查找文件长度为n块的文件,带有c时表示文件长度以字节计。 find /etc/ -size 585c c代表字符 -585c 小于 +566c大于 find /tmp/ -size 2 大于2块 -2小于2块

🟩find 支持对查找到的文件进一步操作

# 格式 find [路径] [参数] [表达式] -exec 指令 {} \ ; -{} 代表find找到的文件 -\ 禁止转意 ; 表示本行指令结束 # find /sbin -type f -size +1M -exec ls {} \; --在/sbin目录中查找文件类型为常规文件并且文件大小大于1M,再使用ls命令来查看找到的文件的类型 # find /sbin -type f -size +1M -exec cp {} /tmp \;

[root@uplooking pub]# find /var/​​ftp/​​ -size 0 -a -type f -exec rm -rf {} \; 找出/var所有空普通文件删除 -exec直接执行 [root@uplooking pub]# find /var/​​ftp/​​ -size 0 -a -type f -ok rm -rf {} \; 找出/var所有空普通文件删除 -ok询问每条动作 [root@uplooking pub]# find /etc/ -name "*.conf" -exec cp {} /home/www \; 将/etc/ 所有的conf文件复制到 /home/www

❗ -ok

# find / -size 1000 -ok cp {} /var/tmp/ \;

对找到的文件 执行 cp 操作前 会提示


文件内容查找----------grep

grep 参数 查找目录

pgrep -------不支持正则与通配符

grep---------支持一般正则

egrep--------支持所有正则,包括扩展正则(例如 或| )

grep "root" /etc/passwd --在passwd过滤root关键字 grep -i "root" /etc/passwd --忽略大小写 grep -n -i "root" /etc/passwd --忽略大小写并输入行号 grep -v "root" /etc/passwd -v除了root这个关键字 grep -v '^$' /etc/passwd ^$ 空行** grep '^root' /etc/passwd ^root以root开头 grep 'bash$' /etc/passwd bash$以bash结尾** grep -w “^root” /etc/passwd 精确匹配以root单词开头的内容,例如rootabc则不满足,root:abc 匹配 grep -vE "^#|^$" /etc/ssh/sshd_config “-E”开启扩展正则字符支持 grep -Rl "pthread_create" /usr/include/ 在/usr/include找包含pthread_create内容的文件 grep -Rn "hello" /usr/share/ 在/usr/share目录中查找文件中内容包含"hello"的文件 n 列出 hello所在的行号

❗❗❗❗❗注意加黑的那几个 '^$' 是单引号 不能使用双引号

❗❗❗❗❗使用正则的时候要使用 单引号 不能用 双引号

find 怎么支持 ^ 和 $ 的正则 ????????????


解压


zip 压缩/ unzip 解压

zip 指定压缩后的文件名 要压缩的文件 (没知道压缩后的文件名的时候会报错)

zip -r -----------递归

unzip xxx -----------解压到当前

unzip xxxx -d yyyy -------------解压到指定的yyyy目录

gzip/gunzip---------压缩速度快,占用CPU资源少,但是占用空间多,而且只能压缩一个文件

gzip -5 afile ----指定压缩级别 1-9 数字越大压缩级别越高,压缩率越高,体积越小,数字越小,压缩越快。

bzip2/bunzip2 ------------与gzip一样 但是压缩的强度高很多


zcat--------------不解压查看

tar------------打包/压缩

-x 解压 -c 创建一个压缩文件(压缩) -t 不解压直接查看

-r 追加文件到压缩包 -z gzip ----可以不写,自动以后缀名智能选择 -j bzip2 -v 详细信息 -f 文件(必选项) -p 保持权限不变

tar     .gz后缀名的文件
tar -czvf /home/user1001/a.tar.gz a
tar -cvf /home/user1001/a.tar.gz a 不指定-z根据后缀名gz选用gzip算法压缩
tar -tzvf /home/user1001/a.tar.gz
tar -xzvf /home/user1001/a.tar.gz -C /tmp

tar .bz2后缀名的文件
tar -cjvf /home/user1001/a.tar.bz2 a
tar -tjvf /home/user1001/a.tar.bz2
tar -xjvf /home/user1001/a.tar.bz2 -C /tmp

❓❓❓后面的a ??????????????????????????????

参数: -c :建立一个压缩文件的参数指令(create 的意思); -x :解开一个压缩文件的参数指令! -t :查看 tarfile 里面的文件! 特别注意,在参数的下达中, c/x/t 仅能存在一个!不可同时存在! 因为不可能同时压缩与解压缩。 -z :是否同时具有 gzip 的属性?亦即是否需要用 gzip 压缩? -j :是否同时具有 bzip2 的属性?亦即是否需要用 bzip2 压缩? -v :压缩的过程中显示文件!这个常用,但不建议用在背景执行过程! -f :使用档名,请留意,在 f 之后要立即接档名喔!不要再加参数!    例如使用『 tar -zcvfP tfile sfile』就是错误的写法,要写成    『 tar -zcvPf tfile sfile』才对喔! -p :使用原文件的原来属性(属性不会依据使用者而变) -P :可以使用绝对路径来压缩! -N :比后面接的日期(yyyy/mm/dd)还要新的才会被打包进新建的文件中! --exclude FILE:在压缩的过程中,不要将 FILE 打包!

范例: 范例一:将整个 /etc 目录下的文件全部打包成为 /tmp/etc.tar [root@linux ~]# tar -cvf /tmp/etc.tar /etc <==仅打包,不压缩! [root@linux ~]# tar -zcvf /tmp/etc.tar.gz /etc <==打包后,以 gzip 压缩 [root@linux ~]# tar -jcvf /tmp/etc.tar.bz2 /etc <==打包后,以 bzip2 压缩 # 特别注意,在参数 f 之后的文件档名是自己取的,我们习惯上都用 .tar 来作为辨识。 # 如果加 z 参数,则以 .tar.gz 或 .tgz 来代表 gzip 压缩过的 tar file ~ # 如果加 j 参数,则以 .tar.bz2 来作为附档名啊~ # 上述指令在执行的时候,会显示一个警告讯息: # 『tar: Removing leading `/' from member names』那是关於绝对路径的特殊设定。

范例二:查阅上述 /tmp/etc.tar.gz 文件内有哪些文件? [root@linux ~]# tar -ztvf /tmp/etc.tar.gz # 由於我们使用 gzip 压缩,所以要查阅该 tar file 内的文件时, # 就得要加上 z 这个参数了!这很重要的!

范例三:将 /tmp/etc.tar.gz 文件解压缩在 /usr/local/src 底下 [root@linux ~]# cd /usr/local/src [root@linux src]# tar -zxvf /tmp/etc.tar.gz # 在预设的情况下,我们可以将压缩档在任何地方解开的!以这个范例来说, # 我先将工作目录变换到 /usr/local/src 底下,并且解开 /tmp/etc.tar.gz , # 则解开的目录会在 /usr/local/src/etc 呢!另外,如果您进入 /usr/local/src/etc # 则会发现,该目录下的文件属性与 /etc/ 可能会有所不同喔!

范例四:在 /tmp 底下,我只想要将 /tmp/etc.tar.gz 内的 etc/passwd 解开而已 [root@linux ~]# cd /tmp [root@linux tmp]# tar -zxvf /tmp/etc.tar.gz etc/passwd # 我可以透过 tar -ztvf 来查阅 tarfile 内的文件名称,如果单只要一个文件, # 就可以透过这个方式来下达!注意到! etc.tar.gz 内的根目录 / 是被拿掉了!

范例五:将 /etc/ 内的所有文件备份下来,并且保存其权限! [root@linux ~]# tar -zxvpf /tmp/etc.tar.gz /etc # 这个 -p 的属性是很重要的,尤其是当您要保留原本文件的属性时!

范例六:在 /home 当中,比 2005/06/01 新的文件才备份 [root@linux ~]# tar -N '2005/06/01' -zcvf home.tar.gz /home

范例七:我要备份 /home, /etc ,但不要 /home/dmtsai [root@linux ~]# tar --exclude /home/dmtsai -zcvf myfile.tar.gz /home/* /etc

范例八:将 /etc/ 打包后直接解开在 /tmp 底下,而不产生文件! [root@linux ~]# cd /tmp [root@linux tmp]# tar -cvf - /etc | tar -xvf - # 这个动作有点像是 cp -r /etc /tmp 啦~依旧是有其有用途的! # 要注意的地方在於输出档变成 - 而输入档也变成 - ,又有一个 | 存在~ # 这分别代表 standard output, standard input 与管线命令啦! # 这部分我们会在 Bash shell 时,再次提到这个指令跟大家再解释啰!

❗❗❗下载rpm包的时候可以直接用 连接下载

rpm -i ​​http://xxxxxxxxxxxxxxxxxxxx​

more 按空格 往后翻一页 ❗但是只能往后 不能往前

也就是只能下一页 不能上一页

less 上下键 可以一行一行的查看

还可以在:/的模式下 n 下一页 N 上一页

也可以匹配关键字 /dafu

cat more less tail head

❗❗❗❗路由器和电脑是同种设备 相连的时候要用交叉线