基于数据库查找----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