一、目录与路径
1.相对路径与绝对路径
- 绝对路径:路径的写法【一定由根目录 / 写起】,例如: /usr/share/doc 这个目录。
- 相对路径:路径的写法【不是由 / 写起】,例如由 /usr/share/doc 要到 /usr/share/man 底下时,可以写成: 【cd ../man】这就是相对路径的写法。相对路径意指相对于当前的工作目录
2.cd (切换目录)
这个命令应该是Linux中用的最频繁的一个命令之一了,因为我们经常需要进行目录的切换。常用的一些比较特殊的目录:
.表示当前目录
..表示当前目录的上一级目录
cd ~ 表示回到自己的主目录,对于 root 用户,其主目录为 /root
cd -表示回到刚刚的那个目录
~account 代表 account 这个用户的自家家目录
如:
[root@xiaoluo ~]# cd /home # 此时我们进入到了home目录下 [root@xiaoluo home]# cd . # .表示当前目录,所以当前还是在home目录下 [root@xiaoluo home]# cd .. # ..表示上一层目录,所以此时就进入到了 / 目录下
[root@xiaoluo /]# cd ~
# ~表示【目前用户身份】所在的自家目录,当前用户就是root,所以就进入到了root这个目录下
[root@xiaoluo ~]# cd ~xiaoluo
# ~account表示 account 这个用户的自家家目录 ,我如果想进入 xiaoluo 这个用户的主目录,输入 cd ~xiaoluo即可
[root@xiaoluo xiaoluo]# cd -
/root
# -表示前一个工作目录,我们的前一个工作目录就是在root下,所以此时又会进入到root这个目录下
[root@xiaoluo ~]# cd ../usr
# 如果我们需要进入到usr目录下,这里可以写成相对路径形式也可以写成绝对路径形式
[root@xiaoluo usr]#
3.pwd (显示当前所在的目录)
[root@xiaoluo ~]# pwd [-P] 参数: -P :显示出确实的路径,而非使用链接 (link) 路径。(P是大写)
例: [root@xiaoluo ~]# pwd /root <== 显示出当前所在的目录
[root@xiaoluo ~]# cd /var/mail [root@xiaoluo mail]# pwd /var/mail [root@xiaoluo mail]# pwd -P /var/spool/mail <== 怎么回事?有没有加 -P 差很多
[root@xiaoluo mail]# ls -l /var/mail lrwxrwxrwx. 1 root root 10 3月 30 10:37 mail -> spool/mail
4.mkdir (建立新目录)
[root@xiaoluo ~]# mkdir [-mp] 目录名称 参数: -m :配置文件目录的权限。我们可以自己设定自己想要的权限,而不需要使用umask定义的默认权限 -p :帮助你直接将所需要的目录递归建立起来! 例: [root@xiaoluo ~]# cd /home [root@xiaoluo home]# mkdir test <== 建立一名为 test 的新目录 [root@xiaoluo home]# mkdir test1/test2/test3/test4 mkdir: 无法创建目录"test1/test2/test3/test4": 没有那个文件或目录
[root@linux tmp]# mkdir -p test1/test2/test3/test4 # 加了这个 -p 的参数,可以自行帮我们建立多层目录! [root@xiaoluo home]# mkdir -p test1/test2/test3/test4 [root@xiaoluo home]# mkdir -m 711 test2 [root@xiaoluo home]# ls -l drwxr-xr-x. 2 root root 4096 4月 21 13:08 test drwxr-xr-x. 3 root root 4096 4月 21 13:10 test1 drwx--x--x. 2 root root 4096 4月 21 13:11 test2
5.rmdir (删除"空"目录)
[root@xiaoluo ~]# rmdir [-p] 目录名称 参数: -p :连同上层『空的』目录也一起删除 例: [root@xiaoluo home]# ls -l drwxr-xr-x. 2 root root 4096 4月 21 13:08 test drwxr-xr-x. 3 root root 4096 4月 21 13:10 test1 drwx--x--x. 2 root root 4096 4月 21 13:11 test2 [root@xiaoluo home]# rmdir test [root@xiaoluo home]# rmdir test1 rmdir: 删除 "test1" 失败: 目录非空 [root@xiaoluo home]# rmdir -p test1/test2/test3/test4/ [root@xiaoluo home]# ls -l drwx--x--x. 2 root root 4096 4月 21 13:11 test2
# 利用 -p 这个参数,立刻就可以将 test1/test2/test3/test4 一次删除~ # 不过要注意的是,这个 rmdir 仅能【删除空的目录】。
二、
1.ls (查看文件和目录)
参数: -a :全部的文件,连同隐藏文件( 开头为 . 的目录) 一起列出来~ -A :全部的文件,连同隐藏文件,但不包括 . 与 .. 这两个目录,一起列出来~ -d :仅列出目录本身,而不是列出目录内的文件数据 -f :直接列出结果,而不进行排序 (ls 预设会以文件名排序!) -F :根据文件、目录等信息,给予附加数据结构,例如: *:代表可执行文件; /:代表目录; =:代表 socket 档案; |:代表 FIFO 文件; -h :列出文件的打小(例如GB、KB等等) -i :列出 inode 位置,而非列出文件属性; -l :长数据串行出,包含文件的属性等等数据; -n :列出 UID 与 GID 而非使用者与群组的名称 (UID与GID会在账号管理提到!) -r :将排序结果反向输出,例如:原本文件名由小到大,反向则为由大到小; -R :连同子目录内容一起列出来; -S :以文件容量大小排序! -t :依时间排序 --color=never :不要依据文件特性给予颜色显示; --color=always :显示颜色 --color=auto :让系统自行依据设定来判断是否给予颜色 --full-time :以完整时间模式 (包含年、月、日、时、分) 输出 --time={atime,ctime} :输出 access 时间或 改变权限属性时间 (ctime) 而非内容变更时间 (modification time)
shutdown -c 取消已经执行的shutdown命令
-r 重启
-h 定时关机
Reboot 重启
halt ,poweroff关机
history 显示历史目录
2. cp (复制命令)
[root@xiaoluo ~]# cp [-adfilprsu] 源文件(source) 目的文件(destination)
[root@xiaoluo ~]# cp [options] source1 source2 source3 .... directory
参数:
-a :相当于 -pdr 的意思;
-d :若来源文件为链接文件的属性(link file),则复制链接文件属性而非档案本身;
-f :为强制 (force) 的意思,若有重复或其他疑问时,不会询问使用者,而强制复制;
-i :若目的文件(destination)已经存在时,在覆盖时会先询问是否真的动作!
-l :进行硬式连结 (hard link) 的连结文件建立,而非复制文件本身;
-p :连同文件的属性一起复制过去,而非使用默认属性;
-r :递归持续复制,用于目录的复制行为;
-s :复制成为符号链接文件 (symbolic link),亦即『快捷方式』文件;
-u :若 destination 比 source 旧才更新 destination !
最后需要注意的,如果来源档有两个以上,则最后一个目的文件一定要是『目录』
3.rm (删除文件或目录)
[root@xiaoluo ~]# rm [-fir] 文件或目录
参数:
-f :就是 force 的意思,强制移除;
-i :互动模式,在删除前会询问使用者是否动作
-r :递归删除,最常用在目录的删除
例:
[root@xiaoluo tmp]# rm bashrc
rm:是否删除普通文件 "bashrc"?y
[root@xiaoluo tmp]# rm wtmp wtmp2
rm:是否删除普通文件 "wtmp"?y
rm:是否删除普通文件 "wtmp2"?y
[root@xiaoluo tmp]# rm -rf etc/ -->> 这个就会强制将etc这个目录以及里面的所有子目录、文件删除掉
4.mv (移动文件与目录、文件重命名)
[root@xiaoluo ~]# mv [-fiu] source destination [root@xiaoluo ~]# mv [options] source1 source2 source3 .... directory 参数: -f :force 强制的意思,强制直接移动而不询问; -i :若目标文件 (destination) 已经存在时,就会询问是否覆盖! -u :若目标文件已经存在,且 source 比较新,才会更新 (update)
实例一:复制一档案,建立一目录,将档案移动到目录中
[root@xiaoluo tmp]# cp ~/.bashrc bashrc
[root@xiaoluo tmp]# mkdir mvtest
[root@xiaoluo tmp]# mv bashrc mvtest/
[root@xiaoluo tmp]# cd mvtest/
[root@xiaoluo mvtest]# ls
bashrc
实例二:将刚刚的目录名称更名为 mvtest2
[root@xiaoluo tmp]# mv mvtest mvtest2
三、查看文件内容
1.cat 由第一行开始显示文件内容
[root@xiaoluo~]# cat [-AEnTv]
参数:
-A :相当于 -vET 的整合参数,可列出一些特殊字符~
-E :将结尾的断行字符 $ 显示出来;
-n :打印出行号;
-T :将 [tab] 按键以 ^I 显示出来;
-v :列出一些看不出来的特殊字符
2.tac (反向显示)
[root@xiaoluo ~]# tac /etc/sysconfig/network
HOSTNAME=xiaoluo
NETWORKING=yes
tac是将cat反写,所以它的功能就与cat相反, cat 是由【第一行到最后一行连续显示在屏幕上】,而 tac 则是『【由最后一行到第一行反向在屏幕上显示出来 】。
4.more (翻页查看)
[root@xiaoluo ~]# more /etc/passwd
root:x:0:0:root:/root:/bin/bash
bin:x:1:1:bin:/bin:/sbin/nologin
daemon:x:2:2:daemon:/sbin:/sbin/nologin
adm:x:3:4:adm:/var/adm:/sbin/nologin
lp:x:4:7:lp:/var/spool/lpd:/sbin/nologin
sync:x:5:0:sync:/sbin:/bin/sync
shutdown:x:6:0:shutdown:/sbin:/sbin/shutdown
halt:x:7:0:halt:/sbin:/sbin/halt
mail:x:8:12:mail:/var/spool/mail:/sbin/nologin
uucp:x:10:14:uucp:/var/spool/uucp:/sbin/nologin
operator:x:11:0:operator:/root:/sbin/nologin
games:x:12:100:games:/usr/games:/sbin/nologin
gopher:x:13:30:gopher:/var/gopher:/sbin/nologin
ftp:x:14:50:FTP User:/var/ftp:/sbin/nologin
nobody:x:99:99:Nobody:/:/sbin/nologin
dbus:x:81:81:System message bus:/:/sbin/nologin
rpc:x:32:32:Rpcbind Daemon:/var/cache/rpcbind:/sbin/nologin
usbmuxd:x:113:113:usbmuxd user:/:/sbin/nologin
abrt:x:173:173::/etc/abrt:/sbin/nologin
pegasus:x:66:65:tog-pegasus OpenPegasus WBEM/CIM services:/var/lib/Pegasus:/sbin
/nologin
cimsrvr:x:134:134:tog-pegasus OpenPegasus WBEM/CIM services:/var/lib/Pegasus:/sb
in/nologin
--More--(36%)
在使用more命令时,我们通常可以使用以下一些快捷键来帮助我们
- 空格键 (space):代表向下翻一页;
- Enter :代表向下翻【一行】;
- /字符串 :代表在这个显示的内容当中,向下搜寻【字符串】;
- :f :立刻显示出文件名以及目前显示的行数;
- q :代表立刻离开 more ,不再显示该文件内容。
5. less (翻页查看)
[root@xiaoluo ~]# less /etc/passwd
root:x:0:0:root:/root:/bin/bash
bin:x:1:1:bin:/bin:/sbin/nologin
daemon:x:2:2:daemon:/sbin:/sbin/nologin
adm:x:3:4:adm:/var/adm:/sbin/nologin
lp:x:4:7:lp:/var/spool/lpd:/sbin/nologin
sync:x:5:0:sync:/sbin:/bin/sync
shutdown:x:6:0:shutdown:/sbin:/sbin/shutdown
halt:x:7:0:halt:/sbin:/sbin/halt
mail:x:8:12:mail:/var/spool/mail:/sbin/nologin
uucp:x:10:14:uucp:/var/spool/uucp:/sbin/nologin
operator:x:11:0:operator:/root:/sbin/nologin
games:x:12:100:games:/usr/games:/sbin/nologin
gopher:x:13:30:gopher:/var/gopher:/sbin/nologin
ftp:x:14:50:FTP User:/var/ftp:/sbin/nologin
nobody:x:99:99:Nobody:/:/sbin/nologin
dbus:x:81:81:System message bus:/:/sbin/nologin
rpc:x:32:32:Rpcbind Daemon:/var/cache/rpcbind:/sbin/nologin
usbmuxd:x:113:113:usbmuxd user:/:/sbin/nologin
abrt:x:173:173::/etc/abrt:/sbin/nologin
pegasus:x:66:65:tog-pegasus OpenPegasus WBEM/CIM services:/var/lib/Pegasus:/sbin/nologin
cimsrvr:x:134:134:tog-pegasus OpenPegasus WBEM/CIM services:/var/lib/Pegasus:/sbin/nologin
/etc/passwd
less的用法比more要更灵活,使用more命令时我们没有办法向前翻页,只能往后看,而less命令可以通过(PageUp) (PageDown)来进行前后的翻页查看文件。
less命令的一些常用快捷键操作如下:
- 空格键 :向下翻动一页;
- [pagedown]:向下翻动一页;
- [pageup] :向上翻动一页;
- /字符串 :向下搜寻【字符串】的功能;
- ?字符串 :向上搜寻【字符串】的功能;
- n :重复前一个搜寻 (与 / 或 ? 有关!)
- N :反向的重复前一个搜寻 (与 / 或 ? 有关!)
- q :离开 less 这个程序;
6. head (取出前几行)
[root@xiaoluo ~]# head [-n number] 文件 参数: -n :后面接数字,代表显示几行的意思
实例: [root@xiaoluo ~]# head /etc/man.config # 默认的情况中,显示前面十行!若要显示前 20 行,就得要这样: [root@xiaoluo ~]# head -n 20 /etc/man.config
7.tail (取出后面几行)
[root@xiaoluo ~]# tail [-n number] 文件
参数:
-n :后面接数字,代表显示几行的意思
范例:
[root@xiaoluo ~]#tail /etc/man.config
# 默认的情况中,显示最后的十行!若要显示最后的 20 行,就得要这样:
[root@xiaoluo ~]# tail -n 20 /etc/man.config
四、1. touch 命令 (修改文件时间与创建新文件)
[root@xiaoluo ~]# touch [-acdmt] 文件
选项与参数:
-a :仅修订 access time;
-c :仅修改文件的时间,若该文件不存在则不创建新文件;
-d :后面可以接欲修订的日期而不用目前的日期,也可以使用 --date="日期或时间"
-m : 仅修改 mtime ;
-t : 后面可以接欲修订的时间而不用目前的时间,格式为[YYMMDDhhmm]
实例一:新建一个空的文件 [root@xiaoluo ~]# cd /home/ [root@xiaoluo home]# touch test.txt [root@xiaoluo home]# ls -l test.txt -rw-r--r--. 1 root root 0 4月 25 22:07 test.txt # 注意,这个文件的大小是 0 !在默认的状态下,如果 touch 后面有接文件, # 则该文件的三个时间 (atime/ctime/mtime) 都会更新为目前的时间。若该文件不存在, # 则会主动的创建一个新的空的文件!! 实例二:将 ~/.bashrc 复制成为 bashrc,假设复制完全的属性,检查其日期 [root@xiaoluo home]# cp -a ~/.bashrc bashrc [root@xiaoluo home]# ls -l bashrc -rw-r--r--. 1 root root 177 4月 8 22:43 bashrc <==这是 mtime [root@xiaoluo home]# ls -l --time=atime bashrc -rw-r--r--. 1 root root 177 4月 25 21:48 bashrc <==这是 atime [root@xiaoluo home]# ls -l --time=ctime bashrc -rw-r--r--. 1 root root 177 4月 25 22:08 bashrc <==这是 ctime
实例三:修改实例二的bashrc文件,将日期调整为三天前
[root@xiaoluo home]# touch -d "3 days ago" bashrc
[root@xiaoluo home]# ls -l bashrc ; ls -l --time=atime bashrc ; ls -l --time=ctime bashrc
-rw-r--r--. 1 root root 177 4月 22 22:12 bashrc <==这是 mtime
-rw-r--r--. 1 root root 177 4月 22 22:12 bashrc <==这是 atime
-rw-r--r--. 1 root root 177 4月 25 22:12 bashrc <==这是 ctime
# 注意,日期在 atime 与 mtime 都改变了,但是 ctime 并没有改变!
实例四:将实例三的bashrc日期改为 2013/4/24 23:23
[root@xiaoluo home]# touch -t 1304242323 bashrc
[root@xiaoluo home]# ls -l bashrc ; ls -l --time=atime bashrc ; ls -l --time=ctime bashrc
-rw-r--r--. 1 root root 177 4月 24 23:23 bashrc <==这是 mtime
-rw-r--r--. 1 root root 177 4月 24 23:23 bashrc <==这是 atime
-rw-r--r--. 1 root root 177 4月 25 22:11 bashrc <==这是 ctime
五、文件与目录的默认权限与隐藏权限
1.umask (文件默认权限)
[root@xiaoluo home]# umask
0022
[root@xiaoluo home]# umask -S
u=rwx,g=rx,o=rx
查看方式有两种,一种可以直接输入 umask ,就可以看到数字型态的权限配置分数, 一种则是加入 -S (Symbolic) 这个选项,就会以符号类型的方式来显示出权限了。这里显示的 umask 有四组数字, 第一组是特殊权限用的,我们先不要理他,先看后面三组数字。
在默认权限的属性上,目录与文件是不一样的。由于我们不希望文件具有可执行的权限,默认情况下,文件是没有可执行(x)权限的。因此:
- 若使用者创建为 文件 则默认【没有可运行( x )权限】,亦即只有 rw 这两个权限,也就是最大为 666 分,默认权限如下: -rw-rw-rw-
- 若使用者创建为 目录 ,则由于 x 与是否可以进入此目录有关,因此默认为所有权限均开放,亦即为 777 分,默认权限如下: drwxrwxrwx
umask 指定的是【该默认值需要减掉的权限】因为 r、w、x 分别是 4、2、1 ,也就是说,当要拿掉能写的权限,就是输入 2 分,而如果要拿掉能读的权限,也就是 4 分,那么要拿掉读与写的权限,也就是 6 分,而要拿掉执行与写入的权限,也就是 3 分,如果我拿掉5 分的话,那就是拿掉读与执行的权限啦!如果以上面的例子来说明的话,因为 umask 为 022 ,所以 user 并没有被拿掉属性,不过 group 与 others 的属性被拿掉了 2 ( 也就是 w 这个属性 ),那么由于当使用者:
- 建立档案时:(-rw-rw-rw-) – (-----w--w-) ==> -rw-r--r--
- 建立目录时:(drwxrwxrwx) – (d----w--w-) ==> drwxr-xr-x
[root@xiaoluo home]# umask
0022
[root@xiaoluo home]# touch test1
[root@xiaoluo home]# mkdir test2
[root@xiaoluo home]# ls -
-rw-r--r--. 1 root root 0 4月 25 22:29 test1
drwxr-xr-x. 2 root root 4096 4月 25 22:29 test2
所以,umask与文件和目录的默认权限是有很大关系的。如果我们希望编写的文件具有的权限是 -rw-rw-r-- 权限,则此时应该将umask改成 002 才对。例如如下例子:
[root@xiaoluo home]# umask 002 // 这样文件的默认权限就是默认 其他组权限拿掉 可读r权限
[root@xiaoluo home]# touch test3 [root@xiaoluo home]# mkdir test4 -rw-rw-r--. 1 root root 0 4月 25 22:37 test3 drwxrwxr-x. 2 root root 4096 4月 25 22:37 test4
2.
更改文件权限:
chgrp更改文件所属组 想要更改子目录以及子文件,-R
chown更改文件的所有者 -R 只适用于目录
chmod更改文件权限 r=4 w=2 x=1
直接赋予:ugo=rwx
添加减少:ugo+/-rwx
数字添加:r=4 w=2 x=1 chmod 741 [文件]
六、文件隐藏属性
chattr [+-=][Asaci][文件名或目录名] +-=分别表示增加,减少和设定
添加:
A:文件或目录的atime将不可修改
s:数据同步写入磁盘中
a:只能追加不能删除,非root用户不能设定该属性
c:自动压缩该文件,读取时会自动解压
i:文件不能重命名,删除、设定链接、写入及新增数据。
参数: + :增加某一个特殊参数,其他原本存在参数则不动。 - :移除某一个特殊参数,其他原本存在参数则不动。 = :设定一定,且仅有后面接的参数 注意:这个属性设定上面,比较常见的是 a 与 i 的设定值,而且很多设定值必须要身为 root 才能够设定的! 范例: [root@xiaoluo home]# touch attrtest
[root@xiaoluo home]# chattr +i attrtest
[root@xiaoluo home]# rm attrtest
rm:是否删除普通空文件 "attrtest"?y
rm: 无法删除"attrtest": 不允许的操作
# 只要给该文件加上了-i这个属性后,连 root 也没有办法将这个档案删除!
[root@xiaoluo home]# chattr -i attrtest
+i 可以让一个文件无法被更改
2. lsattr (显示文件的隐藏属性)
[root@xiaoluo ~]# lsattr [-adR] 文件或目录 选项与参数: -a :将隐藏文件的属性也lie出来; -d :如果接的是目录,仅列出目录本身的属性而非目录内的文件名; -R :连同子目录的数据也一并列出来!
[root@xiaoluo home]# chattr +aij attrtest
[root@xiaoluo home]# lsattr attrtest
----ia---j---e- attrtest
七、搜索文件
1.which (寻找"执行文件")
[root@xiaoluo ~]# which [-a] command 参数: -a :将所有可以找到的指令均列出,而不止第一个被找到的指令名称 [root@xiaoluo ~]# which passwd -->> 列出第一个找到的可执行文件
/usr/bin/passwd
[root@xiaoluo ~]# which -a tracepath -->> 列出所有找到的同名可执行文件
/bin/tracepath /usr/sbin/tracepath
这个指令是根据【PATH】这个环境变量所规范的路径,去搜寻【执行文件】的文件名。所以,重点是找出【执行文件】而已!且 which 后面接的是要是 完整的文件名字 。若加上 -a 参数,则可以列出所有的可以找到的同名执行文件,而非仅显示第一个而已。
2.whereis (寻找特定文件)
[root@xiaoluo ~]# whereis [-bmsu] 文件名或目录名 参数: -b :只找 binary 的文件
-m :只找在说明文件 manual 路径下的文件 -s :只找 source 来源文件
-u :没有说明文件的文件
[root@xiaoluo ~]# whereis passwd
passwd: /usr/bin/passwd /etc/passwd /usr/share/man/man1/passwd.1.gz /usr/share/man/man5/passwd.5.gz
# 任何与 passwd 有关的文件名都会被列出来
[root@xiaoluo ~]# whereis -b passwd
passwd: /usr/bin/passwd /etc/passwd
[root@xiaoluo ~]# whereis -m passwd
passwd: /usr/share/man/man1/passwd.1.gz /usr/share/man/man5/passwd.5.gz
3.locate (寻找特定文件)
[root@xiaoluo ~]# locate filename
[root@xiaoluo ~]# locate passwd
/etc/passwd
/etc/passwd-
/etc/dovecot/conf.d/auth-passwdfile.conf.ext
/etc/pam.d/passwd
/etc/samba/smbpasswd
/etc/security/opasswd
/etc/sysconfig/ha/web/secure/passwd.php
/lib64/security/pam_passwdqc.so
/lib64/security/pam_unix_passwd.so
/usr/bin/RSA_SecurID_getpasswd
...............此处省略N个字!!!!!!.................
locate的使用比whereis更简单,直接在后面输入 "文件的部分名称" 后,就能得到结果了。例如我们这个例子输入的是 locate passwd,那么,在完整的文件名(包含路径名称)中,只要其中有passwd,就会被搜索显示出来。如果忘记了某个文件的完整文件名时,这是以恶很方便好用的命令。
locate来搜索文件也非常的快,这是因为locate与whereis命令一样都是从数据库中去搜索文件,所以比find命令直接去硬盘里搜索速度要快的多。
4.find
[root@xiaoluo ~]# find [PATH] [option] [action] 参数: 1. 与时间有关的参数: -atime n :表示访问或执行大于或小于n天的文件 -ctime n :表示写入更改inode属性的时间大于或小于n天的文件 -mtime n :表示写入时间大于或小于n天的文件 -newer file :file 为一个存在的文件,意思是说,只要档案比 file 还要新, 就会被搜索出来2. 与使用者或组名有关的参数: -uid n :n 为数字,这个数字是用户的账号 ID,亦即 UID ,这个 UID 是记录在 /etc/passwd 里面与账号名称对应的数字。这方面我们会在第四篇介绍。 -gid n :n 为数字,这个数字是组名的 ID,亦即 GID,这个 GID 记录在 /etc/group,
-user name :name 为使用者账号名称 -group name:name 为组名,例如 users ; -nouser :寻找档案的拥有者不存在 /etc/passwd 的人! -nogroup :寻找档案的拥有群组不存在于 /etc/group 的文件! 当您自行安装软件时,很可能该软件的属性当中并没有文件拥有者, 这是可能的!在这个时候,就可以使用 -nouser 与 -nogroup 搜寻。 3. 与文件权限及名称有关的参数: -name filename:搜寻文件名为 filename 的文件; -size [+-]SIZE:搜寻比 SIZE 还要大(+)或小(-)的文件。这个 SIZE 的规格有: c: 代表 byte, k: 代表 1024bytes。所以,要找比 50KB 还要大的文件,就是『 -size +50k 』 -type TYPE :搜寻文件的类型为 TYPE 的,类型主要有:一般正规文件 (f), 装置文件 (b, c), 目录 (d), 连结文件 (l), socket (s), 及 FIFO (p) 等属性。
可以使用下面的Linux find 命令删除非空目录,如:
find ./ -name “dir1” -type d -exec rm -rf {} +或者
find ./ -name “dir1” -type d -exec rm -rf ;
Linux find 命令结合xargs命令实现删除非空目录
4. 额外可进行的动作:
-exec command :command 为其他指令,-exec 后面可再接额外的指令来处理搜寻到
的结果。
-print :将结果打印到屏幕上,这个动作是预设动作!
逻辑关系-a(与)-o(或)
实例一:将过去系统上面 24 小时内有改变过内容 (mtime) 的文件列出
[root@xiaoluo ~]# find / -mtime 实例二:寻找 /etc 底下的文件,如果文件日期比 /etc/passwd 新就列[root@xialuo ~]# find /etc -newer /etc/passwd
实例三:搜寻 /home 底下属于 xiaoluo 的文件
[root@xiaoluo ~]# find /home -user xiaoluo
实例四:搜寻系统中不属于任何人的文件
[root@xiaoluo ~]# find / -nouser
实例五:找出文件名为 passwd 这个文件
[root@xiaoluo ~]# find / -name passwd
实例六:搜寻文件属性为 f (一般文件) 的文件
[root@xiaoluo ~]# find /home -type f
实例七:搜寻文件当中含有 SGID/SUID/SBIT 的属性
[root@xiaoluo ~]# find / -perm +7000
实例八:将上个范例找到的文件使用 ls -l 列出来
[root@xiaoluo ~]# find / -perm +7000 -exec ls -l {} ;
# 注意到,那个 -exec 后面的 ls -l 就是额外的指令,
# 而那个 {} 代表的是【由 find 找到的内容】的意思~所以, -exec ls -l {}
# 就是将前面找到的那些档案以 ls -l 列出长的数据!至于 ; 则是表示
# -exec 的指令到此为止的意思。 意思是说,整个指令其实只有在
# -exec (里面就是指令下达) ;
# 也就是说,-exec 最后一定要以 ; 结束才行!
实例九:找出系统中,大于 1MB 的文件
[root@xiaoluo ~]# find / -size +1000k