• 四 shell基本命令


    一   内置命令

    hlep 命令  帮助

    help test

    help -s printf   显示内置命令的语法格式

    echo 用来显示一行文字

    echo "hello world"     默认会自动换行

    echo -n "hello wrold" 不自动换行

    echo -e 让字符串中的特殊字符起作用

    echo -e "I AM THE King of the world"          就不会作为输出来输出,而是作为换行来输出

    printf 格式化输出

     

     

     

    [root@localhost ~]# export str="hello world"
    [root@localhost ~]# echo $str
    hello world
    [root@localhost ~]# printf "%d" "$str"  
    -bash: printf: hello world: 无效数字
    0[root@localhost ~]# printf "%c" "$str" 
    h[root@localhost ~]# printf "%c
    " "$str"
    h
    [root@localhost ~]# printf "%d
    " 30
    30
    [root@localhost ~]# printf "%f
    " 30 
    30.000000
    [root@localhost ~]# printf "%5s
    " "$str"
    hello world
    [root@localhost ~]# printf "%5s
    " "
    > yes"
     
    yes
    [root@localhost ~]# printf "%5s
    " yes
      yes
    [root@localhost ~]# printf "%-5s
    " yes
    yes  
    [root@localhost ~]# printf "%-5.1f
    " ye
    -bash: printf: ye: 无效数字
    0.0  
    [root@localhost ~]# printf "%-5.1f
    " 30
    30.0 
    [root@localhost ~]# printf "%q
    " $str
    hello
    world
    [root@localhost ~]# printf -v myvar "%q" "ABC 123 XYZ"
    [root@localhost ~]# echo $myvar
    ABC 123 XYZ
    [root@localhost ~]# printf "%b" "ABC
    123
    XYZ
    "
    ABC
    123
    XYZ

     

    [root@localhost ~]# printf "%s
    " "ABCDEF" | tr '[A-Z]' '[a-z]'
    abcdef

    cd  目录进入命令

    cd  路径 进入该目录

    cd -   退回到之前目录

    cd .. 返回上一级

    pwd  显示当前工作目录

    :(冒号)  传回真值(传回 0)

    [root@localhost ~]# : >text.txt
    [root@localhost ~]# cat text.txt   #创建一个空文件

    .(半角句点)  和 Source  在当前Sheel环境下执行Shell程序

    alias   显示,设定 程序的别名

    [root@localhost ~]# alias
    alias cp='cp -i'
    alias egrep='egrep --color=auto'
    alias fgrep='fgrep --color=auto'
    alias grep='grep --color=auto'
    alias l.='ls -d .* --color=auto'
    alias ll='ls -l --color=auto'
    alias ls='ls --color=auto'
    alias mv='mv -i'
    alias perlll='eval `perl -Mlocal::lib`'
    alias rm='rm -i'
    alias which='alias | /usr/bin/which --tty-only --read-alias --show-dot --show-tilde'

    alias 新的别名='组合的命令'  设定程序新的别名

    unalias  取消程序别名

    exit 退出bash或script脚本

    logout 注销loginshell

    umask 显示或设定文件。目录建立时,文件权限的屏蔽值

    用途:新建文件夹的权限一般都是777的权限,但这种权限是不安全的,为了安全起见,让文件管理者能够方便的创建文件及目录,又不必担心权限安全性的问题,才有了umask的机制

    例如:

    [root@localhost ~]# umask
    0022

    意思就是 0777-0022的权限,就是0755的权限。也就是说任何文件夹的建立,默认都是0755的权限设定。

    这样在创建文件夹的时候,就不必考虑文件夹的权限问题了

    history  显示过去曾执行过的Shell命令

    HISTFILE  root的历史脚本文件存储位置

    HISTFILESIZE  指定历史脚本文件的行数大小

    HISTSIZE   在一个互动模式的Shell中,可记住的历史指令数目

    fc 列出登录主机后,最近执行过的指令

    [root@localhost ~]# fc -l
    1019     printf "%b" "ABC
    123
    XYZ
    "
    1020     man tr
    1021     printf "%s/n" "ABCDEF" | tr '[A-Z]' '[a-z]'
    1022     printf "%s
    " "ABCDEF" | tr '[A-Z]' '[a-z]'
    1023     cd /var/log
    1024     cd -
    1025     : >text.txt
    1026     cat text.txt
    1027     rm -y text.txt
    1028     rm  text.txt
    1029     alais
    1030     alias
    1031     ls -la
    1032     ls -ld
    1033     unmask
    1034     umask

    [root@localhost ~]# fc -l 497  #列出编号大于等于497的历史命令
    497 wget http://linux.vbird.org/linux_basic/0520source/ntp-4.2.8p3.tar.gz
    498 ls
    499 man tar
    500 cd /usr/local/src
    501 ll
    502 tar -zxvf /root/ntp-4.2.8p3.tar.gz
    503 ls
    504 cd ntp-4.2.8p3
    505 ls
    506 cat install
    507 vi install
    508 ls
    509 cat INSTALL
    510 cd ntp*
    511 cd ntp-4.2.8p3
    512 cd /root
    513 cd ntp-4.2.8p3
    514 ls
    515 cd src
    516 cd /usr/local/src

    [root@localhost ~]# fc -l 497 499   #列出编号在497到499之间的历史命令
    497 wget http://linux.vbird.org/linux_basic/0520source/ntp-4.2.8p3.tar.gz
    498 ls
    499 man tar

    [root@localhost ~]# fc -ln
    printf "%s " "ABCDEF" | tr '[A-Z]' '[a-z]'
    cd /var/log
    cd -
    : >text.txt
    cat text.txt
    rm -y text.txt
    rm text.txt
    alais
    alias
    ls -la
    ls -ld
    unmask
    umask
    fc -l
    fc -l 497
    fc -l 497 499
    [root@localhost ~]# fc -lrn
    fc -ln
    fc -l 497 499
    fc -l 497
    fc -l
    umask
    unmask
    ls -ld
    ls -la
    alias
    alais
    rm text.txt
    rm -y text.txt
    cat text.txt
    : >text.txt
    cd -
    cd /var/log

    read 有标准输入读取一行数据

    [root@localhost ~]# echo "输入名字"
    输入名字
    [root@localhost ~]# read name
    lsq
    [root@localhost ~]# echo "你的名字是"$name
    你的名字是lsq

    如果read输入没有接入变量,则会启用默认变量 $REPLY来接受输入

    [root@localhost ~]# echo "输入名字"       
    输入名字
    [root@localhost ~]# read
    lsq
    [root@localhost ~]# echo "你的名字"$REPLY
    你的名字lsq

    同样可以利用 -p来提示用户输入信息

    read -p “请输入你的名字”  echo $REPLY

    read也可以一次读取一行数据放入数组中。

    read -a arr <<(echo 123 23 45)

    获取数组值的时候可以用 

    echo ${arr[2]} 来获取

    默认都是用空格作为分隔符来讲文件或输入读取到变量中。如果要转换分隔符,就需要 IFS 这个命令

    [root@localhost ~]# IFS=':'    #设置分隔符为:
    [root@localhost ~]# read f1 f2 f3 f4 f5 f6 f7 </etc/passwd
    [root@localhost ~]# echo f1
    f1
    [root@localhost ~]# echo f2
    f2
    [root@localhost ~]# echo $f2
    x
    [root@localhost ~]# echo $f1
    root
    [root@localhost ~]# echo $f3
    0
    [root@localhost ~]# echo $f4
    0

    注意:read 在读取数据时,默认会去掉转义字符的意义,及过滤掉 中的。只保留n。这样就失去了转义符的意义。如果要允许输入数据时保留转义字符。需要用到 -r 选项

    read -r TEST

    echo $TEST

    eval 命令  将指令放入到变量中,然后执行该变量中的指令

    [root@localhost ~]# listlog="ls -la /var/log/*.log"     #将该变量放到listlog中
    [root@localhost ~]# eval $listlog              #通过eval 执行变量中的命令
    -rw-------. 1 root root     0 9月  26 09:35 /var/log/boot.log
    -rw-r--r--. 1 root root   673 8月  19 11:05 /var/log/openlmi-install.log
    -rw-r--r--. 1 root root  6575 9月  25 09:22 /var/log/vmware-network.1.log
    -rw-r--r--. 1 root root  6575 9月  23 16:01 /var/log/vmware-network.2.log
    -rw-r--r--. 1 root root  6575 9月  20 10:08 /var/log/vmware-network.3.log
    -rw-r--r--. 1 root root   734 9月  19 11:13 /var/log/vmware-network.4.log
    -rw-r--r--. 1 root root   756 9月  19 11:13 /var/log/vmware-network.5.log
    -rw-r--r--. 1 root root  6575 9月  19 11:09 /var/log/vmware-network.6.log
    -rw-r--r--. 1 root root  6575 9月  18 09:46 /var/log/vmware-network.7.log
    -rw-r--r--. 1 root root  6575 9月  17 15:20 /var/log/vmware-network.8.log
    -rw-r--r--. 1 root root  6575 9月  12 14:35 /var/log/vmware-network.9.log
    -rw-r--r--. 1 root root   734 9月  26 08:45 /var/log/vmware-network.log
    -rw-r--r--. 1 root root 43399 9月  26 08:45 /var/log/vmware-vmsvc.log
    -rw-r--r--. 1 root root  6653 9月  19 11:09 /var/log/vmware-vmusr.log
    -rw-r--r--. 1 root root   360 9月  19 11:14 /var/log/wpa_supplicant.log
    -rw-r--r--. 1 root root 46347 9月  20 10:08 /var/log/Xorg.0.log
    -rw-r--r--. 1 root lsq  33627 9月  19 11:16 /var/log/Xorg.1.log
    -rw-r--r--. 1 root root 22681 8月  19 13:39 /var/log/Xorg.9.log
    -rw-------. 1 root root 18030 9月  19 13:39 /var/log/yum.log

    二  命令行程序

    which 搜寻路径中,找出某一命令行程序的文件位置

    [root@localhost ~]# which lsof
    /usr/sbin/lsof

    which -a 命令。找出所有符合条件的路径

    locate 从文件名数据库中,找出包含关键词的文件路径

    [root@localhost ~]# locate lsof
    /usr/include/kde4/ksysguard/lsof.h
    /usr/lib64/liblsofui.so
    /usr/lib64/liblsofui.so.4
    /usr/lib64/liblsofui.so.4.14.8
    /usr/lib64/kde4/plugins/designer/ksysguardlsofwidgets.so
    /usr/sbin/lsof
    /usr/share/doc/lsof-4.87
    /usr/share/doc/lsof-4.87/00.README.FIRST
    /usr/share/doc/lsof-4.87/00.README.FIRST_4.87
    /usr/share/doc/lsof-4.87/00CREDITS
    /usr/share/doc/lsof-4.87/00DCACHE
    /usr/share/doc/lsof-4.87/00DIALECTS
    /usr/share/doc/lsof-4.87/00DIST
    /usr/share/doc/lsof-4.87/00FAQ
    /usr/share/doc/lsof-4.87/00LSOF-L
    /usr/share/doc/lsof-4.87/00MANIFEST
    /usr/share/doc/lsof-4.87/00PORTING
    /usr/share/doc/lsof-4.87/00QUICKSTART
    /usr/share/doc/lsof-4.87/00README
    /usr/share/doc/lsof-4.87/00TEST
    /usr/share/doc/lsof-4.87/00XCONFIG
    /usr/share/doc/lsof-4.87/README.lsof_4.87
    /usr/share/locale/zh_CN/LC_MESSAGES/ksysguardlsofwidgets.mo
    /usr/share/man/man8/lsof.8.gz

    date 显示,设定系统的日期和时间

    常用的格式有

    who  显示现在谁在登录主机

    whoami  显示当前登录主机的账号

    ls  列出目录内容

    ls -a 列出所有目录内容,包含隐藏文件

    ls -A 列出所有目录内容,包含隐藏文件,但不显示. 和 ..

    [root@localhost ~]# ls -A    不显示 . 和 .. 
    alog.txt         .bash_history  .bashrc  cos_value.c  .esd_auth  hello.c        important.file        .local    nohup.out           perl5  shellscript  sorted.txt   .tcshrc   .Xauthority  视频  下载
    anaconda-ks.cfg  .bash_logout   .cache   .cshrc       haha.c     hello.o        initial-setup-ks.cfg  main.c    ntp-4.2.8p3.tar.gz  .pki   sin_value.c  .ssh         test.sh   公共         图片  音乐
    a.out            .bash_profile  .config  .dbus        hello      .ICEauthority  .lesshst              makefile  out.sh              .rnd   sleep500.sh  .subversion  .viminfo  模板         文档  桌面
    [root@localhost ~]# ls -a   显示 . 和 .. 第一列中的两行
    .         anaconda-ks.cfg  .bash_logout   .cache       .cshrc     haha.c   hello.o         initial-setup-ks.cfg  main.c     ntp-4.2.8p3.tar.gz  .pki         sin_value.c  .ssh         test.sh      公共  图片  音乐
    ..        a.out            .bash_profile  .config      .dbus      hello    .ICEauthority   .lesshst              makefile   out.sh              .rnd         sleep500.sh  .subversion  .viminfo     模板  文档  桌面
    alog.txt  .bash_history    .bashrc        cos_value.c  .esd_auth  hello.c  important.file  .local                nohup.out  perl5               shellscript  sorted.txt   .tcshrc      .Xauthority  视频  下载

    为啥要这样显示呢?

    ls -la  长格式显示目录所有内容,包含隐藏文件

    ls -ld  只显示目录信息,不显示目录内容

    ls -F   在目录后面加上标识符

    [root@localhost ~]# ls -lF
    总用量 7012
    -rw-r--r--. 1 root root       0 9月  25 14:39 alog.txt
    -rw-------. 1 root root    2380 8月  19 11:19 anaconda-ks.cfg
    -rwxr-xr-x. 1 root root    8440 9月   2 16:51 a.out*
    -rw-r--r--. 1 root root     185 9月  12 15:22 cos_value.c
    -rw-r--r--. 1 root root     102 9月  12 15:22 haha.c
    -rwxr-xr-x. 1 root root    8440 9月   2 16:53 hello*
    -rw-r--r--. 1 root root      63 9月   2 16:51 hello.c
    -rw-r--r--. 1 root root    1496 9月   2 16:52 hello.o
    -rw-r--r--. 1 root root       0 9月  17 15:35 important.file
    -rw-r--r--. 1 root root    2428 8月  19 13:39 initial-setup-ks.cfg
    -rw-r--r--. 1 root root     292 9月  12 15:23 main.c
    -rw-r--r--. 1 root root     156 9月  12 15:35 makefile
    -rw-------. 1 root root      93 8月  27 14:23 nohup.out
    -rw-r--r--. 1 root root 7099575 6月  30 2015 ntp-4.2.8p3.tar.gz
    -rw-r--r--. 1 root root      31 9月  25 11:20 out.sh
    drwxr-xr-x. 2 root root       6 8月  19 13:42 perl5/
    drwxr-xr-x. 2 root root      41 9月  19 16:58 shellscript/
    -rw-r--r--. 1 root root     187 9月  12 15:23 sin_value.c
    -rwxr-xr-x. 1 root root      65 8月  27 14:12 sleep500.sh*
    -rw-r--r--. 1 root root       0 9月  25 11:27 sorted.txt
    -rwxr-xr-x. 1 root root     330 9月  25 16:00 test.sh*
    drwxr-xr-x. 2 root root       6 8月  19 15:17 公共/
    drwxr-xr-x. 2 root root       6 8月  19 15:17 模板/
    drwxr-xr-x. 2 root root       6 8月  19 15:17 视频/
    drwxr-xr-x. 2 root root       6 8月  19 15:17 图片/
    drwxr-xr-x. 2 root root       6 8月  19 15:17 文档/
    drwxr-xr-x. 2 root root       6 8月  19 15:17 下载/
    drwxr-xr-x. 2 root root       6 8月  19 15:17 音乐/
    drwxr-xr-x. 2 root root       6 8月  19 15:17 桌面/

    cat 链接文件内容并显示

    [root@localhost ~]# cat test.sh
    #!/bin/bash
    #
    #用途:简单的shell程序
    #
    #
    #
    function show_name()
    {
            echo "今天是 $1 ,你 $2 大大,来自 $3"
    }
    
    name=$1
    ip="192.168.1.16"
    today=$(date +%F)
    
    if [ $# != 1 ]; then
            echo "Usage: . /$0 [使用者名称]"
            exit
    fi
    
    show_name "$today" "$name" "$ip"
    
    sleep 5
    
    echo 
    
    echo "Bye-Bye ;-)"
    [root@localhost ~]# cat hello.c test.sh
    #include <stdio.h>
    
    int main(void)
    {
            printf("Hello world");
    }
    #!/bin/bash
    #
    #用途:简单的shell程序
    #
    #
    #
    function show_name()
    {
            echo "今天是 $1 ,你 $2 大大,来自 $3"
    }
    
    name=$1
    ip="192.168.1.16"
    today=$(date +%F)
    
    if [ $# != 1 ]; then
            echo "Usage: . /$0 [使用者名称]"
            exit
    fi
    
    show_name "$today" "$name" "$ip"
    
    sleep 5
    
    echo 
    
    echo "Bye-Bye ;-)"
    [root@localhost ~]# cat sorted.txt
    #没有任何内容
    [root@localhost ~]# cat hello.c test.sh > sorted.txt
    [root@localhost ~]# cat sorted.txt
    #include <stdio.h>
    
    int main(void)
    {
            printf("Hello world");
    }
    #!/bin/bash
    #
    #用途:简单的shell程序
    #
    #
    #
    function show_name()
    {
            echo "今天是 $1 ,你 $2 大大,来自 $3"
    }
    
    name=$1
    ip="192.168.1.16"
    today=$(date +%F)
    
    if [ $# != 1 ]; then
            echo "Usage: . /$0 [使用者名称]"
            exit
    fi
    
    show_name "$today" "$name" "$ip"
    
    sleep 5
    
    echo 
    
    echo "Bye-Bye ;-)"

    [root@localhost ~]# echo $FROM | cat - sorted.txt   将echo的命令和sorted.txt链接打印。注意到中间那个 - 了么?位补足,因为cat需要连接两个文档进行输出,所以,用 -来补足cat的参数位置
    joe@sample.edu.cn
    #include <stdio.h>

    
    

    int main(void)
    {
    printf("Hello world");
    }
    #!/bin/bash
    #
    #用途:简单的shell程序
    #
    #
    #
    function show_name()
    {
    echo "今天是 $1 ,你 $2 大大,来自 $3"
    }

    
    

    name=$1
    ip="192.168.1.16"
    today=$(date +%F)

    
    

    if [ $# != 1 ]; then
    echo "Usage: . /$0 [使用者名称]"
    exit
    fi

    
    

    show_name "$today" "$name" "$ip"

    
    

    sleep 5

    
    

    echo

    
    

    echo "Bye-Bye ;-)"

     

    head 输出文件默认为前10行,

    head -100 输出文件的前100行

    tail 输出文件的后面部分 默认为后10行

    tail -100 输出后100行

    wc  计算文件内涵的总字数和行数

    wc -l   显示有多少行

    wc -c 显示有多少字符

    wc -w 显示有多少单词

    ln  软硬链接

    ln f1 f2 将f1 f2进行硬连接

    ln -s f1 f3  将f3对f1进行软链接

    ls -sf f1 f3 也是将f3对f1进行软连接,但是如果f3软连接已经存在的话,则会删除原来的f3,重新建立

    软连接,硬连接不懂的,可以看以前的博客。鸟哥的书中讲的很详细

    mkdir 建立目录

    mkdir -p  如果子目录不存在,会同时建立相应级别的目录

    rmdir 删除空目录

    rm 删除文件

    rm -f 强行删除文件。如果只执行rm的话,一般会提示你是否要删除。如果使用命令行-f 来执行的话,则不会提示,会直接删除

    rm -Rf 目录

    -R采用递归方式,将目录下的所有子目录和文件删除

    find 在分层目录中寻找文件

    find 路径 样式  操作

    find / -name '*.txt'   从根目录往下查找所有后缀名为txt的文件

    find . -name '*.txt'  -exec rm -f {}

    会将工作目录中的所有txt文件删除

    前半部分不讲了,后面的-exec部分。exec 执行后面的命令。{} 表示找到的文件  ; 是执行 -exec的终止符,因为;是bash shell的特殊字符,所以需要来转义一下

    find /root -type d  -print

    选好文件形态是 目录 的文件。find 选项 -type 支持的种类有

    tar  将文件或目录打包成一个文件(也可以反向解开),并保留目录结构和文件的权限属性

     tar cvzf etc.tgz /etc

    将/etc目录打包成etc.tar.gz

    其中 c 代表建立tar文件,v表示详细显示过程,z代表呼叫gzip压缩tar 文件,f 指定文件名。

    tar tvzf etc.tgz

    t表示列出打包内容

    tar xvzf etc.tgz

    z表示呼叫gzip解压,x表示解包

    tar xvzf etc.tgz -C test2 。      如果要切换目录解压缩,一定要用实际路径,而非虚拟路径,否则会出问题。这个已经做过实验,否则他会在虚拟目录中在将原压缩文件目录进行新建并解压缩

    -C表示切换到某一目录。这个指令的意思是,把etc.tgz 放入到 test2目录中解压

    tar cvf - test2 | gzip -9 >save.tgz

    该方法是在不支持z选项的tar版本中。先用cvf把test2目录打包,- 表示将打包结果往标准输出丢,然后经由管道 交给gzip压缩,在转向文件save.tgz。其中 -9表示压缩比最高。

    gzip -9dc save.tgz | tar xvf -

    该方法也是在不支持z选项的tar版本中,解压缩。先用gzip解压缩save.tgz。其中 -d 表示解压之意, -c表示解压缩到标准输出,然后通过管道,交给tar解压。其中 最后一个 -  表示有标准输入读取数据

    备份目录A到目录B

    [root@localhost ntpFile]# tar cvf - . | tar xvf - -C /root/ntpFile2   

    这有两点要注意一下,首先要进入tar目录之中,然后后面的路径要实际路径。这样,就会将当前目录中的所有东西备份到ntpFile2中

    basename 取得路径名称中最后的文件名部分

    basename /usr/local/bin/sftp

    显示结果就是sftp

    dirname   取得路径名称中的目录部分

    dirname /usr/local/bin/sftp   显示结果/usr/local/bin

    sort  对文本文件的每一行做排序

    sort dataf4   按照ascII 的字符排列做升序

    sort -r dataf4   降序

    sort -n dataf4   按照字符串的数值大小升幂排序

     sort -k 2 dataf5   以 data5中的第二个字段做排序依据(以字符串比较的方式),如果使用-n 选项,则以数值大小的方式来比较

    sort -nk 2 dataf5  以数值大小的方式从data5中的第二个字段作为排序依据进行排序

    sort -n +2 dataf3  跳过前两栏,以dataf3中的第三栏以数值大小作为排序依据排序    【经检验,跨越行此操作无效

    sort -nr +2 -t: /etc/passwd -t 表示以:为分隔符,+2 跳过前两栏 ,以 /etc/passwd的第三栏作为降序牌系列,-n 表示sort以数值大小的方式进行比较,-r  降序排列【经检验,跨越行此操作无效

    [root@localhost ~]# sort -nr +2 -t: /etc/passwd 
    sort: cannot read: +2: 没有那个文件或目录
    如果要实现上述的命令,只能先取第三行之后的数据,在排序,删除重复行
    sed -n '2,$p' /et/passwd | sort -nr -t: | uniq

    sort < data4 > sorted 

    从标准输入data4排序后,转存到sorted中

    uniq  对以排序文件删除重复行

    uniq dataf3  注:若重复列未连续摆在一起,则不会起任何作用。所以这就要求,先排序再删除重复行,否则会导致有些重复行无法删除

    sort dataf3 | uniq

    sort dataf3 | uniq -d  挑出重复行

    sort dataf3 | uniq -c 计算每一行重复的次数

    cut 对文件中的每一行抽取某一部分

    cut -c2 dataf1   抽取dataf1中每一行的第2个字符

    [root@localhost ~]# cut -c2 /etc/passwd
    o
    i
    a
    d

    cut -c3-10 dataf1 从dataf1中每一行抽取3-10个字符

    [root@localhost ~]# cut -c2-10 /etc/passwd
    oot:x:0:0
    in:x:1:1:
    aemon:x:2
    dm:x:3:4:
    p:x:4:7:l

    cut -c1-3 ,22- dataf1 从dataf1中抽取1-3和22到之后的所有字符

    cut -d: -f1 /etc/passwd   -d 是以:为分隔符   -f1 是取第一个字段的意思

    [root@localhost ~]# cut -d: -f1 /etc/passwd
    root
    bin
    daemon
    adm
    lp

    cut -d: -f3,4 /etc/passwd   以:为分隔符,取第三,第四行的数据

    [root@localhost ~]# cut -d: -f1,3 /etc/passwd
    root:0
    bin:1
    daemon:2
    adm:3
    lp:4
    sync:5

    [root@localhost ~]# cut -d: -f1,3- /etc/passwd    #3-表示从第3行开始到最后所有的数据全部重现

    root:0:0:root:/root:/bin/bash
    bin:1:1:bin:/bin:/sbin/nologin
    daemon:2:2:daemon:/sbin:/sbin/nologin
    adm:3:4:adm:/var/adm:/sbin/nologin
    lp:4:7:lp:/var/spool/lpd:/sbin/nologin

    paste  对文件以行和行的方式合并

    paste dataf1 dataf2   将dataf1的每一行和dataf2的每一行合并。默认以tab分隔

    paste -d'#' dataf1 dataf2  将dataf1每一行与dataf2每一行合并。默认以#分割

    paste -s dataf4 将dataf4每一行自己合并起来。并默认以tab分割

    tr  转换或删除字符

    tr k K <dataf1 将dataf1中的k 转换成 K

    tr ',' ' ' <ttt  将ttt文件中的逗号  转换成

    tr -d k 将k字符全部删除

    cut -d: -f1-6 /etc/passwd | tr :'+'  将etc/password的1-6栏中的所有改成 + 分割

    [root@localhost ~]# cut -d: -f1-6 /etc/passwd | tr : '+'  
    root+x+0+0+root+/root
    bin+x+1+1+bin+/bin
    daemon+x+2+2+daemon+/sbin
    adm+x+3+4+adm+/var/adm
    lp+x+4+7+lp+/var/spool/lpd
    sync+x+5+0+sync+/sbin
    shutdown+x+6+0+shutdown+/sbin
    halt+x+7+0+halt+/sbin
    mail+x+8+12+mail+/var/spool/mail

    tr '[A-Z]' '[a-z]' <dataf1  将dataf1中的所有大写字母改成小写字母

    tr -s '''' < dataf1  将多余的空白删除,只剩一个  (-s 是挤压的意思)

    grep 显示符合样式的行

    grep A* 将所有包含A的文件及行显示出来

    grep -i A* 将所有包含A或a的文件及行显示出来  -i 是不区分大小写的意思

    grep -v La data3 将不包含La的文件及行显示出来  -v 是不包含的意思

    grep -l La* 只显示包含La的行

    grep -n La* 同上,但也显示出行号

    dmesg | grep eht0 将含有eth0的这个关键词的信息显示出来。

    Linux 命令 dmesg 用来显示开机信息,kernel 会将开机信息存储在 ring buffer 中。若是开机时来不及查看信息,可利用 dmesg 来查看。开机信息亦保存在 /var/log 目录中,名称为 dmesg 的文件里。通过 grep 使用管道查看 dmesg 的输出,可以更容易找到待查信息。

    grep -q keyword filename 若filename包含keyword则返回0(真),否则,返回非0

    每个命令或Script,在执行完毕后,其执行结果会以一个数值传回,成为离去状态。他的传回值会放在 $? 这个变量中,只要echo $?,便可得知起执行结果与否。请记住0 成功,非0失败

    grep -A 200 -e 'XXXX‘ filename

    -e 表示后面接的是欲比较的样式

    -A 200表示找到该样式后再显示接下来的200行数据

    tee 读取标准输入,然后由标准输出显示,并把这些数据存储在指定的文件

    tee test.log 若test.log存在,则会清空,若不存在,则会创建新文件。欲结束输入,按ctrl +d .输入的数据回储存在test.log中

    tee -a filename 以附加的形式,将输入的内容添加到filename文件中

    diff  比较两个文件的差异

    diff hello.sh hello2.sh

    comm 以列和列的方式,比较两个已排序好的文件

    第一个文件存在的内容会放在第一列

    第二个文件存在的内容会放在第二列

    两个文件都存在的内容会放在第三列

    xargs  有标准输入,安排要执行的命令和参数

    find . -name '*.txt' | xargs -n 2 diff

    由现在的工作目录,寻找扩展名为 .txt的文件,然后丢给xargs来处理。-n 2 表示执行指令的参数之多2个,也就是说把找到的txt文件。以两个一组的方式,丢给diff去比较差异

    diff: missing operand after './.subversion/README.txt'
    diff: Try 'diff --help' for more information.
    [root@localhost ~]# find -name '*.txt' | xargs -n 2 diff

    #如果包含的文件为奇数,就会报错。因为只有一个参数,而diff 需要两个参数

    三   执行多个命令的方法

    命令行中,可以一次执行多个命令,其方式有一下几种

    1 各命令用  ,   分割                                解析:各命令互不干扰,前面的命令执行失败,后面的命令也会继续执行

    2 每个命令之间用 && 分割       解析:各命令依次为条件。前面的命令执行成功,后面的命令才会执行。常用在自行安装的script中

    文中给了一个自动安装apache和php的脚本。这个脚本的用途在于下载源代码包文件后的自行安装。现在一般都用yum源来安装,如果没有,你就只能用这个脚本文件来操作。

    #! /bin/bash
    
    
    #解压缩   这个要改成你自己的apache版本和php版本。而且这个版本很低,还需要根据最新的configure的要求进行设定。也就是说你直接用不一定好用。最新的我直接用yum安装的,所以我就不测试了
    tar -xvzf httpd-2.2.11.tar.gz &&
    tar -xvzf php-5.3.0.tar.gz &&
    
    #设定apache
    echo ' Configure apache .....' &&
    cd httpd-2.2.11 && 
    ./configure --prefix=/usr/local/apache2 --enable-so &&
    make &&
    make install &&
    
    #设定/编译/安装php
    cd ../php-5.3.0 &&
    ./configure 
                    --with-apxs2=/usr/local/apache2/bin/apxs
                    --with-mysql=/usr/local/mysql && make && make install &&
    
    #复制php.ini到/usr/local/lib
    cp -f php.ini-production /usr/local/lib/php.ini &&
    
    echo
    
    echo 'Done!'
    
    echo
    ~        

    3  ||  命令1 || 命令2 || 命令3   解析:当命令1执行成功的时候,就会退出。如果命令1失败,才执行命令2.同理命令3

    4  将命令弄成一组,整体执行命令

      (命令1;命令2;命令3)   解析   新开一个shell窗口来执行。这样就可以通过 & 来拖到后台执行

            { 命令1;命令2;命令3 }    解析   在当前shell总体执行所有命令。在大括号的左右两侧,各需要间隔至少一个空格,而且每个命令都需要一个;来做为结束

    四  记录命令执行过程

    Script工具程序   /usr/lib/script目录中

    如果不提供自定义日志文件,默认会将数据存储在 typescript 文件中

    script log.txt    就会将执行命令所产生的信息记录下来,存放在Log.txt中,执行script之后,就可以执行各种操作了。script会记录下所有的输出信息,如果要结束操作,exit 便可以离开script

    [root@localhost ~]# script log.txt
    Script started, file is log.txt
    [root@localhost ~]# ls -la /tmp/
    总用量 1028
    drwxrwxrwt. 24 root root   4096 10月  8 16:13 .
    dr-xr-xr-x. 18 root root    239 8月  28 17:26 ..
    drwx------.  2 root root     20 9月  19 11:09 .esd-0
    drwx------.  2 lsq  lsq      20 9月  19 11:14 .esd-1000
    drwxrwxrwt.  2 root root      6 8月  19 11:03 .font-unix
    drwxr-xr-x.  2 root root      6 9月  18 14:15 hsperfdata_root
    drwxrwxrwt.  2 root root     44 9月  19 11:14 .ICE-unix
    drwx------.  2 lsq  lsq      25 9月  19 11:14 ssh-8c8E8ZoTR6JT
    drwx------.  3 root root     17 9月  26 08:45 systemd-private-2f2a7500abcf4dba99ce9b179eae6d57-httpd.service-3n0xvq
    drwx------.  3 root root     17 9月  26 08:45 systemd-private-2f2a7500abcf4dba99ce9b179eae6d57-systemd-machined.service-sWIVg8
    drwx------.  3 root root     17 9月  19 13:42 systemd-private-32b42b88babe40ff91a8f886ef37c4de-colord.service-JTClM4
    drwx------.  3 root root     17 9月  20 10:08 systemd-private-32b42b88babe40ff91a8f886ef37c4de-fwupd.service-j3e8ab
    drwx------.  3 root root     17 9月  19 11:13 systemd-private-32b42b88babe40ff91a8f886ef37c4de-httpd.service-CTIPHR
    drwx------.  3 root root     17 9月  19 11:13 systemd-private-32b42b88babe40ff91a8f886ef37c4de-rtkit-daemon.service-1cRAUO
    drwx------.  3 root root     17 9月  19 11:13 systemd-private-32b42b88babe40ff91a8f886ef37c4de-systemd-machined.service-TIRI3p
    drwx------.  2 lsq  lsq       6 9月  18 16:40 Temp-e6f811a6-1f8e-4f3a-b10c-847129fbefbc
    drwxrwxrwt.  2 root root      6 8月  19 11:03 .Test-unix
    drwx------.  2 root root      6 9月  19 11:09 tracker-extract-files.0
    drwx------.  2 lsq  lsq       6 9月  18 16:40 tracker-extract-files.1000
    drwx------.  2 root root      6 9月  19 11:13 vmware-root_7008-2831224237
    drwx------.  2 root root      6 9月  26 08:45 vmware-root_7029-3854406118
    drwx------.  2 root root      6 9月  17 15:19 vmware-root_7031-3845951588
    drwxrwxrwt.  2 root root     26 9月  19 11:14 .X11-unix
    drwxrwxrwt.  2 root root      6 8月  19 11:03 .XIM-unix
    -rw-------.  1 root root 523044 9月  19 11:10 yum_save_tx.2019-09-19.11-10.BH4F6D.yumtx
    -rw-------.  1 root root 523044 9月  20 10:54 yum_save_tx.2019-09-20.10-54.ZDRbv2.yumtx
    [root@localhost ~]# exit
    exit
    Script done, file is log.txt
    [root@localhost ~]# cat log.txt
    脚本启动于 2019年10月08日 星期二 16时19分43秒
    [root@localhost ~]# ls -la /tmp/
    总用量 1028
    drwxrwxrwt. 24 root root   4096 10月  8 16:13 .
    dr-xr-xr-x. 18 root root    239 8月  28 17:26 ..
    drwx------.  2 root root     20 9月  19 11:09 .esd-0
    drwx------.  2 lsq  lsq      20 9月  19 11:14 .esd-1000
    drwxrwxrwt.  2 root root      6 8月  19 11:03 .font-unix
    drwxr-xr-x.  2 root root      6 9月  18 14:15 hsperfdata_root
    drwxrwxrwt.  2 root root     44 9月  19 11:14 .ICE-unix
    drwx------.  2 lsq  lsq      25 9月  19 11:14 ssh-8c8E8ZoTR6JT
    drwx------.  3 root root     17 9月  26 08:45 systemd-private-2f2a7500abcf4dba99ce9b179eae6d57-httpd.service-3n0xvq
    drwx------.  3 root root     17 9月  26 08:45 systemd-private-2f2a7500abcf4dba99ce9b179eae6d57-systemd-machined.service-sWIVg8
    drwx------.  3 root root     17 9月  19 13:42 systemd-private-32b42b88babe40ff91a8f886ef37c4de-colord.service-JTClM4
    drwx------.  3 root root     17 9月  20 10:08 systemd-private-32b42b88babe40ff91a8f886ef37c4de-fwupd.service-j3e8ab
    drwx------.  3 root root     17 9月  19 11:13 systemd-private-32b42b88babe40ff91a8f886ef37c4de-httpd.service-CTIPHR
    drwx------.  3 root root     17 9月  19 11:13 systemd-private-32b42b88babe40ff91a8f886ef37c4de-rtkit-daemon.service-1cRAUO
    drwx------.  3 root root     17 9月  19 11:13 systemd-private-32b42b88babe40ff91a8f886ef37c4de-systemd-machined.service-TIRI3p
    drwx------.  2 lsq  lsq       6 9月  18 16:40 Temp-e6f811a6-1f8e-4f3a-b10c-847129fbefbc
    drwxrwxrwt.  2 root root      6 8月  19 11:03 .Test-unix
    drwx------.  2 root root      6 9月  19 11:09 tracker-extract-files.0
    drwx------.  2 lsq  lsq       6 9月  18 16:40 tracker-extract-files.1000
    drwx------.  2 root root      6 9月  19 11:13 vmware-root_7008-2831224237
    drwx------.  2 root root      6 9月  26 08:45 vmware-root_7029-3854406118
    drwx------.  2 root root      6 9月  17 15:19 vmware-root_7031-3845951588
    drwxrwxrwt.  2 root root     26 9月  19 11:14 .X11-unix
    drwxrwxrwt.  2 root root      6 8月  19 11:03 .XIM-unix
    -rw-------.  1 root root 523044 9月  19 11:10 yum_save_tx.2019-09-19.11-10.BH4F6D.yumtx
    -rw-------.  1 root root 523044 9月  20 10:54 yum_save_tx.2019-09-20.10-54.ZDRbv2.yumtx
    [root@localhost ~]# exit
    exit
    
    Script done on 2019年10月08日 星期二 16时19分56秒

    五  命令行编辑方法

    Bash支持命令行编辑,也就是如果打错了某个命令,可以移动光标对指令进行修改。Bash之所以有这个功能是因为GNU的Readline函数库。Readline函数库支持 Emacs和vi两种编辑模式。文中推荐Emacs模式

    首先检查编辑模式是否位Emacs模式

    [root@localhost ~]# set -o | grep emacs
    emacs           on    #我这里是打开的
    #如果是关闭的,则用下面命令打开
    [root@localhost ~]# set -o emacs

     

     

     

     

     六   Bash 分析命令行的方式

    分割管道=》对各命令进行分析=》取出token(使用分隔符,如空白 tab 将命令分割成组成命令的单词) =》替换别名 =》括号扩展 ({a,b}in  扩展成 ain,bin)=> ~ 符号扩展 (如果有家目录符号,扩展成实际路径) => 替换变量 =》 替换命令 =》 替换算术 =》 替换通配符

    =》 根据函数,内置命令,搜寻路径顺序,找寻第一个token所代表的命令位于何处 =》 执行替换完成的指令

     

  • 相关阅读:
    PythonStudy——greenlet 协程
    PythonStudy——事件 Event
    PythonStudy——单线程并发的实现
    2015年的总结
    kylin一种OLAP的实现
    分布式消息队列的使用kakfa
    第一次听到了docker
    Hive分布式的数据仓库
    dubbo服务框架学习
    Storm实时计算框架的编程模式
  • 原文地址:https://www.cnblogs.com/Lonelychampion/p/11586286.html
Copyright © 2020-2023  润新知