shell学习之常用命令总结

1.find命令

  主要用途:主要用来做文件查找。

  使用方法:查找文件的方式可以基于:文件名,文件时间属性,文件的所有者和组,文件权限属性,文件类型属性,文件大小,另外可以指定 查找目录的深度,排除指定子目录,具体使用方法:

  http://www.cnblogs.com/mchina/archive/2012/07/02/2573313.html

  其他:可以通过-exec ,-OK选项对匹配的文件做进一步的处理。-exec选项:对匹配的文件执行该参数所给出的shell命令。相应命令的形式为'command' {} ;,注意{}和;之间的空格,同时两个{}之间没有空格,-OK: 其主要功能和语法格式与-exec完全相同,唯一的差别是在于该选项更加安全,因为它会在每次执行shell命令之前均予以提示,只有在回答为y的时候, 其后的shell命令才会被继续执行。-exec使用示例,-OK的使用方法类似:

##删除匹配查找的文件
find . -name "*.log" -mtime -1 -exec rm -f {} ; 

  常用find命令总结:

#!/bin/bash

find   .   -size   +1000000c   -print        #查长度大于1Mb的文件
find   -name april*                          # 在当前目录下查找以april开始的文件
find   /home   -mtime   -2                   #在/home下查最近两天内改动过的文件
find   ./   -mtime   -1   -type f   -exec   ls -l   {} ;     # 查询当天修改过的文件
find logs -type f -mtime +5 -exec   -ok   rm {} ;           #删除查找到得文件

2.xargs命令

  主要功能:从输入中构建和执行shell命令

  使用方法:在使用find命令的-exec选项处理匹配到的文件时, find命令将所有匹配到的文件一起传递给exec执行。但有些系统对能够传递给exec的命令长度有限制,这样在find命令运行几分钟之后,就会出现 溢出错误。错误信息通常是“参数列太长”或“参数列溢出”。这就是xargs命令的用处所在,特别是与find命令一起使用。  find命令把匹配到的文件传递给xargs命令,而xargs命令每次只获取一部分文件而不是全部,不像-exec选项那样。这样它可以先处理最先获取的一部分文件,然后是下一批,并如此继续下去。xargs命令使用示例:

##在当面目录下查找所有普通文件,并用grep命令在搜索到的文件中查找hostname这个词
find . -type f -print | xargs grep "hostname" 

##直接杀掉mysql的进程
pgrep mysql | xargs kill -9  

3.sed命令
  主要功能:对输入流进行编辑。
  基本知识:sed 基本语法-sed [-n] 'editing command',
sed工作过程:

  • 依次从输入中读取每一行放入到模式空间中;
  • 使用 'editing command'对模式空间中的字符串进行处理;
  • 输出模式空间中处理后的字符串;

  常用选项参数解释

  • -n:不是模式空间的所有处理后的字符串都打印,而是仅仅显示以p指定的行;
  • -e:使用多个 editing command时,必须使用这个选项;
  • -i:将对模式空间字符串的修改,直接写回到输入中相应的行;
  • -f:指定脚本文件。

  sed常用command:

  • a  新增, a 的后面可以接字串,而这些字串会在新的一行出现(目前的下一行)~比如:nl testfile |sed '2aUnited States'
  • c  取代, c 的后面可以接字串,这些字串可以取代 n1,n2 之间的行! 比如:nl testfile |sed '2,5cNo 2-5 number'
  • d  删除,因为是删除啊,所以 d 后面通常不接任何咚咚                      比如:nl testfile |sed '/west/,/north/d'
  • i  插入, i 的后面可以接字串,而这些字串会在新的一行出现(目前的上一行) 比如:sed '/eastern/iNEW ENGLAND REGION' testfile 
  • p  列印,亦即将某个选择的资料印出。通常 p 会与参数 sed -n 一起运作   比如:nl testfile |sed -n '/south/,/east/p'
  • s  取代,可以直接进行取代的工作哩!通常这个 s 的动作可以搭配正规表示法!例如 1,20s/old/new/g 就是啦!比如nl testfile |sed -n 's/Hemenway/Jones/gp'

  sed常用示例:http://www.cnblogs.com/mchina/archive/2012/06/30/2570523.html 

4.grep命令

  主要功能:文本过滤,自一个或多个文件中过滤出具有某个字符串的行,或是从标准输入过滤出具有某个字符串的行。

  grep退出状态:

  • 0: 表示成功;
  • 1: 表示在所提供的文件无法找到匹配的pattern;
  • 2: 表示参数中提供的文件不存在。

  grep常用示例:

  http://www.cnblogs.com/mchina/archive/2012/06/29/2570187.html

  使用grep判断一个文件是否包含指定的模式:

 if grep source testfile>/dev/null; then echo match; fi

5.awk命令

  主要功能:awk逐行扫描文件的,从第一行到最后一行,寻找匹配特定模板的行,并在这些行上运行“选择”动作。如果一个模板没有指定动作,这些匹配的行就被显示在屏幕上。如果一个动作没有模板,所有被动作指定的行都被处理。与sed相比,awd具有单独把某些列打印出来的功能,sed不具有这种功能,如果想实现需要借助cut

  使用模板:

  • awk 'pattern' filename   #将匹配模板的行打印出来。
  • awk '{action}' filename #对所有的行执行action,然后打印出来。
  • awk 'pattern {action}' filename #对匹配pattern的行执行aciton动作。

  示例:

  • awk -F: '/Tom Jones/{print $1,$2}' employees2  #这里-F选项后面的字符表示分隔符。
  • awk -F: '{OFS = "?"};  /Tom/{print $1,$2 }' employees2 #在输出时,域字段间的分隔符已经是?(问号)了

     对于awk而言,其模式部分将控制这动作部分的输入,只有符合模式条件的记录才可以交由动作部分基础处理,而模式部分不仅可以写成正则表达式(如上面的例子),awk还支持条件表达式。

  • awk '$3 < 4000 {print}' employees  #模式使用条件判断语句

    在花括号内,用分号分隔的语句称为动作。如果模式在动作前面,模式将决定什么时候发出动作。动作可以是一个语句或是一组语句。语句之间用分号分隔,也可以用换行符,如:
    pattern { action statement; action statement; etc. } or
    pattern {
        action statement
        action statement
    }

  • awk '$3 < 4000 && /Sally/ {print}' employees
  • awk '$1 ~ /[Bb]ill/' employees      #显示所有第一个域匹配Bill或bill的行。
  • awk '$1 !~ /[Bb]ill/' employees     #显示所有第一个域不匹配Bill或bill的行,其中!~表示不匹配的意思。
  •  awk '$3 == "Ann" { $3 = "Christian"; print}' testfile #找到第三个域等于Ann的记录,然后给该域重新赋值为Christian,之后再打印输出该记录。
  •  awk '/Ann/{$8 += 12; print $8}' testfile #找到包含Ann的记录,并将该条记录的第八个域的值+=12,最后再打印输出

   总结: awk命令包括模式pattern和动作action两个部分,对匹配模式pattern的行执行action动作。模式匹配可以是正则表达式或者是条件表达式,动作部分可以修改域并格式化打印全部或者指定的域。sed+cut完成的功能可以用awk来实现。

  详细的awk使用示例http://www.cnblogs.com/mchina/archive/2012/06/30/2571308.html

6.cut命令

  主要功能:剪下文本文件里的数据,文本文件可以是字段类型或是字符类型。

  主要选项:

  • -c list:以字符为主,执行剪下操作。
  • -d delim: 和-f选项配合使用,使用delim作为分隔字段的定界符
  • -f list : 以字段为主,作剪下操作。

  使用示例:

  • ifconfig eth0 | sed -n '2p' | cut -d : -f 2 | cut -d ' ' -f 1 #获取eth0的IP地址,主要是以字段执行剪下操作,输出:192.168.91.188
  • ifconfig eth0 | sed -n '2p' | cut -c 21-34 #获取eth0的IP地址,执行以字符为主的剪下操作,输出同上。

7.sort命令

    主要功能:排序输入。

  主要选项:

  • -r:倒置排序的顺序为由大至小。
  • -t char:使用单个字符char作为默认的字段分隔字符,取代默认的空白字符。
  • -u:只有唯一的记录:丢弃所有具有相同键值的记录,只留其中的第一条。
  • -k:定义排序键值字段。

8.tr命令

    主要功能:转换字符,比如将大写转换为小写等。

  命令语法:tr [ options ] source-char-list replace-char-list

  主要选项:

  • -c : 将不在source-char-list中的字符依次转换为replace-char-list中的字符, 比如: echo hello | tr -c o v 输出 vvvvov。
  • -d:删除source-char-list中的字符。比如:echo hello | tr -d l 输出:heo。
  • -s:浓缩重复的字符。 比如:echo hello | tr -s l 输出:helo。

10.read命令

  主要功能:将信息读入一个或多个shell变量中。

  主要选项:

  • -r:读入行时,原始读取,不做任何处理。不将结尾处的反斜杠解释为序行字符。

  示例:

  • 读取姓名和年龄,并输出:
echo "please input name and age";read name age
echo "name is $name and age is $age"
  • 读入passwd文件,并输出user和homedir列:
#!/bin/bash

##IFS定义了将每一行分割成字段的分隔符
while IFS=: read user pass uid gid fullname homedir shell
do
    echo "user is $user, and homedir is $homedir"
done < /etc/passwd
  • read从管道中读入的例子,复制整个目录树:
#!/bin/bash

find /home/xuchao -type d -print | #查找所有的目录
  sed 's;/home/xuchao;/home/xuchao/bak;' |
    while read newdir     ###read从管道中读
    do
        mkdir $newdir
    done

 11.locate命令

   主要功能:基于数据库的文件查找。locate将文件系统里的所有文件名压缩成数据库,以迅速找到匹配类Shell通配字符模式的文件名,不必实际查找整个庞大的目录结构。 locate *file* 的输出如下。

/home/shell_learn/dos-file
/home/shell_learn/myfile
/home/shell_learn/unix-file

 下面介绍两个任务定时命令:

13.at命令

  主要功能:让程序在特定的时间执行。at使用示例如下:

at 21:00 < command-file #在下午9点执行
at now    < command-file #立刻执行
at now + 10 minutes < command-file #10分钟后执行
at 0400 tomorrow < command-file #明早上4点执行
at 14 july < command-file #下个国庆日执行(美国)
at noon +15 minutes < command-file #在今天中午12::15执行

另外atq可以查询当前的定时任务,atrm删除定时任务。

14.crontab命令

  主要功能:周期性的在特定时间执行指定的程序。
  使用方法:crontab -e 修改定时任务配置文件,定时任务配置文件命令格式如下,前5栏分别用于指定程序的执行时间,依次是:分时年月周, crontab -l 显示当前周期任务。 

*  *  *  *  * user-name command to be executed

  使用示例:

#在 12 月内, 每天的早上 6 点到 12 点中,每隔 20 分钟执行一次 /usr/bin/backup 
*/20 6-12 * 12 * /usr/bin/backup

 

  

原文地址:https://www.cnblogs.com/VincentXu/p/3194412.html