Linux 学习笔记之超详细基础linux命令 Part 10

Linux学习笔记之超详细基础linux命令

by:授客 QQ1033553122

---------------------------------接Part 9------------------------------

find命令

方法:find
[路径]
[选项]

表达式

说明:从指定路径开始向下搜素满足表达式的文件或目录,不指定目录路径时查找当前目录。当查找到用户不具有执行权限的目录时,屏幕将显示“权限不够”等提示信息。

主要表达式:

-name
文件名

按文件名查找,可使用通配符

-group
组群名

查找文件的所属组群为指定组群的文件

-user
用户名

查找文件所有者为指定用户的文件

-type
文件类型

按照文件类型查找,其中d为目录文件,l为符号链接文件

-size
[+][-]文件大小

查找指定大小的文件

例子:查找/etc目录中以“fs”开头的文件和目录[root权限]

[laiyu@localhost ~]$ find
/etc -name fs*

find: `/etc/dhcp':
Permission denied

find: `/etc/sudoers.d':
Permission denied

find: `/etc/sssd':
Permission denied

...

[laiyu@localhost ~]$
su

Password:

[root@localhost laiyu]#
find /etc -name fs*

/etc/fstab

例子:查找当前目录中的所有符号链接文件

[laiyu@localhost ~]$ find
-type l

./.xinputrc

./.kde/cache-localhost.localdomain

./.kde/tmp-localhost.localdomain

./.kde/socket-localhost.localdomain

./.pulse/8811a723d421b24ed1412d7e00000033-runtime

./file.lnk

注意:find命令将显示满足条件的所有文件,包括隐藏文件和隐藏目录。

例子:查找当前目录中所有大于10kb的文件和目录[反之:-10k则表示小于10kb]

[laiyu@localhost ~]$ find
-size +10k

./.mozilla/firefox/scrsbbvc.default/cesessions/1351781697741.js

./.mozilla/firefox/scrsbbvc.default/cesessions/1352521543586.js

...

#Debain下测试

例子:在当前目录下查找名为fil2的文件,排除对当前目录下的fil目录的搜索

builder:~# ls

fil  myfile

builder:~# ls -R
myfile/   
#说明,-R必须大写

fil2

builder:~# find . -path
./fil -prune -o -name file2 -print

builder:~# find . -path
./fil -prune -o -name fil2 -print

./myfile/fil2

builder:~# find . -path
./fil -prune -o -name fil2 -print

例子:在当前目录下查找名为tes的文件或目录,排除对Picutre目录的搜索

[root@localhost ~]# find .
-path ./Pictures -prune -o -name tes -print

./tes

./tes/tes

例子:在当前目录下查找名为tes的文件或目录,排除对tes目录下的tes目录的搜索

[root@localhost ~]# find .
-path ./tes/tes -prune -o -name tes -print

./tes/tes

例子:在当前目录下查找名为fil2的文件,排除对当前目录下的fil以及file目录的搜索

builder:~# ls

fil  file  myfile

builder:~# find . \(-path
./fil -o -path ./file \) -prune -o -name fil2 -print

find: invalid ex pression;
you have used a binary operator '-o' with nothing before
it.

builder:~# find . \( -path
./fil -o -path ./file \) -prune -o -name fil2 -print

./myfile/fil2

说明:\(  \)
->(),,,注意括号和-path有空格分开

grep命令

方法:grep
[选项]

字符串
文件列表

功能:从指定的文本文件或标准输出中查找符合条件的字符串,默认显示其所在行的内容

主要选项:

-n(number)

显示行号

-v(invert)

显示不包含指定字符串的行

-i(ignore)

查找时不区分大小写

例子:查找/etc/passwd文件中包含“laiyu”的行,并显示其行号

[laiyu@localhost ~]$ grep
-n laiyu /etc/passwd

37:laiyu:x:500:500:laiyu:/home/laiyu:/bin/bash

du命令

方法:du
[选项]
[目录|文件]

功能:显示目录或文件大小,默认以KB为单位,参数为目录,默认递归显示指定目录及其所有子目录的大小

主要选项:

-a(all)

显示指定目录及其所有子目录和文件的大小,默认只显示目录的大小

-h(human)

以易读方式显示目录或文件的大小

-s(summarize)

只显示指定目录的大小,而不显示其子目录的大小

-b

以字节为单位列出磁盘空间使用情况

-k
以1024字节为单位列出磁盘空间使用情况。

-c
最后再加上一个总计(系统缺省设置)。

-l
计算所有的文件大小,对硬链接文件,则计算多次。

-x
跳过在不同文件系统上的目录不予统计。

[laiyu@localhost ~]$ du -sh
/home/laiyu

53M   
/home/laiyu

小知识: du
/etc | sort -nr | more

sort
的参数 -nr
表示要以数字排序法进行反向排序,因为我们要对目录大小做排序,所以不可以使用 human-readable

的大小输出,

不然目录大小中会有 K、M

等字样,会造成排序不正确。

文件归档与压缩

归档与压缩文件的Shell命令

1.tar命令

格式:tar
[选项]

归档/压缩文件
[目录或文件列表]

功能:将多个文件或目录归档为tar文件,如果使用相关选项还可压缩归档文件。

备注:建议使用tar归档时,让归档文件中包含一个子目录,解压归档文件时,子目录会被产生,所有文件都会放在这个目录里。也就是说把

所有文件都放到一个子目录下,然后归档该子目录

备注:tar会把文件的拥有者和权限存在备份文件中,并且保留完整的目录结构,符号链接,物理链接,所以使用tar可以说是在同一操作系统

上拷贝或者搬移整个树状目录的最好方法。

主要选项说明:

-c(create) 
创建归档压缩文件

-r 
向归档/压缩文件追加文件和目录

-t(list) 
显示归档/压缩文件的内容

-u(update)

更新归档或压缩文件

-x(extract)

还原归档或压缩文件中的文件和目录

-v(verbose)

显示命令的执行过程(可以同时用两个v选项,以显示更多的信息)

-z(gzip)

采用gzip方式压缩/解压缩归档文件

-j
采用bzip2方式压缩/解压缩归档文件

-f tar命令的必需选项

例:将/ecc目录下的所有conf文件归档为etc.tar文件

[laiyu@localhost ~]$ tar
-cf etc.tar /etc/*.conf

tar: Removing leading `/'
from member names

tar:
/etc/autofs_ldap_auth.conf: Cannot open: Permission
denied

tar: /etc/libaudit.conf:
Cannot open: Permission denied

tar: /etc/sudo-ldap.conf:
Cannot open: Permission denied

tar: Exiting with failure
status due to previous errors

[laiyu@localhost ~]$ ls |
grep etc

etc

etc.tar

例子:etc.tar中添加文件

[laiyu@localhost ~]$ tar
-rf etc.tar testfile

例子:将/etc目录下的所有conf文件归档为etc.tar.gz文件

[laiyu@localhost ~]$ tar
-cf etc.tar.gz /etc/*.conf

tar: Removing leading `/'
from member names

tar:
/etc/autofs_ldap_auth.conf: Cannot open: Permission
denied

tar: /etc/libaudit.conf:
Cannot open: Permission denied

tar: /etc/sudo-ldap.conf:
Cannot open: Permission denied

tar: Exiting with failure
status due to previous errors

[laiyu@localhost ~]$ ls |
grep etc

etc

etc.tar

etc.tar.gz

例子:将文件file归档压缩为file.tgz文件

[laiyu@localhost ~]$ tar
-czvf file.tgz file

例子:查看etc/tar.gz文件的内容

[laiyu@localhost ~]$ tar
-tf etc.tar.gz   
#注意这里的f选项不可少

etc/asound.conf

etc/cas.conf

etc/cgconfig.conf

etc/cgrules.conf

etc/cgsnapshot_blacklist.conf

etc/dnsmasq.conf

...

etc/yum.conf

...

注:归档/压缩操作时,系统会保留文件和目录的路径,并将绝对路径变为相对路径

例:将etc.tar文件中的yum.conf文件还原到当前目录

[laiyu@localhost ~]$ tar
-xf etc.tar etc/yum.conf

tar: etc/yum.conf: Cannot
open: File exists

tar: Exiting with failure
status due to previous errors

[laiyu@localhost ~]$ tar
-xf etc.tar test/yum.conf

tar: test/yum.conf: Not
found in archive

tar: Exiting with failure
status due to previous errors

[laiyu@localhost ~]$ cd
test

[laiyu@localhost test]$
mkdir etc

[laiyu@localhost test]$
ls

etc  file  file1  linux

[laiyu@localhost test]$ tar
-xf etc.tar etc/yum.conf

tar: etc.tar: Cannot open:
No such file or directory

tar: Error is not
recoverable: exiting now

[laiyu@localhost test]$ mv
../etc.tar .

[laiyu@localhost test]$
ls

etc  etc.tar  file  file1  linux

[laiyu@localhost test]$ tar
-xf etc.tar etc/yum.conf

[laiyu@localhost test]$ ls
| grep etc

etc

etc.tar

[laiyu@localhost test]$ ls
etc/

yum.conf

说明:由于进行归档/压缩操作采用的是相对路径,所以还原某个文件时必须使用相对路径。

1.tar: etc/yum.conf: Cannot
open: File exists出现该错误的原因是源目录的权限问题,比如源目录是root创建的,其它用户没写的权限,而当前操作者是普通用户laiyu,因为其他用户没写的权限,这样一来,写操作就没权限执行了。

2.如果你想把压缩文件解压到某个目录下,则先进入该目录,然后tar
[选项]

压缩/归档文件

或tar
[选项]

压缩/归档文件

压缩/归档文件中的首目录

(注:这里的首目录形如上面例子中的etc,可以是已经存在的或不存在的)或者
tar
[选项]

压缩/归档文件

压缩/归档文件中的首目录/文件名,总之,形式要和压缩包对应

也就是说,你创建时文件名采用了路径的形式,如tar -cf etc.tar
/etc/*,那么当你解压时,可以这样:tar
-xf etc.tar
或 tar
-xf etc.tar etc
或 tar
-xf etc.tar etc/yum.conf

注意:etc前不能加/,,加了则变成根目录下的etc目录了,为绝对路径

例子:将etc.tar.gz文件的所有文件还原到/tmp目录

[laiyu@localhost ~]$ tar
-xzf etc.tar.gz

gzip: stdin: not in gzip
format 
说明这貌似因为创建时使用tar -cf
,没用tar
-czf,,,所以解压时也不能用

tar: Child returned status
1

tar: Error is not
recoverable: exiting now

[laiyu@localhost ~]$ cd
/tmp

[laiyu@localhost tmp]$
pwd

/tmp

[laiyu@localhost tmp]$ tar
-xvf ../home/laiyu/etc.tar.gz

etc/asound.conf

etc/cas.conf

...

[laiyu@localhost ~]$ cd
/tmp/

[laiyu@localhost tmp]$ ls |
grep etc

etc

[laiyu@localhost tmp]$ ls
etc/

asound.conf            
   krb5.conf                    
prelink.conf

cas.conf                  
latrace.conf                 
readahead.conf

cgconfig.conf             
ld.so.conf                   
reader.conf

cgrules.conf              
libuser.conf                 
request-key.conf

cgsnapshot_blacklist.conf 
logrotate.conf               
resolv.conf

dnsmasq.conf              
ltrace.conf                  
rsyslog.conf

dracut.conf               
mke2fs.conf                  
sestatus.conf

elinks.conf               
mtools.conf  
                smartd.conf

fprintd.conf              
nfsmount.conf                
sos.conf

gai.conf                  
nsswitch.conf                
sysctl.conf

grub.conf                 
ntp.conf                     
Trolltech.conf

gssapi_mech.conf    
      numad.conf                   
updatedb.conf

host.conf                 
oddjobd.conf                 
warnquota.conf

idmapd.conf               
openct.conf                  
yp.conf

kdump.conf                
pm-utils-hd-apm-restore.conf  yum.conf

说明:也就是说要解压到哪个目录就先进入到那个目录,然后解压

上一篇:[置顶] java 枚举


下一篇:Linux 学习笔记之超详细基础linux命令(the end)