zoukankan      html  css  js  c++  java
  • 经典shell面试题整理

    一、取出/etc/passwd文件中shell出现的次数
    问题:下面是一个/etc/passwd文件的部分内容。题目要求取出shell并统计次数,shell是指后面的/bin/bash,/sbin/nologin等,如下面/bin/bash出现12次,/sbin/nologin出现3次。
     
    hyn:x:525:500::/home/hyn:/bin/bash   
    ljlxx:x:526:500::/home/ljlxx:/bin/bash   
    lzj:x:527:500::/home/lzj:/bin/bash   
    wfly:x:528:500::/home/wfly:/bin/bash   
    squid:x:23:23::/var/spool/squid:/sbin/nologin   
    wyj:x:529:500::/home/wyj:/bin/bash   
    qemu:x:107:107:qemu user:/:/sbin/nologin   
    radvd:x:75:75:radvd user:/:/sbin/nologin   
    dungbee:x:530:500::/home/dungbee:/bin/bash   
    mysql:x:27:27:MySQL Server:/var/lib/mysql:/bin/bash   
    scidb:x:531:531::/home/scidb:/bin/bash   
    postgres:x:532:532::/home/postgres:/bin/bash   
    crane:x:533:533::/home/crane:/bin/bash   
    test:x:534:534::/home/test:/bin/bash   
    hguser:x:535:535::/home/hguser:/bin/bash  
    参考答案: 
    cat /etc/passwd|awk -F: '{print $7}'|sort|uniq -c  
    解析:
    使用awk根据冒号分割内容,打印输出分割后的第7列,也就是shell所在列。然后调用sort命令排序并使用uniq -c统计每个shell出现的次数。
     
     
    二、文件整理
    问题:
    employee文件中记录了工号和姓名 
    employee.txt:   
    100 Jason Smith    
    200 John Doe    
    300 Sanjay Gupta    
    400 Ashok Sharma
    bonus文件中记录工号和工资 
    bonus.txt:   
    100 $5,000    
    200 $500    
    300 $3,000    
    400 $1,250
    要求把两个文件合并并输出如下
    处理结果: 
    400 ashok sharma $1,250   
    100 jason smith  $5,000   
    200 john doe  $500   
    300 sanjay gupta  $3,000  
    参考答案:
    paste employee.txt bonus.txt | awk '{print $1,$2,$3,$5}'|tr '[:upper:]' '[:lower:]'|sort -k 2  
    解析:
    这里用到好几个命令,包括paste,awk,tr以及sort。paste命令用于合并多个文件的同行数据,如上面两个文件employee和bonus调用paste后合并成
    100 Jason Smith     100 $5,000    
    200 John Doe    200 $500    
    300 Sanjay Gupta    300 $3,000    
    400 Ashok Sharma    400 $1,250   
    paste命令可以使用-d指定合并时加入的符号。比如paste -d : employee bonus则结果变成类似100 Jason Smith :100 $5,000 等。默认合并符号为tab符号。
    awk用于提取除了tab符号的其余4列。
    tr命令用于将字符串中所有大写字符转换为小写字符。
    sort命令对字符排序。sort -k 2表示按文件第2个域排序,这里第二个域为姓名,所以是按姓名升序排序。如果要降序排列,则要用sort -k 2r。
     
     
    三、打印本机交换分区大小
    问题:打印本机交换分区大小,输出如下
    Swap:1024M  
    参考答案:
    top -n 1|grep Swap|sed 's/k.*//'|awk '{print $1,$2/1000"M"}'  
    解析:
    top 命令显示系统资源占用情况,-n 1表示只调用1次。
    grep Swap选取Swap所在行。grep命令执行后结果可能如下:
    Swap: 16779884k total,        0k used, 16779884k free,  3268200k cached  
    sed命令用于字符串的一些正则匹配,这里使用了替换参数,将第1个k以及后面的字符替换成了空白。这样,sed执行后,结果为:
    Swap: 16779884  
    awk命令输出内容,对第二个参数除以1000.
     
     
    四、用户清理
    问题:清除本机除了当前登陆用户以外的所有用户。
    参考答案:
     
    kill $(who -u|grep -v `whoami`|awk '{print $6}'|sort -u)  
    解析:
     
    who -u显示所有当前用户。grep -v选取当前登录用户以外的所有用户。awk打印用户进程ID。sort -u会删除相同的行。最后用kill命令终止。
  • 相关阅读:
    vue之v-on
    垂直居中下
    垂直居中上
    vue之v-for
    vue之v-if和v-show
    vue之v-model
    vue之v-bind
    数学---目录
    【数学】证明题
    【计算机网络】应用层
  • 原文地址:https://www.cnblogs.com/fjping0606/p/4573466.html
Copyright © 2011-2022 走看看