linux shell脚本攻略

 

第一章 小试牛刀

echo 后面可以直接跟内容,或者用单引号和双引号

1.单引号中的变量不会被解析,比如echo '$aa' 结构就是 $aa

2.不带引号时,echo hello;hello  的第二个hello会被当做命令执行

echo -n 忽略换行
echo -e 输出的内容会被转移

    printf 

%-5s  打印字符串,- 表示左对齐,不到5位的用空格替代
$s格式化字符串,%c是替换字符,%d是数字,%f是浮点数

输出带色彩的文件和背景

echo -e "\e[1;45m \e[1;31m sssssssssssssss \e[0m" 

 

变量的一些简单实用

var=hello
输出var变量
echo $var
echo ${var}
 
求字符串长度
echo ${#var}
 
当前的shell版本
echo $SHELL
echo $0

 

数学运算

let var++   #执行let时候变量前面不需要加$符号
echo $var
result=$[no1 + no2]      #[]中也可以使用$前缀
result=$[$no1 + 5]
result=$(( no1 + 5 ))    #()这种写法时,变量前必须加上$
echo "4*3.14" | bc       #只有bc才支持浮点运算

 

调用一个shell有两种方式,调用一个shell执行然后得到它的返回值

result=`expr 3+4`
result=$(exprt $no1+5)

 

 

输入输出

0    stdin(标准输入)
1    stdout(标志输出)
2    stderr(标志错误)
> 等同于1>; >>等同于1>>
echo "hello " 2>&1 out.log
echo "hello"  &> out.log

 

自定义文件描述符(注意 > 符号和数字之间不能有空格)

echo "this is new line" > input.txt
exec 3<input.txt
cat <&3
exec 4 > out.txt
echo "new line" >& 4
exec 5>>input.txt 
echo "append" >&5
echo "aaa" 2> /dev/null     #错误输出重定向到黑洞文件

 

数组

array_var=(1,2,3,4,5,6)
array_var[0]="test1"
array_var[1]="test2"
array_var[2]="test3"
echo $(array_var[0])
echo $(array_var[$index])    #假设index=5
echo $(array_var[@])
    结果: test1 test2 test3 test4 test5 test6
echo $(#array_var[*])        #打印数组长度

 

关联数组

declare -A ass_array
ass_array=(([index1]=val-1 [index2]=val-2))
或者:
ass_array[index1]=val-1
ass_array[index2]=val-2
fruits_value=( [apple]='100 dollars' [orage]='150 dollars' )
    列出数组索引
echo $(!array_var[*])
echo $(!array_var[@])

 语法	              描述
 ${!array[*]}	 取关联数组所有键
 ${!array[@]}	 取关联数组所有键
 ${array[*]}	 取关联数组所有值
 ${array[@]}	 取关联数组所有值
 ${#array[*]}    关联数组的长度
 ${#array[@]}	 关联数组的长度
    

 

别名

alias rm='cp $@ ~/backup; rm $@'
可以将其放入到 ~/.bashrc文件中,新的shell进程就会生效,删除可以从这个文件中删除或者使用
unalias命令

 

时间

sleep 秒
usleep 微妙(百万分之一秒)
date,格式化字符串
星期    %a(简写) %A(完整)
月      %b(简写) %B(完整)
日      %d
年      %y(两位表示)  %Y(四位表示)
小时    %H
分钟    %M
秒      %S
纳秒    %N
时间戳  %s

 

调试

sh -x script.sh
set -x: 在执行时显示参数和命令
set +x: 禁止调试
set -v: 当命令进行读取时显示输入
set +v: 禁止打印输入

function DEBUG() {
    [ "$_DEBUG" == "on" ] && $@ || :
}
可以将调试功能设置为on来运行脚本
_DEBUG=ON ./scritp.sh
DEBUG函数中的 :  告诉shell不要执行任何操作
把 #! /bin/bash 改成 #! /bin/bash -xv 这样不用其他任何选项就可以启用调试功能了

 

函数

调用函数方式  
myfun ;
传递参数
myfun arg1 arg2 ;
参数可以传递给脚本并通过$0(脚本名) 访问
$1 第一个参数
$2 第二个参数
$n 第n个参数
$@ 被扩展成 "$1" "$2"  "$3" 等
$* 被扩展成 "$1c$2c$3"等
$@用的最多,由于$*将所有参数当做单个字符串因此很少被使用

导出函数,之后函数的作用域就可以扩展到子进程中
export -f myfun   

读取命令返回值(状态)
cmd;
echo $?
利用()可以生成子shell,子shell中执行的内容不会对父shell产生影响
pwd;
(cd /bin; ls)

 

从控制台读取

read -n number_of_chars variable_name    #从输入中读取n个字符并存入变量variable_name中
read -s var                     #用不回显的方式去读密码
read -p "enter input :" var     # 显示提示信息
read -t timeout var             #在特定的时间内读取输入read -t 2 var 两秒内输入
read -d delim_char var          #用定界符结束输入行 read -d ":" var  
#输入hello:  var被设置为hello

 

分隔符

读取/etc/passwd,打印出用户默认的shell
line="root:x:0:0:root:/root:/bin/bash"
oldIFS=$IFS
IFS=":"
count=0
for item in $line;
do
    [ $count -eq 0 ] && user=$item;
    [ $count -eq 6 ] && shell=$item;
    let count++
done;
IFS=$oldIFS
echo $user\'s shell is $shell
结果: root's shell is /bin/bash
echo {1..50}          #能够生产从1到50的数字列表
echo {a..z}或者{A..Z},或者使用{a..h}生产部分列表
for i in {a..z} do action; done;

    for循环
for var in list;
do
    command;
done

    采用c语言中的for循环格式
for((i=0;i<10;i++)) {
    commands;
}

    while循环
while condition
do
    command;
done
用true作为循环条件能够参数无限循环

    until循环(它会一直执行循环直到给定的条件为真)
x=0;
unitl [ $x -eq 9 ]; 
do
    let x++;
    echo $x;
done

 

比较

if condition;then
    commands;
fi

if condtion;then
    commands;
elif condtion;then
    commands;
else
    commands;
fi
条件通常被放置在封闭的中括号内,一定要注意在[或]与操作数之间有一个空格,如果忘记空格脚本就

会报错
    
    一些重要的操作符:
-gt    大于
-lt    小于
-ge    大于或等于
-le    小于或等于
-eq    等于
-nq    不等于
    
    文件系统相关测试
[ -f $file_var ]    如果给定的变量包含正常的文件路径或文件名则返回真
[ -x $var ]         如果给定的变量包含的文件可执行,则返回真
[ -d $var ]         如果给定的变量包含的是目录,则返回真
[ -e $var ]         如果给定的变量包含的文件存在,则返回真
[ -c $var ]         如果给定的变量包含的是一个字符设备文件的路径,则返回真
[ -b $var ]         如果给定的变量包含的是一个块设备文件的路径,则返回真
[ -w $var ]         如果给定的变量包含的文件可写,则返回真
[ -r $var ]         如果给定的变量包含的文件可读,则返回真
[ -L $var ]         如果给定的变量包含的是一个符号链接,则返回真

    字符串比较(因为有时候采用单个中括号会产生错误,最好使用双个中括号)
注意在 = 前后各有一个空格,如果忘记加空格,那就不是比较关系了,而变成赋值语句了 
[[ $str1 = $str2 ] 
[[ $str1 == $str2 ]
[[ $str1 != $str2 ]
[[ $str1 > $str2 ]        #str1的字母序比str2大
[[ $str1 < $str2 ] 
[[ -z $str1 ]]            #如果str1包含的是空字符串,则返回真
[[ -n $str1 ]]            #如果str1包含的是空字符串,则返回真

 

 

 

 

 

第二章 命令之乐

 cat相关

cat file1 file2 file3      #将多个文本内容拼接在一起
OUTPUT_FROM_SOME COMMANDS | cat    #从表中输入中读取
echo 'from stdin' | cat - file.txt
cat -s file                #压缩空白行
cat -T file.py             #将制表符显示为 ^|
cat -n file.txt            #显示行号

 

录制和回放终端会话

script
scriptreplay

 

 文件查找

find base_path       #base_path 可以是任何位置
-print  指明打印出匹配的文件名(路径)
-print0 指明使用'\0'作为定界符来打印每一个匹配的文件名
-name   后面的参数可以包含正则表达式,指定了文件名所必须匹配的字符串
-iname  类似-name,但是忽略大小写,如果有多个匹配条件可以用OR,也可以用!否定参数的含义
    find . \(-name "*.txt" -o -name "*.pdf" \) -print
    find . ! -name "*.txt" -print    #打印所有不以.txt结尾的文件
-regex  支持正则表达式
-iregix 忽略大小写
    find . -iregex ".*\(\.py\|\.sh\)$"     #忽略大小写找到所有py和sh结尾的文件
-maxdepth  深度搜索,最多搜索多少层
-mindepth  深度搜索,最少搜索多少层
    find . -maxdepth 1 -type f -print   #从性能角度来说,最好先指定深度再确定类型
-type      搜索文件类型
    普通文件    f
    符号链接    l
    目录        d
    字符设备    c
    块设备      b
    套接字      s
    fifo        p
-atime      用户最近一次访问文件的时间,可以带上 + 和 - 表示大于和小于
-mtime      文件内存最后一次被修改的时间
-ctime      文件元数据(metadata,列如权限  或所有权)最后一次改变的时间   
    find . -type f -atime -7 print      #打印出最近七天内被访问过的所有文件
    find . -type f -atime 7 print       #打印出恰好在七天前被访问过的文件
    find . -type f -atime +7 print      #大餐饮出访问时间超过七天的所有文件
-amin       访问时间,以分钟为单位
-mmin       修改时间,以分钟为单位
-cmin       变化时间,以分钟为单位
    find . -type f amin +7 -print       #打印出访问时间超过7分钟的所有文件
-newer      指定一个用户比较时间长的参考文件,然后找出比参考文件更新的(更长修改时间)文件
    find . -tpe f -newer file.txt -print
-size       根据文件大小搜索
    b      块(512字节)
    c      字节
    w      字(2字节)
    k      千字节
    M      兆字节
    G      吉字节
    find . -type f -size +2k               #大于2k的文件
-delete     用来删除find查找到的匹配文件
    find . -type f -name "*.swp" -delete   #删除当前目录下所有.swp文件
-perm       根据文件权限和所有权查找(-user 可以指定用户)
    find . -type f -perm 644 -print        #打印出权限位644的文件
    find . -type f -user testuser -print   #打印出所有testuser用户的文件
-prune      跳过指定的目录
    find /data0/source_path \( -name ".git" -prune \) -o \( -type f -print \) #忽略git文件
-exec       可以与其他命令结合(但是只能执行一个命令)
    find . -type f -user root -exec chown testuser {} \;
    #上面的语句是找到所有root所有者的文件修改为testuser,对于每一个匹配的文件{}会被替换成
    #相应的文件名,如果找到两个文件file1.txt和file2.txt那么会执行
    chown testuser file1.txt
    chown testuser file2.txt
    
    find . -type f -name "*.c" -exec cat {} \;>all_c_files.txt
    #上面的命令是将所有c程序文件拼接起来写入单个文件all_c_files
    
    find . -type f -mtime +10 -name "*.txt" -exec cp {} OLD \;
    #上面的命令将10天前的.txt文件复制到OLD目录中

    find . -type f -exec ./commands.sh {} \;
    #虽然-exec 参数无法使用多个命令,但是可以执行一个脚本,在脚本中放入多个命令

    find . -type f -name "*.txt" -exec printf "Text file : %s\n" {} \;
    #-exec能够同printf结合起来生产有用的输出信息

 

玩转xargs

xargs命令把从stdin接收到的数据重新格式化,再将其作为参数提供给其他命令
    -n 参数表示将输入的内容转换为指定的行
    cat example.txt | xargs -n 3     #将example.txt的内容转换为3行

    -d作为定界符
    echo "splitXsplitXsplitXsplit" | xargs -d X -n 2
    #结果: split split 
           split split
    假设args.txt内容如下:
    arg1
    arg2
    arg3

    -I选项指定一个替换字符串,这个字符串在xargs扩展时会被替换掉。当-I与xargs结合使用时,
    对于每一个参数,命令都会被执行一次
    cat args.txt | xargs -I {} ./echo.sh -p {} -x
    结果为:
    ./echo.sh -p arg1 -x
    ./echo.sh -p arg2 -x
    ./echo.sh -p arg3 -x

 

 用tr进行转换

    tr 输入部分 [需要转换的部分] [转换后的部分]
    echo "hello world hehe 1234 aa" | tr 'a-z' 'A-Z'
    #结果: HELLO WORLD HEHE 1234 AA
    
    压缩字符
    echo "gun is not unix " | tr -s ' '       #将连续的字符压缩成单个字符
   
    删除
    echo "hello world hehe 1234 aa" | tr -d '0-9'
    #结果: hello world hehe  aa

    补集,比如下面这个列子,将不在 0-9,空格,回车中的字符全部删除
    echo hello 1 char 2 next 4 | tr -d -c '0-9 \n'
    #结果: 1 2 4

 

校验和核实

    md5sum file    #创建一个文件的指纹,并将字符串打印到控制台上
    md5sum file > check.md5
    #生成的内容
    65466125197978378ec6340989ac50db  check.log
    md5sum -c check.md5  #对文件进行校验    
    
    sha1sum file    #创建一个文件的指纹,并将字符串打印到控制台上
    sha1sum file > check.sha1
    #生成的内容
    3acec0d3b6e19f68c4d25de104eabb25d5c982d2  checkfile.log
    sha1sum -c check.sha1  #对文件进行校验

 

排序

    sort -n 按数字进行排序
    sort -r 逆序排序
    sort -M 按照月份排序,一月,二月,三月这样的顺序
    sort -C 测试一个文件是否已经被排序过
    sort -m sorted1 sorted2   合并两个排序过的文件,而且不需要对合并后的文件再进行排序
    sort -k 指定了排序应该按照哪一个键来排序
    sort -b 忽略文件中的前导空白字符
    sort -d 按照字典排序
    sort -o file.log 将排序结果输出到指定文件中
    sort -u 文件去重
    #用法
    sort -C file
    if [ $? -eq 0 ];then
        echo sorted
    else
        echo unsorted
    fi

 

单一与重复

    uniq命令可以消除重复的内容,但必须用于排序过的数据,一般和sort命令结合使用
    uniq -u sorted.txt    只显示唯一的行(在输入文本中没有出现重复的行)
    uniq -c sorted.txt    统计各行在文件中出现的次数
    uniq -s 2 sorted.txt  指定可以跳过前N个字符
    uniq -w 2 sorted.txt  指定用于比较的最大字符串
    uniq -z file.txt	  为每行最后添加\0值字符

 

临时文件与随机数

    echo $RANDOM	#每次都会返回一个随机数
    temp_file="/tmp/file-$RANDOM"
    tmpe_file="/tmp/var.$$"	# $$表示当前进程的id

 

文件分割

    split -b 10k data.file
    ls
    #结果为: data.file xxa xab xac ... axj   xa开头的一共10个文件
    split -d 指定数字为后缀
    split -a 4 指定后缀长度
    split -b 10k data.file -d -a 4
    split [command_args] prefix  分割的文件前缀

 

根据扩展名切分文件名

    file_jpg="sample.jpg"
    echo ${file_jpg%.*}    #输出sample
    echo ${file_jpg#*.}    #输出jpg

    ${VAR%.*}  表示删除位于%右侧的通配符(也就是 .* ),通配符从右向左进行匹配 这种是非贪婪形的
    ${VAR%%.*} 从右向左执行贪婪操作匹配
    file=hack.fun.book.txt
    ${file%%.*} 输出为hack

    ${VAR#*.}  是从左向右匹配,删除位于#右侧的通配符(也就是 *. )
    ${VAR##*.} 是贪婪匹配,从左向右删除变量中匹配的结果
    file=hack.fun.book.txt
    ${file##*.}  结果是txt

  

批量重命名和移动

    count=1;
    for img in *.jpg *.png
    do
        new=image-$count.${img##*.}
        mv "$img" "$new" 2> /dev/null

        if [ $? -eq 0 ];then
            echo "renaming $img to $new"
            let count++
        fi
    done

 

 

 

 

 

第三章 以文件之名

生成任意大小的文件

dd if=/dev/zero of=/junk.data bs=1M count=1
    if是input file
    of是output file
    bs是block size
    count代表需要被复制的块数
    块的大小定义如下:
    字节(1B)	c
    字(2B)	w
    块(512B)	b
    1k		k
    1m		M
    1g		G

 

文件的交集与差集

cat a.log
apple
gold
iron
orange
silver
steel

cat b.txt
carrot
cookies
gold
orange

comm a.log b.log
结果:
apple
        carrot
        cookies
                gold
iron
                orange
silver
steel

第一列是只在a.log中出现的
第二列是只在b.log中出现的
第三列是同时在a.log和b.log中出现的
comm a.log b.log -1      #删除第一列
comm a.log b.log -2	 #删除第一列
comm a.log b.log -3	 #删除第一列
comm a.log b.log -1 -2   #删除第一和第二列

 

查找并删除重复文件

#! /bin/bash
ls -lS | awk 'BEGIN{
    getline;getline
    size=$5; lastName=$9
}
{
    currentName=$9
    if(size==$5) {
        "md5sum "lastName | getline;  csum1=$1;
        "md5sum "currentName | getline; csum2=$1;        
        if(csum1==csum2) {
            print lastName
            print currentName                                
        }
    };
    size=$5
    lastName=currentName
} ' | sort -u > dup_file
cat dup_file | xargs -I {} md5sum {} | sort | uniq -w 32 | awk '{ print $2 }' | sort -u > dup_sample_file
comm dup_file dup_sample_file -2 -3 | tee /dev/stderr | xargs rm

#首先获得文件列表然后遍历并按大小排序,获取文件大小和文件名,如果文件大小相同再比较两个文件
#的MD5值。如果MD5值相同那么肯定是重复的文件,把这两个文件名打印出来,最后重定向到dup_file中
#之后cat这个文件再对每行(也就是每个重复的文件)计算MD5值并排序(只比较前32个字节),最后去重
#只打印一个重复的文件并重定向到dup_sample_file中
#最后用comm比较dup_file和dup_sample_file,打印出只在dup_file中出现的文件,并用tee打印到标准
#错误输出中,最后交给xargs 删除这些文件

#其中上面的功能只需要一行就可以完成了
ll | awk 'BEGIN{getline} {print $9}' | xargs -I {} md5sum {} | uniq -w 32 -D | awk 'BEGIN{getline}{print $2}' | xargs -I {} rm {}
#awk中的getline是读取一行,ll的第一行内容不需要所以只读取然后忽略即可,之后用对每个文件做
#MD5,然后比较前32个字节,打印出所有重复的文件名,之后再用awk,忽略掉第一行(从第二行开始读)
#然后交给xargs最后删除这些重复文件

 

文件权限 所有者和粘滞位

ls的第一位
-	普通文件
d	目录
c	字符设备
b	块设备
l	符号链接
s	套接字
p	管道
之后是9个权限位rwxrwxrwx,用户,组,其他
对于用户来说有一个suid位,-rwS------ setuid权限允许用户以其他拥有者的权限来执行可执行文件
对于组用户有一个sgid位,----rwS---   setgid位允许以同该目录拥有者所在组相同 的有效组权限来执行文件
目录有一个特殊权限,叫粘滞位。当一个目录设置了粘滞位,只有创建该目录的用户才能删除目录中的文件,即使其他用户和组用户有权限也不行。
粘滞位出现在其他用户执行的执行权限位置(x),使用t或者T表示,如果没有设置执行权限,但设置了粘滞位则使用t表示;如果同时设置了执行权限和粘滞位就使用T表示

chmod a+t directory_name   #设置粘滞位	
chmod 777 . -R             #递归执行
chmod +s executeable_file  #设置sid位

 

批量生成空文件 创建不可修改文件

touch file
for name in {1..100}.txt
do
    touch name
done
touch -a 只更改改文件的访问时间(access time)
touch -m 只更改文件内容修改时间(modification time)
touch -d 为文件指定特定的时间戳
touch -d "Jan 20 2010"
chattr -i file   #设置不可删除的文件

 

查找符号链接及指向

ll | grep "^l" | awk '{print $9 " " $10 " " $11}'
find -type l | xargs readlink 

 

 

列举文件类型统计信息 

#遍历一个目录下的文件类型,并打印出这种文件类型出现的次数
#下面这段代码是书中提供的,但是有问题不知道如何修改
#! /bin/bash

if [ $# -ne 1 ];then
    echo $0 bashpath;
    echo
fi
path=$1

declare  statArray
find $path -maxdepth 1 -print | while read line
do
    ftype=`file -b $line`
    let "statArray[$ftype]"++ ;
done

for ftype in "${!statArray[@]}"
do
    echo $ftype : ${statArray["$ftype"]}
done


#上面的功能用一行就看以完成了
find /root -maxdepth 1 -print | xargs -I {} file -b {} | awk '{sum[$0]++} END{ for(i in sum){print i "\t" sum[i]} }'

 

环回文件与挂载

dd if=/dev/zero of=loopback.img bs=10m count=1
mkfs.ext3 loopback.img
sudo mkdir /mnt/loopback
mount -o loop lopback.img /mnt/loopback
mount -t ext4 /dev/sdb1 /data1      #挂载一个分区

 

文件补丁

diff version1.txt version2.txt
#显示差异

#-u用做生成一体化输出,并将结果重定向到patch文件中
diff -u version1.txt version2.txt > version.patch

#给version1打补丁后就变成了version.txt
patch -p1 version1.txt < version.patch

#再打一次补丁就还原回version1了,此时会出现是提示,是否需要继续执行
patch -p1 version1.txt < version.patch

 

 

head和tail

head file            #默认打印前10行
head -n 5 file       #打印前5行
head -n -5 file      #打印除了最后5行外的所有行
tail file	     #打印最后10行
tail -n 5 file       #打印最后5行
tail -n +5 file      #打印除了前5行外的所有行
seq 100 | tail -n +20   #seq 100 会打印出1到100个数字,每打印一次会换行
dmegs | tail -f
PID=${pidof Foo}
tail -f file --pid $PID    #当进程Foo结束后,tail也会跟着结束

 

只列出目录

ls -D
ls -F    #对于目录会增加/ 结尾,对于文件增加 * 结尾
ls -F /home | grep "/$"   #查找/home目录的所有文件,以/ 结尾的
ls -l /home | grep "^d"
find /home -type d -maxdepth 1 -print

  

 

在命令行中用pushd和popd快速定位

pushd可以在多个目录中快速的定位
pushd /data0/test/mydir
pushd /home/hehe/test
pushd /var/log/test
pushd /test/dir
位置从0开始
dirs /test/dir /var/log/test /home/hehe/test /data0/test/mydir
pushd +0 就是/test/dir表示在这个目录不动
pushd +1 就是切换到/var/log/test
popd 是弹出最上面的目录
popd +n 弹出第n个目录,它也是从下标0开始计算的
popd +1 表示弹出/var/log/test

如果只有两个目录/data0/test和/home/hehe
先cd到/data0/test再cd到/home/hehe
如果想切回到/data0/test
执行cd -   即可,再切换到/home/hehe,再执行一次 cd -
不停的执行cd -  就可以在两个目录之间切换了

 

统计文件的行数 单词数和字符数

wc -l file    #统计行数
wc -w file    #统计单词数
wc -c file    #统计字符数
wc file       #打印出文件的行数,单词数和字符数
wc file -L    #打印最长行的长度

 

打印目录树

tree
tree -P "*.jpg"     #用通配符描述样式
tree -L [path]      #指定递归的目录深度
tree --inodes	    #列出文件并显示这个文件的inode
tree -d [path]      #只显示目录
tree -s [path]      #列出文件并显示大小(字节)
tree -D [path]      #列出文件并显示修改时间
tree -H [path]      #以HTML格式打印
tree -o file [path] #结果重定向到文件中

 

 

 

 

 

第四章 让文本飞

正则表达式

^	行起始标记		^tux 匹配以tux起始的行
$	行尾标记		tux$ 匹配以tux结尾的行
.	匹配任意一个字符	Hack.匹配Hack1和Hacki,但是不匹配Hackl2和Hackil
[]	包含在[]之中任意字符	cook[kl]匹配cook或cool
[^]	匹配除^之外任意字符	9[^01]匹配92,93但是不匹配91或90
[-]	匹配[]中指定范围任意字符	[1-5]匹配从1~5的任意一个数字s
?	匹配之前的项1次或0次	colou?r 匹配color或者colour,但不能匹配colouur
+	匹配之前的项目1次或多次	Rollno-9+ 匹配Rollno-99,Rollno-9
*	匹配之前的项0次或多次	co*l匹配cl,col,coool等
()	创建一个用于匹配的字串	ma(tri)? 匹配max或maxtrix
{n}	之前的项匹配n次		[0-9]{3}匹配任意一个三位数,[0-9][0-9][0-9]
{n,m}	指定之前的项所必须匹配的最小和最大次数	[0-9]{2,5}匹配从两位数到五位数之间任意一个
|	交替--匹配 | 两边任意一项	Oct(1st|2nd) 匹配Oct1st或0ct2nd
\	转移符可以将特殊字符进行转移	a\.b匹配a.b

\b	单词边界			\bcool\b 匹配cool,但不匹配coolant
\B	非单词边界			cool\B 匹配coolant,但不匹配cool
\d	单个数字字符			b\db匹配b2b,但不匹配bcb
\D	单个非数字字符			b/Db匹配bcb,但不匹配b2b
\W	单个单词字符(字母数字下划线)	\w匹配1或a,但不匹配&
\W	单个非单词字符			\W匹配&,但不匹配1或a
\n	换行符				\n匹配一个新行
\s	单个空白字符			X\sx匹配x x,但不匹配xx
\S	单个非空白字符			x\Sx匹配xx,但不匹配x x
\r	回车				匹配回车


#匹配一个IP地址
[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.

 

用grep搜索

grep match_pattern filename
grep "match_pattern" filename
echo -e "this is a wordl\ntext line" | grep word
grep "match_text" file1 file2 file3 ... 	#对多个文本进行搜索
grep word filename --color=auto			#对输出行中重点标记处匹配到的单词
grep -E "[a-z]+"	#使用扩展正则表达式
egrep "[a-z]+"		#功能同上
grep -v "match_pattern" file		#打印除包含match_pattern的行之外的所有行
grep -c "text" filename			#统计文本或文件中包含匹配字符串的行
echo -e "1 2 3 4\nhello\n 5 6" | egrep -c "[0-9]"	#统计匹配的行的数量,不是次数
grep linux -n sample.txt	#打印出包含匹配字符串的行数
echo gnu is not unix | grep -b -o "not"		#打印样式匹配所位于的字符或字节偏移
#结果	7:not

grep "text" . -R -n		#在多级目录中对文本进行递归搜索   .  指定了当前的目录
echo "hello world" | grep -i "HELLO"	#忽略大小写
grep -e "pattern1" -e "pattern2"	#匹配多个样式
grep -f pattern_file  filename		#用-f读取一个匹配样式文件
grep "main()" . -r --include *.{c,cpp}		#在目录中只递归搜索.c和.cpp文件
grep "main()" . -r --exclude "README"		#在搜索中排除搜油的README文件
grep --exclude-dir		#排除目录
grep --exclude-from FILE	#排除所需的文件列表
grep -q				#静默输出,可以用于 if [ $? -eq 0 ]; 来判断
seq 10 | grep 5 -A 3		#打印某个匹配结果之后的3行
seq 10 | grep 5 -B 3		#打印某个匹配结果之前的3行
seq 10 | grep 5 -C 3		#打印某个结果之以及之后的3行

 

用cut按列切分文件

cut -f FIELD_LIST filename
cut -f 2,3 filename		#默认按照空格分隔,读取第二第三列
cut -d ";"		#指定定界符
cut -c 1-5 range_file.txt	#打印第一到第五个字符
cut -f 		#表示定义字符安
cut -b		#表示定义字节

 

统计特定文件中的词频

egrep -o "[a-zA-Z]+" $filename | awk '{count[$0]} END{printf("%14s%s\n", "WORD", "COUNT")} 
for(ind in count){printf("%-14s%d\n",ind,count[ind])} '

 

sed入门

sed 's/pattern/replace_string/' file	#替换
sed -i 's/pattern/replace/' file	#使用-i,可以替换原文件
sed 's/pattern/replace/g' file		#替换所有处
sed '/pattern/p'                        #打印匹配的内容
echo this thisthisthis | sed 's/this/THIS/2g'		#从第N+1处开始替换
#this THISTHISTHIS

echo this this this this | sed 's/this/THIS/3g'	
#this this THIS THIS

echo this this this this | sed 's/this/THIS/4g'
#this this this THIS

#移除空白行
sed '/^$/d'		# d 是删除
echo this is an example | sed 's/\w\+[&]/g'	#用 & 标记匹配样式的字符串
[this] [is] [an] [example]			#能够在匹配字符串时使用已匹配的内容

echo this is digit 7 in a number | sed 's/digit\([0-9]\)/\1/'
#上面这个命令将digit 7替换为7,\(pattern\) 用于匹配子串,对于匹配的第一个子串对应的标记是
# \1,匹配的第二个子串是\2,下面是包含了多个匹配
echo seven EIGHT | sed 's/\([a-z]\+\) \([A-Z]\+\)/\2 \1'
# EIGHT seven

 

awk入门

awk脚本的基本结构
awk 'BEGIN{ command } pattern{commands} END{ command }' file

echo | awk '{var1="v1"; var2="v2"; var3="v3"; print var1,var2,var3}'
#结果v1 v2 v3
#print var1"-"var2"-"var3
#结果v1-v2-v3

#特殊变量
NR	表示记录数量,相当于行号
NF	表示字段数量,在执行过程中对应当前的字段数
$0	当前行的文本内容
$1	第一个字段的文本内容
$2	第二个字段的文本内容

VAR=1000
echo | awk -v VARIABLE=$VAR '{print VARIABLE}'	#将外部变量的值传给awk

用getline读取行
seq 5 | awk 'BEGIN{ getline; print "read ahead first line", $0} {print $0}'
#read ahead first line 1

awk 'NR < 5'		#行号小于5的行
awk 'NR==1,NR==4'	#行号在1到5之间的行
awk '/linux/'		#包含样式linux的行
awk '!/linux/'		#不包含样式linux的行	

awk -F ":" '{print $NF}' file	#重新设置定界符
awk 'BEGIN{FS=":"}'		#同上
"command" | getline output	#将command的输出读入变量output中
echo | awk '{"grep root /etc/passwd" | getline out; print out}'
#结果 root:x:0:0:root/root:/bin/bash

#在awk中使用循环
for(i=0;i<10;i++) {print $i}
for(i in array) {print array[i]}
#内建字符串
length(string)			#返回字符串的长度
index(string,search_string)	#返回search_string在字符串中出现的位置
split(string,array,delimiter)	#用定界符生成一个字符串列表,并将结果存入数组
substr(string,star-position,end-position)	#在字符串中用字符起止偏移量生成子串并返回
sub(regex,replacement_str,string)	#将正则表达式匹配到第一处内容替换成replacement_str
gsub(regex,replacement_str,string)	#类似上面,但是替换所有处
match(regex,string)		#检查正则表达式是否能够匹配字符串,能则返回非0,否则返回0

 

对本文行字符迭代

while read line
do
    echo $line
done < file.txt

#使用子shell方式
cat file.txt | (while read line; do echo $line; done)

#迭代一行中每一个单词
for word in $line
do
    echo $word
done

#迭代一个单词中的每一个字符
for((i=0;i<$(#word);i++))
do
    echo ${word:i:1}
done

 

按列合并文件

paste file1 file2 file3 ...
paste -d ","		#列之间的定界符

 

打印不同行或样式之间的文本

awk 'NR==M, NR==N' filename
seq 100 | awk 'NR==4, NR==6'	#打印4--6行之间的文本
awk '/start_pattern/', /end_pattern/ filename

 

以逆序形式打印

tac file1 file2 ...
seq 5 | tac
seq 9 | awk '{info[NR]=$0; no=NR} END{for(;no>-1;no--){print info[no}}'

 

解析文本中的电子邮件

grep -E -o "[A-Za-z0-9]+@[A-Za-z0-9]+\.[a-zA-Z]{2,4}" email.txt

 

在文件中移除包含某个单词的句子

sed 's/[^.]*mobile phones[^.]*\.//g' sentence.txt
#[^.]	可以匹配除.之外的任意字符,每个单词被//替换,注意//之间没有任何字符,也就是空字符

 

用awk模拟head,tail,tac

awk 'NR <= 10' filename		#模拟head
awk '{buffer[N%10]=$0} END{for(i=1;i<11;i++){print buffer[i%10]} }' filename	#模拟tail
awk '{buffer[NR]=$0} END{for(i=NR;i>0;i--){print buffer[i]} }' filename 	#模拟tac

 

文本切片与参数操作

var="THIS is a line of text"
echo ${var/line/REPLACE}
#结果 This is a REPLACE of text

#通过制定字符串的起始位置和长度来生成子串
${variable_name:start_pos:length}
string=abcdefghijklmnopqrstuvwxyz
echo ${string:4}
#结果 efghijklmnopqrstuvwxyz

#从第五个字符开始,打印8个字符
echo ${string:4:8}
#结果 efghijkl

#从后向前计数,最后一个字符索引记为-1,但必须放到括号内
echo ${string:(-1)}
#结果 z
echo ${string:(-2):2}
#结果 yz

 

检测回文字符串

#类似abbc 这样的字符
#使用sed的反向引用,p用来打印匹配内容,下面这个命令可以匹配4个字符的回文
#如abbc, \(.\) 匹配第一个字符,\2是反向引用,\1引用第一个,于是匹配abbc这样的结构
sed '/^\(.\)\(.\)\2\1/p'

 

 

 

 

 

第五章 一团乱麻

网站下载

wget URL1 URL2 URL3
#下载后的文件名和原始一致进度输出到stdout
wget ftp://example_domian.com/somefile.img	
wget -t 5 URL		#指定重试次数
wget URL -o log
wget --limit-rate 20k URL	#对wget限速
wget -Q 100m URL		#限制配额,最多只能下载100M
wget --quote URL		#同上
wget -C URL			#断点续传
wget --mirror exampledomain.com		#像爬虫一样递归的收集网页上的所有URL链接
wget -r -N -l DEPTH URL		# -l 指定页面层级DEPTH,这个选项需要和-r(递归)一同使用
wget --user username --password pass URL	#认证

#将网页以ASCII字符形式下载到文本文件中
lynx -dump URL > webpage_text.txt	

 

curl入门

curl URL		#默认将内容输出到stdout中
curl URL > index.html
curl URL --slient	#不显示进度信息
curl URL -o		#将文结果写入文件,默认和URL中的文件名一致
curl  URL -o index.html --progress	#在下载过程中显示如 # 的进度条
curl URL/file -C offset			#能够从特定的文件便宜出继续下载
curl --referer Referer_URL target_URL	#如果referer是指定中的url,则跳转到那个URL中
curl URL --cookie "user-slynux;pass=hack"	#指定cookie
curl URL --cookie-jar cookie_file		#将cookie存入另一个文件
curl --user-agent "Mozila/5.0"		#指定user-agent头
curl -H "Accept-language: en"		#指定请求头
curl URL --limit-rate 20K		#限制curl下载速度
curl --max-filesize bytes		#指定最大下载量
curl -u user:pass URL			#进行认证
curl -I URL				#只返回响应头
curl -head URL				#同上
curl -v					#显示详细内容

 

 

 

 

 

第六章 B计划

用tar归档

tar -c 		#创建文件
tar -f		#指定文件名
tar -v		#详细显示
tar -t		#查看
tar -x		#提取归档
tar -r		#追加归档
tar -rvf original.tar new_file
tar -Af file1.tar file2.tar	#将file2.tar的内容合并到file1.tar中
tar -f archive.tar --delete file1 file2 ...	#从归档中删除文件
tar -cf arch.tar.* --exclude "*.txt"		#排除归档
tar --totals	#打印归档后的总字节数
tar -u		#只有比归档文件中的同名文件更新的时候才进行添加
#如	tar -uvf archive.tar filea	只有filea的文件内容修改时间更新的时候才对他添加
tar -d		#打印出两者之间的差别
tar -j		#指定bunzip2格式
tar -z		#指定gzip格式
tar --lzma	#指定lzma格式

 

用cpio归档 

#用于将多个文件和文件夹存储为单个文件,同时还能保利麓所有的文件属性
touch file1 file2 file3
echo file1 file2 file3 | epio -ov > archive.cpio	#归档
cpio -it < archive.cpio		#列出归档
cpio -id < archive.cpio		#从归档中提取文件
 

gzip压缩

gzip filename		#会创建filename.gz的文件,并将原文件filename删除
gzip -l filename	#列出压缩文件的属性信息
cat file | gzip -c > file	#从stdin中读取并写入到stdout中
gzip --fast		#最低压缩比
gzip --best		#最高压缩比
gunzip filename.gz	#解压缩
tar -zcvf archive.tar.gz [FILES]	#创建gzip归档
tar -cvf archive.tar [FILES]	#先创建归档
gzip archive.tar		#再压缩
tar -ztvf archive.tar.gz	#查看
tar -zxvf archive.tar.gz	#提取
gzip -9 test.img		# 1级最低,9级最高压缩率
zcat test.gz		#直接查看压缩文件
 

bzip压缩

bzip2 filename		#会创建filename.bz2文件,并删除原始的filename文件
cat file | gzip2 -c file.tar.bz2	#从stdin中读取并写入到stdout中
tar -jcvf archive.tar.bz2 [FILES]	#创建归档
tar -cvf archive.tar [FILES]		#先创建归档
bzip2 archive.tar			#再压缩
tar -jtvf archive.tar.bz2		#查看
tar -jxvf archive.tar.bz2		#提取
bzip2 -9 test.img		#和gzip一样从1--9级,1最快9压缩率最高
 

zip归档

zip archive_name.zip [SOURCE FILES/DIRS]
#如 zip file.zip file
#对目录和文件进行递归操作,和bzip2 gzip不同,zip不会删除原始文件
zip -r archive.zip folder1 file2	
unzip file.zip		#解压缩,不会删除原始文件
zip file.zip -u newfile	#更新归档中的内容
zip -d arc.zip file.txt	#从压缩归档中删除内容
zip -l archive.zip	#列出归档文件中的内容
 

加密工具与散列

crypt <input_file> output_file
Enter passphrass:			#将stdin中接收一个文件以及口令,输出到output
crpyt PASSPHRASE < input_file > encrypted_file	#通过命令行参数来提供口令
crpyt PASSHRASE -d < encrypted_file > output_file	#创建解密文件

gpg -c filename		#加密文件
gpg filename.gpg	#解密文件

base64 filename > outputfile	#将文件编码为base64格式
cat file | base64 > outputfile
base64 -d file > outputfile	#解码base64文件
cat base64_file | base64 -d outputfile
md5sum file	#输出编码和文件名
sha1sun file	#输出编码和文件名
openssl passwd -1 -salt SALT_STRING PASSWORD	#利用openssl加盐散列加密

 

用rsync备份系统快照

rsync -av source_path destination_path		#将源目录复制到目的端
rsync -a		#比较进行归档
rsync -v		#打印详细信息
rsync -av username@host:PATH destination	#将远程机主机上的数据恢复到本地主机
rsync -z			#传输时压缩数据
rsync --exclude "*.txt"		#指定需要排除的文件
rsync --exclude-from FILEPATH	#通过一个列表文件指定需要排除的文件
rsync -avz SOURCE DESTINATION --delete		#备份时删除已不存在的文件

 

用dd克隆磁盘

dd if=SOURCE of=TARGET bs=BLOCK_SIZE count=COUNT
dd if=/dev/sda1 of=sda1_partition.img		#将一个分区复制到文件中
dd if=sda1_partition.img of=/dev/sda1		#用备份恢复分区
dd if=/dev/zero of=/dev/sda1			#永久性删除一个分区中所有数据
dd if=/dev/sda of=/dev/sdb			#在容量相同的硬盘间进行克隆
dd if=/dev/cdrom of=cdrom.iso			#制作CD ROM的镜像

 

其他

lzma
超高压缩率的squashfs文件系统

 

 

 

 

 

第七章 无网不利

联网知识

#打印可用的网络接口列表 
ifconfig | cut -c-10 | tr -d ' ' | tr -s '\n' 
#打印eth1网卡的ip 
ifconfig eth1 | grep "inet" | cut -d ":" -f 2 | awk '{print $1}' 
#MAC地址欺骗 
ifconfig eth1 hw enter [新的MAC地址] 

HWaddr 这个是MAC地址 
inet addr	IP地址 
Bcast	 广播地址 
Mask	 子网掩码 


分配给当前系统的名字服务器可以通过/etc/resolv.conf查看 
host www.baidu.com	#列出这个域名的所有IP 
nslookup 域名	 #类似host,会列出更多细节 
route	 #显示路由表 
route -n #指定以数字形式显示地址 
traceroute 域名	 #以显示分组途径的所有网关地址,用于测量源和目的经过了多少跳 
ping -c 数量 域名	#发送多少ICMP包 

#探测子网内所有活跃的机器,将循环体内放到 ( ) 内,可以并行执行脚本,也就是生成多个子shell,最后wait是等待 
#上面的子shell执行技术 
for ip in 192.168.0.1.{1..255} 
do 
( 
ping $ip -c 2 &> /dev/null 
if [ $? -eq 0 ];then 
echo $ip is alive 
fi 
) & 
wait 
done 

#fping可以ping一组ip 
fping -a #指定打印出所有活动主机的IP 
fping -u	#打印出所有无法达到的主机 
fping -g	#指定从写作IP/mask的 "斜线--子网掩码" 记法或者起止IP地址记法中生成IP地址范围 
fping -a 192.168.1/24 -g 
fping -d	#对每一个echo回应进行DNS查询来返回主机名 
fpipng -a -d 2> /dev/null < ip.list 
cat ip.list 
192.168.0.86 
192.168.0.9 
192.168.0.6 
#结果 
www.local 
dnss.local 

 

传输

scp SOURCE DESTIONATION 
scp user@remotehost:/home/path/filename source_filename 
#递归复制 
scp -r /home/slynux user@remotehost:/home/backups 
scp -p	 #在复制文件的同时保留文件的权限和模式 

 

SSH

ssh-keygen -t rsa 
默认放到~/.ssh目录中 
id_rsa.pub 是生成的公钥 
id_rsa 是生成的私钥 
公钥必须添加到远程服务器的 ~/.ssh/authorized_keys 

#添加一个密钥,会提示要输入密码,之后就不用输入密码了 
ssh USER@REMOTE_HOST "cat >> ~/.ssh/authorized_keys" < ~/.ssh/id_rsa.pub 
ssh -C user@hostname COMMANDS	 #传输时压缩数据 

 

网络监控

lsof -i	 #检测所有打开的端口 
netatat -antp 

 

 

 

 

 

第八章 当个好管家

统计磁盘使用情况

du FILENAME1 FILENAM2 ...
du -a DIRECTORY	 #递归的统计目录下所有的文件大小
du -h	 #以KB,MB,GB的方式打印大小
du -c	 #统计所有文件和目录综合,最后会统计总大小
du -c *.txt
du -b FILE(s)	 #打印字节
du -k FILE(s)	 #打印KB为单位的文件
du -m FILE(s)	 #打印MB为单位的文件
du -B BLOCK_SIZE FILE	#打印以指定块为单位的文件大小
du - B 4 pcpu.sh
du --exclude "*.txt" FILE(s)	 #排除指定的文件
du --exclude-from EXCLUDE.txt DIRECTORY	 #EXCLUDE.txt包含了需要排除的文件列表
du --max-depth 2 DIRECTORY	 #指定最大递归深度
du -s DIRECTORY	 #累计指定目录总大小

#找出指定目录中最大的10个文件
du -ak DIRECTORY | sort -nrk 1 | head
find . -type f -exec du -k {} \; | sort -nrk 1 | head

df #打印磁盘目录
df -h   #按照MB,GB的格式打印

 

计算时间

time COMMAND
real	从开始到结束的时间
user	进程再用户模式下花费的时间
sys	在内核模式下花费的时间

 

与当前登陆用户启动日志及启动故障的相关信息

who	 #获取当前登陆的相关信息
w	 #同who,但是更详细
users	 #当前登陆的用户列表
uptime	 #系统运行了多少时间以及平均负载
last	 #登陆会话信息,实际上是一个系统登陆日志,包括了tty,登陆时间状态灯信息
last -f /var/log/wtmp	#明确指定日志文件
last USER	 #获取单个用户登陆会话信息
lastb	 #获取失败的用户登陆会话信息

 

打印历史记录中最常用的10条命令

printf "COMMAND\tCOUNT\n"; history | awk '{list[$4]++} END{ for(i in list){printf("%s\t%d\n",i,list[i])} }' | sort -nrk 2 |
head

 

列出一小时内占用CPU最多的10个进程

LOOP=3600
for((i=0;i<LOOP;i++))
do
    ps -eo comm,pcpu | tail -n +2 >> /tmp/cpu_usage.$$
    sleep 1
done

cat /tmp/cpu_usage.$$ | awk '{process[$1]+=[$2]} END{ for(i in process){printf("%-20s %

s",i,process[i);} }' | \
sort -nrk 2 | head

 

一些监控命令

watch #在某段时间间隔内不断监视某个命令的输出
watch ls	#监控ls
watch 'ls -l | grep xx'	 #监控ls和grep
watch -d ls	 #高亮显示变化

inotifywait	#用来收集有关文件访问的信息

 

用logrotate管理日志文件

配置目录位于/etcc/logrotate.d
可以为自己的日志文件编写一个特定的配置
cat /etc/logrotate.d/program
/var/log/program.log {
    missingok
    notifempty
    size 30k
        compress
    weekly
        rotate 5
    create 0600 root root
}
其中/var/log/program.log 指定了日志文件路径,旧的日志文件归档之后也放入同一个目录中
配置参数
missingok	如果日志文件丢失则忽略,然后返回(不对日志文件行轮替)
notifempty	仅当源日志文件非空时才对其进行轮替
size 30k	限制实施轮替的日志文件大小,可以用1M表示1MB
compress	允许用gzip对较旧的日志进行压缩
weekly		指定进行轮替的时间间隔,可以是weekly,yearly,daily
rotate 5	这是需要保留的旧日志文件的归档数据。在这里是5
                所以这些文件名将会是program.log1.gz,program.log.2.gz直到program.log.5.gz
create 0600 root root 	指定所要创建的归档文件的模式,用户以及用户组

 

用syslog记录日志

/var/log是存储日志文件的公共目录,这里的文件是被称为syslog的协议处理的
由守护进程sylogd负责执行
linux中的一些重要日志文件
/var/log/boot.log		系统启动信息
/var/log/httpd			apache web服务器日志
/var/log/message		发布内核启动信息
/var/log/auth.log		用户认证日志
/var/log/dmesg			系统启动洗洗
/var/log/mail.log		邮件服务器日志
/var/log/Xorg.0.log		X服务器日志

logger LOG_MESSAGE
logger this is a test log line
tail -n 1 /var/log/message	#查看刚刚输出的日志,如果是用logger命令,他默认记录到
				#这个文件中
logger TAG this is a message    #通过TAG将日志记录到不同的文件中

 

 

 

 

 

第九章 管理重任

收集进程信息

ps -f	显示更多的列
ps -e   系统的每一个进程
ps -ax  也类似ps -ef
ps -o   指定输出的列,如ps -o comm
        ps -eo comm,pcpu | head
-o 适用的参数如下
pcpu	cpu占用率
pid	进程ID
ppid	父进程ID
pmem	内存使用率
comm	可执行文件名
cmd	简单明了(simple command)
user	启动进程的用户
nice	优先级(niceness)
time	累计的CPU时间
etime	进程启动后度过的时间
tty	所关联的TTY设备
euid	有效用户ID
stat	进程状态

--sort对特定参数进行排序,+ 表示升序,- 表示降序
ps -eo comm,pcpu --sort -pcpu | head
ps -C [command_name] #如 ps -C bash
ps -C bash -o pid=    	#跟上pid= 就可以移除头部,只显示单个pid
   #类似pidof
ps -u	有效用户
ps -U 真实用户
#如 ps -u root -U root -o user,pcpu
ps -t TTY1, TTY2 ...
#如 ps -t pst/0, pst/1

ps -eLf    	#NLWP是进程的线程数量,NLP是ps输出中每个条目的线程ID
ps -eLF --sort -nlwp | head
ps -e w  	# w表示宽松输出
ps -eo pid,cmd e | tail -n 3	# e表示显示进程依赖的环境变量

 

杀死进程以及发送或响应信号

kill -l #列出所有可用信号
kill PROCESS_ID_LIST	#终止一个进程
kill -s SIGNAL PID	#参数SIGNAL要么是信号名称,要么是信号数
具体如下:
SIGHUP  1	对控制进程或终端进行挂起检测
SIGINT  2	当按下ctrl+c时发送该信号
SIGKILL 9	用于强行杀死进程
SIGTERM 15	默认用于终止进程
SIGTSTP 20	当按下ctrl+z时发送该信号
#强行杀死进程
kill -s SIGKILL PROCESS_ID
kill -9 PROCESS_ID

killall process_name
killall -s SIGNAL process_name

killall -9 process_name	 #强行杀死
killall -u USERNAME process_name	#通过名称以及所属用户名指定进程
pkill process_name	 #pkill和kill类似,但是pkill接受的是进程名

#trap命令在脚本中用来为信号分配处理程序
trap 'echo `date`:can not terminate by ctrl+C' 2
#将对一个进程执行kill或者对某个进程执行ctrl+c 时候,会出现上面的提示
#说明已经捕捉了此信号

 

which,whereis,file,whatis与平均负载

#which命令用来找出某个命令的位置。我们在终端输入命令的时候无需知道对应的可执行文件位于
#何处。终端会在一组位置中查找这个命令,这一组位置由环境变量PATH指定
#如 which is

#where和which命令类似,但是它不仅返回命令的路径,还能够打印出其对应的命令手册的位置以及命令源代码的路径
whereis ls

#file 命令用来确定文件的类型
file /bin/ls

#whatis命令会输出作为参数的命令的简短描述信息,这些信息是从命令手册中解析得来的
whatis ls

#平均负载,显示了1分钟,5分钟,15分钟的平均负载情况,以及系统的开机时间
uptime

 

向用户终端发送消息

wall
mesg

 

收集系统信息

hostname	 #打印当前系统的主机名
uname -n	 #打印当前系统的主机名
uname -a	 #打印linux内核版本,硬件架构等详细信息
uname -r	 #打印内核发行版本
uname -m	 #打印主机类型
cat /proc/cpuinfo	#打印出CPU的相关信息
cat /proc/cpuinfo | head -n 5 | tail -1	 #获得处理器名称
cat /proc/meminfo	#打印内存的详细信息
cat /proc/partitions	#打印分区的详细信息
fdisk -l	 #同上
lshw	 #同上

 

用/proc收集信息

系统中每一个运行的进程在/proc中都有一个对应的目录
environ	 包含与进程相关联的环境变量
cwd	 是一个到进程工作目录的符号链接
fd	 包含了由进程所使用的文件描述符

 

用cron进行调度

cron表每一个条目都由6部分组成,按照下列顺序排列
分钟 0--59
小时  	0--23
天    	1--31
月份  	1--12
工作日	0--6
命令	在指定时间执行的脚本或命令
* 表示指定命令在每一个时间段都执行

02 * * * *  /home/slynux/test.sh	#在每天的每个小时的第2分钟执行
00 5,6,7 * *  /home/slynux/test.sh	#要在每天的第5,6,7小时执行脚本
00 */12 * * 0  /home/slynux/script.sh	#在周日的每个小时执行脚本
00 02 * * *    /sbin/shutdown -h	#在每天凌晨2点关闭计算机
crontab -e #手动编辑cron脚本
crontab -l	 #列出cron表中的内容
crontab -l -u slynux	#指定用户名来查看其cron表
crontab -r 移除当前cron表中的内容

 

 用户管理脚本

useradd	[用户名]		#增加用户
deluser	[用户名]		#删除用户
chsh USER -s SHELL		#修改用户默认的shell
usermode -L USER		#锁定用户
usermode -U USER		#解锁用户
chage -E DATE			#处理用户账户的过期信息
    其他选项
    -m MIN_DAYS			#将更改密码的最小天数修改成MIN_DAYS
    -M MAX_DAYS			#设置密码有效的最大天数
    -W WARN_DAYS		#设置在前几天提醒需要更改密码
passwd USER			#更改用户密码
addgroup GROUP			#增加一个新用户组
delgroup GROUP			#删除一个用户组
figer USER			#显示用户信息

 

 

 

 

 

参考:

linux shell关联数组

 

 

你可能感兴趣的:(Linux shell)