免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 874 | 回复: 0
打印 上一主题 下一主题

命令 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2008-06-10 18:53 |只看该作者 |倒序浏览

                ls dir cd pwd clear man rm mv  mkdir touch cp ln ln-s chmod chown chgrp grep find
cat w who whoami locate which cal date file finger passwd su sudo free ps kill init shutdown du df fdisk  mount tar ....大概就这些命令吧,总结一下
ls dir是一样的 查看  ls -a -d -l 一般使用的就这3个,查看全部包括隐藏的,查看目录本身,查看权限
rm 删除 -f强制-i提示操作-R递归删除(其他的也可以仿造参数)  mkdir创建目录-p 创建所有父目录:例如:mkdir -p a/b/c/d.....
chmod 765 /home/test
chmod u=rwx,g=rw,o=x /home/test
格式有2种
chown 改所有者-c改描述
chown /home/a.txt root
chgrp改所属组
特别注意:这里有suid,sgid,T
suid:允许其他用户使用改文件的时候具有该文件所属用户的权限
sgid:大致同上
由于设置了suid,sgid的无论那个用户执行命令时,系统都会认为是root用户在执行,因此这样是不安全的,系统里面不应随便使用这种权限设置
格式:chmod u+s file
     chmod u-s file
T位,粘着位,权限中出现有t的标志,表示在该目录下面谁建立,谁就有权利删除,其他包括ROOT用户都不能删除
格式:chmod u+t file
用二进制的话就是1表示
cat 快速查看小文件-n输出编号 atc反转查看
find -name -user -group -size n[c] -perm -empty 。。。。。
格式:find / -name a
.....其他也差不多
-size有分为以block跟字节
-size 10
-size +10k
是不同的
还有find / -size 0 -exec rm -rf {}  \;find可以执行一部分的shell命令


file 查看文件类型
locate一个搜索的命令。不过前提是要进行一个数据库工作,大致就是将文件系统做一个索引,以便快速搜索
使用locate前必须先执行updatedb不然搜索不准确甚至搜索错误
可以设置为开机updatedb,方便去搜索 ,因为这个命令搜索速度很快
sudo切换用户-u以什么用户身份执行命令
umask查看当前用户权限 r 100 4                           w 010 2                         x 001 1umask表示禁止的权限
grep命令介绍
[color="#999999"]本文出自:OHaHa的学习心得[ohaha.ks.edu.tw] 作者:蓝色泡泡(panda@ks.edu.tw) (2002-03-15 08:02:00)
◎grep -- print lines matching a pattern (将符合样式的该行列出)
◎语法: grep [options]
PATTERN [FILE...]
grep用以在file内文中比对相对应的部分,或是当没有指定档案时,
由标准输入中去比对。 在预设的情况下,grep会将符合样式的那一行列出。
         此外,还有两个程式是grep的变化型,egrep及fgrep。         
         其中egrep就等同於grep -E ,fgrep等同於grep -F 。
◎参数
    1. -A NUM,--after-context=NUM
               除了列出符合行之外,并且列出後NUM行。
            
         ex:   $ grep -A 1 panda file
               (从file中搜寻有panda样式的行,并显示该行的後1行)
                                 
    2. -a或--text  
               grep原本是搜寻文字档,若拿二进位的档案作为搜寻的目标,
               则会显示如下的讯息: Binary file 二进位档名 matches 然後结束。
                  
               若加上-a参数则可将二进位档案视为文字档案搜寻,
               相当於--binary-files=text这个参数。
            
         ex:   (从二进位档案mv中去搜寻panda样式)
               (错误!!!)
               $ grep panda mv
               Binary file mv matches  
               (这表示此档案有match之处,详见--binary-files=TYPE )
               $
               (正确!!!)
               $ grep -a panda mv
      
    3. -B NUM,--before-context=NUM
               与 -A NUM 相对,但这此参数是显示除符合行之外
               并显示在它之前的NUM行。        
            
         ex:   (从file中搜寻有panda样式的行,并显示该行的前1行)
               $ grep -B 1 panda file
    4. -C [NUM], -NUM, --context[=NUM]  
               列出符合行之外并列出上下各NUM行,预设值是2。
            
         ex:   (列出file中除包含panda样式的行外并列出其上下2行)
               (若要改变预设值,直接改变NUM即可)
               $ grep -C[NUM]  panda file
            
    5. -b, --byte-offset
               列出样式之前的内文总共有多少byte ..
              
          ex:  $ grep -b  panda file  
               显示结果类似於:
                 0:panda
                66:pandahuang
               123:panda03
                   
    6. --binary-files=TYPE
               此参数TYPE预设为binary(二进位),若以普通方式搜寻,只有2种结果:
                 1.若有符合的地方:显示Binary file 二进位档名 matches
                 2.若没有符合的地方:什麽都没有显示。
                  
               若TYPE为without-match,遇到此参数,
               grep会认为此二进位档案没有包含任何搜寻样式,与-I 参数相同。
                  
               若TPYE为text, grep会将此二进位档视为text档案,与-a 参数相同。
                
     Warning: --binary-files=text 若输出为终端机,可能会产生一些不必要的输出。
              
    7. -c, --count
               不显示符合样式行,只显示符合的总行数。
               若再加上-v,--invert-match,参数显示不符合的总行数。
    8. -d ACTION, --directories=ACTION
               若输入的档案是一个资料夹,使用ACTION去处理这个资料夹。
               预设ACTION是read(读取),也就是说此资料夹会被视为一般的档案;
               若ACTION是skip(略过),资料夹会被grep略过:
               若ACTION是recurse(递),grep会去读取资料夹下所有的档案,
               此相当於-r 参数。
    9.  -E, --extended-regexp
               采用规则表示式去解释样式。
             
   10.  -e PATTERN, --regexp=PATTERN
               把样式做为一个partern,通常用在避免partern用-开始。  
   11.  -f FILE, --file=FILE
               事先将要搜寻的样式写入到一个档案,一行一个样式。
               然後采用档案搜寻。
               空的档案表示没有要搜寻的样式,因此也就不会有任何符合。
               
           ex: (newfile为搜寻样式档)
               $grep -f newfile file   
   12.  -G, --basic-regexp
               将样式视为基本的规则表示式解释。(此为预设)
       
   13.  -H, --with-filename
               在每个符合样式行前加上符合的档案名称,若有路径会显示路径。
               
           ex: (在file与testfile中搜寻panda样式)   
               $grep -H panda file ./testfile
                file:panda
                ./testfile:panda
                $
             
   14.  -h, --no-filename  
               与-H参数相类似,但在输出时不显示路径。
   15.  --help
               产生简短的help讯息。
   16.  -I
               grep会强制认为此二进位档案没有包含任何搜寻样式,
               与--binary-files=without-match参数相同。
                  
           ex:  $ grep -I  panda mv
   17.  -i, --ignore-case              
               忽略大小写,包含要搜寻的样式及被搜寻的档案。
               
           ex:  $ grep -i panda mv
               
   18.  -L, --files-without-match
               不显示平常一般的输出结果,反而显示出没有符合的档案名称。
   19.  -l, --files-with-matches               
               不显示平常一般的输出结果,只显示符合的档案名称。
   20.  --mmap               
               如果可能,使用mmap系统呼叫去读取输入,而不是预设的read系统呼叫。
               在某些状况,--mmap 能产生较好的效能。 然而,--mmap
               如果运作中档案缩短,或I/O 错误发生时,
               可能造成未定义的行为(包含core dump),。
               
   21.  -n, --line-number
               在显示行前,标上行号。
               
            ex:  $ grep -n  panda file  
                显示结果相似於下:
                行号:符合行的内容
   22.  -q, --quiet, --silent
               不显示任何的一般输出。请参阅-s或--no-messages
   23.  -r, --recursive
               递地,读取每个资料夹下的所有档案,此相当於 -d recsuse 参数。
   24.  -s, --no-messages
               不显示关於不存在或无法读取的错误讯息。
             
         小: 不像GNU grep,传统的grep不符合POSIX.2协定,
               因为缺乏-q参数,且他的-s 参数表现像GNU grep的 -q 参数。
               Shell Script倾向将传统的grep移植,避开-q及-s参数,
               且将输出限制到/dev/null。
            
        POSIX: 定义UNIX及UNIX-like系统需要提供的功能。                     
            
   25.  -V, --version       
          显示出grep的版本号到标准错误。
          当您在回报有关grep的bugs时,grep版本号是必须要包含在内的。
   26.  -v, --invert-match
          显示除搜寻样式行之外的全部。
                  
   27.  -w, --word-regexp
          将搜寻样式视为一个字去搜寻,完全符合该"字"的行才会被列出。
   28.  -x, --line-regexp
          将搜寻样式视为一行去搜寻,完全符合该"行"的行才会被列出
再转载一个
关于他的
http://www.yuanma.org/data/2006/0606/article_669.htm
文件查找
和内容过滤命令[转帖]
  grep、fgrep和egrep命令
  这组命令以指定模式搜索文件,并通知用户在什么文
件中搜索到与指定的模式匹配的字符串,并打印出所有包含该字符串的文本行,在该文本行的最前面是该行所在的文件名。grep命令一次只能搜索一个指定的模
式;egrep命令检索扩展的正则表达式(包括表达式组和可选项);fgrep命令检索固定字符串,它不识别正则表达式,是快速搜索命令。
  这
组命令在搜索与定位文件中特定的主题方面非常有用。要搜索的模式可以被认为是一些关键词,您可以用它们来搜索文件中包含的这些关键词。编写程序时,可以用
它来寻找某一个函数,或是相关的词组。grep命令的搜索功能比fgrep强大,因为grep命令的搜索模式可以是正则表达式,而fgrep却不能。有关
正则表达式请参见shell一章。
  该组命令中的每一个命令都有一组选项,利用这些选项可以改变其输出方式。例如,可以在搜索到的文本行上加入行号,或者只输出文本行的行号,或者输出所有与搜索模式不匹配的文本行,或只简单地输出已搜索到指定模式的文件名,并且可以指定在查找模式时忽略大小写。
  这组命令在指定的输入文件中查找与模式匹配的行。如果没有指定文件,则从标准输入中读取。正常情况下,每个匹配的行被显示到标准输出。如果要查找的文件是多个,则在每一行输出之前加上文件名。
  语法:
  grep [选项] [查找模式] [文件名1,文件名2,……]
  egrep [选项] [查找模式] [文件名1,文件名2,……]
  fgrep [选项] [查找模式] [文件名1,文件名2,……]
  这组命令各选项的含义为:
  - E 每个模式作为一个扩展的正则表达式对待。
  - F 每个模式作为一组固定字符串对待(以新行分隔),而不作为正则表达式。
  - b在输出的每一行前显示包含匹配字符串的行在文件中的字节偏移量。
  - c 只显示匹配行的数量。
  - i 比较时不区分大小写。
  - h 在查找多个文件时,指示grep不要将文件名加入到输出之前。
  - l 显示首次匹配串所在的文件名并用换行符将其隔开。当在某文件中多次出现匹配串时,不重复显示此文件名。
  - n 在输出前加上匹配串所在行的行号(文件首行行号为1)。
  - v 只显示不包含匹配串的行。
  - x 只显示整行严格匹配的行。
  - e expression 指定检索使用的模式。用于防止以“-”开头的模式被解释为命令选项。
  - f expfile 从expfile文件中获取要搜索的模式,一个模式占一行。
  对该组命令的使用还需注意以下方面:
 
 在命令后键入搜索的模式,再键入要搜索的文件。其中,文件名列表中也可以使用特殊字符,如“*”等,用来生成文件名列表。如果想在搜索的模式中包含有空
格的字符串,可以用单引号把要搜索的模式括起来,用来表明搜索的模式是由包含空格的字符串组成。否则,Shell将把空格认为是命令行参数的定界符,而
grep命令将把搜索模式中的单词解释为文件名列表中的一部分。在下面的例子中,grep命令在文件example中搜索模式“text file”。
  $ grep ’text file’ example
   用户可以在命令行上用Shell特殊字符来生成将要搜索的文件名列表。在下面的例子中,特殊字符“*”用来生成一个文件名列表,该列表包含当前目录下所有的文件。该命令将搜索出当前目录下所有文件中与模式匹配的行。
  $ grep data *
 
  特殊字符在搜索一组指定的文件时非常有用。例如,如果想搜索所有的C程序源文件中特定的模式,您可以用“*.c”来指定文件名列表。假设用户的
C程序中包含一些不必要的转向语句(goto语句),想要找到这些语句,可以用如下的命令来搜索并显示所有包含goto语句的代码行:
  $ grep goto *.c
 
 用户可以在命令行上键入搜索模式,也可以使用-f选项从指定文件中读取要搜索的模式。在文件中,每个搜索模式占一行。如果经常要搜索一组常见字符串时,
这个功能非常有用。在下面的例子中,用户要在文件exam中搜索字符串“editor”和“create”,就把要搜索的模式放置在文件mypats
中,然后,grep命令从文件mypats中读取要搜索的模式。
  $ cat mypats
  editor
  create
  $ grep -f mypats exam
  文件查找命令
  find命令
  功能:在目录结构中搜索文件,并执行指定的操作。此命令提供了相当多的查找条件,功能很强大。
  语法:find 起始目录 寻找条件 操作
  说明:find命令从指定的起始目录开始,递归地搜索其各个子目录,查找满足寻找条件的文件并对之采取相关的操作。
  该命令提供的寻找条件可以是一个用逻辑运算符not、and、or组成的复合条件。逻辑运算符and、or、not的含义为:
  (1)and:逻辑与,在命令中用“-a”表示,是系统缺省的选项,表示只有当所给的条件都满足时,寻找条件才算满足。例如:
  $ find ????ame ’tmp’ ????type c -user ’inin’
  该命令寻找三个给定条件都满足的所有文件。
  (2)or:逻辑或,在命令中用“-o”表示。该运算符表示只要所给的条件中有一个满足时,寻找条件就算满足。例如:
  $ find ????ame ’tmp’ ???? ????ame ’mina*’
 
  该命令查询文件名为’tmp’或是匹配’mina*’的所有文件。
  (3)not:逻辑非,在命令中用“!”表示。该运算符表示查找不满足所给条件的文件。例如:
  $ find ! ????ame ’tmp’
  该命令查询文件名不是’tmp’的所有文件。
  需要说明的是:当使用很多的逻辑选项时,可以用括号把这些选项括起来。为了避免Shell本身对括号引起误解,在话号前需要加转义字符“”来去除括号的意义。
  例:$ find (????ame ’tmp’ ????type c -user ’inin’ )
  寻找条件有以下选项:
  首先,下列各个选项中的n值可以有三种输入方式,假设n为20,则:
  +20 表示20以后(21,22,23等)
  -20 表示20以前(19,18,17等)
  20 表示正好是20
  1. 以名称和文件属性查找。
  - name ’字串’ 查找文件名匹配所给字串的所有文件,字串内可用通配符*、?、[ ]。
  - lname ’字串’ 查找文件名匹配所给字串的所有符号链接文件,字串内可用通配符*、?、[ ]。
  -gid n 查找属于ID号为n的用户组的所有文件。
  -uid n 查找属于ID号为n的用户的所有文件。
  -group ’字串’ 查找属于用户组名为所给字串的所有的文件。
  -user ’字串’ 查找属于用户名为所给字串的所有的文件。
  -empty 查找大小为0的目录或文件。
  -path ’字串’ 查找路径名匹配所给字串的所有文件,字串内可用通配符*、?、[ ]。
  -perm 权限 查找具有指定权限的文件和目录,权限的表示可以如711,644。
  -size n[bckw] 查找指定文件大小的文件,n后面的字符表示单位,缺省为b,代表512字节的块。
  -type x 查找类型为x的文件,x为下列字符之一:
  b 块设备文件
  c 字符设备文件
  d 目录文件
  p 命名管道(FIFO)
  f 普通文件
  l 符号链接文件(symbolic links)
  s socket文件
  -xtype x 与-type基本相同,但只查找符号链接文件。
  2. 以时间为条件查找
  - amin n 查找n分钟以前被访问过的所有文件。
  - atime n 查找n天以前被访问过的所有文件。
  - cmin n 查找n分钟以前文件状态被修改过的所有文件。
  - ctime n 查找n天以前文件状态被修改过的所有文件。
  - mmin n 查找n分钟以前文件内容被修改过的所有文件。
  - mtime n 查找n天以前文件内容被修改过的所有文件。
  3. 可执行的操作
  - exec 命令名称 {} 对符合条件的文件执行所给的Linux 命令,而不询问用户是否需要执行该命令。{}表示命令的参数即为所找到的文件;命令的末尾必须以“ ;”结束。
  - ok 命令名称 { } 对符合条件的文件执行所给的Linux 命令,与exec不同的是,它会询问用户是否需要执行该命令。
  - ls 详细列出所找到的所有文件。
  - fprintf 文件名 将找到的文件名写入指定文件。
  - print 在标准输出设备上显示查找出的文件名。
  - printf 格式 格式的写法请参考有关C语言的书。
  例1:查找当前目录中所有以main开头的文件,并显示这些文件的内容。
  $ find . - name ‘main*’ - exec more {} ;
  例2:删除当前目录下所有一周之内没有被访问过的a .out或*.o文件。
  $ find . (- name a.out - o - name ‘*.o’)
  > - atime +7 - exec rm {} ;
  说明如下:
 
 命令中的“.”表示当前目录,此时find将从当前目录开始,逐个在其子目录中查找满足后面指定条件的文件。(和)表示括号(),其中的“”称为转义
符。之所以这样写是由于对Shell而言,(和)另有不同的含义,而不是这里的用于组合条件的用途。“- name
a.out”是指要查找名为a.out的文件;“- name ‘*.o’”是指要查找所有名字以 .o结尾的文件。这两个- name之间的-
o表示逻辑或(or),即查找名字为a.out或名字以
.o结尾的文件,find在当前目录及其子目录下找到这佯的文件之后,再进行判断,看其最后访问时间是否在7天以前(条件-atime
+7),若是,则对该文件执行命令rm(- exec rm{ };)。其中{
}代表当前查到的符合条件的文件名,;则是语法所要求的。上述命令中第一行的最后一个是续行符。当命令太长而在一行写不下时,可输入一个,之后系统将显示
一个>,指示用户继续输入命令。
  locate命令
  locate命令用于查找文件,它比find命令的搜索速度快,它需要一个数据库,这个数据库由每天的例行工作(crontab)程序来建立。当我们建立好这个数据库后,就可以方便地来搜寻所需文件了。
  该命令的一般形式为:
  locate 相关字
  例如:查找相关字issue
  $ locate issue
  /etc/issue
  /etc/issue.net
  /usr/man/man5/issue.5
  /usr/man/man5/issue.net.5
               
               

本文来自ChinaUnix博客,如果查看原文请点:http://blog.chinaunix.net/u2/70610/showart_734169.html
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP