博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
10个Linux脚本面试题,看看你能答出几个?
阅读量:6232 次
发布时间:2019-06-21

本文共 4823 字,大约阅读时间需要 16 分钟。

1、写一个脚本,判断当前系统上所有用户的shell是否为可登录shell(即用户的shell不是/sbin/nologin);

分别这两类用户的个数;通过字符串比较来实现;

 declare -a shell        declare sum_login=0        declare sum_nologin=0        shell=($(cat /etc/passwd | cut -d: -f7))        for((i=0;i<${#shell[*]};i++));do           if [  "${shell[i]}" = "/sbin/nologin" ];then                 sum_login=$[$sum_login+1]              else                 sum_nologin=$[$sum_nologin+1]           fi        done        echo "nologin users is $sum_nologin."        echo "login users is $sum_login."

2、写一个脚本

(1) 获取当前主机的主机名,保存于hostname变量中;
(2) 判断此变量的值是否为localhost,如果是,则将当前主机名修改为www.magedu.com;
(3) 否则,则显示当前主机名;

#!/bin/bash         hostname=$(cat /etc/sysconfig/network | grep HOSTNAME | cut -d= -f2)         if [ "$hostname" = "localhost" ];then           sed -i "s/localhost/www.magedu.com/g"  /etc/sysconfig/network         else           echo $(hostname)         fi

3、写一个脚本,完成如下功能

(1) 传递一个磁盘设备文件路径给脚本,判断此设备是否存在;
(2) 如果存在,则显示此设备上的所有分区信息;

#!/bin/bash          fdisk -l $1 &> /dev/null;          if [ $? -eq 0 ];then             fdisk -l $1           else              echo "fisk is not found!"          fi

4、写一个脚本,完成如下功能

脚本能够接受一个参数;
(1) 如果参数1为quit,则显示退出脚本,并执行正常退出;
(2) 如果参数1为yes,则显示继续执行脚本;
(3) 否则,参数1为其它任意值,均执行非正常退出;

case "$1" in        "yes")                echo "running...."                ;;        "quit") echo "quit"                exit 0                ;;        "*")                echo "break"                exit 1                ;;     esac

5、写一个脚本,完成如下功能

传递一个参数给脚本,此参数为gzip、bzip2或者xz三者之一;
(1) 如果参数1的值为gzip,则使用tar和gzip归档压缩/etc目录至/backups目录中,并命名为/backups/etc-20160613.tar.gz;
(2) 如果参数1的值为bzip2,则使用tar和bzip2归档压缩/etc目录至/backups目录中,并命名为/backups/etc-20160613.tar.bz2;
(3) 如果参数1的值为xz,则使用tar和xz归档压缩/etc目录至/backups目录中,并命名为/backups/etc-20160613.tar.xz;
(4) 其它任意值,则显示错误压缩工具,并执行非正常退出;

#!/bin/bash  if [ $# -eq 1 ];then            case $1 in                "gzip")                    tar -zcf /backup/etc-`date +%F`.tar.gz /etc/* ;;                "bzip2")                    tar -jcf /backup/etc-`date +%F`.tar.gz /etc/* ;;                "xz")                    tar -Jcf /backup/etc-`date +%F`.tar.gz /etc/* ;;                *)                    echo -e "Error Pack Tool \nUsage: $0 gzip|bzip2|xz "                    exit 1 ;;            esac          else            echo -e "Parameters Error \nUsage: $0 gzip|bzip2|xz"        fi

6、写一个脚本,接受一个路径参数:

(1) 如果为普通文件,则说明其可被正常访问;
(2) 如果是目录文件,则说明可对其使用cd命令;
(3) 如果为符号链接文件,则说明是个访问路径;
(4) 其它为无法判断;

#!/bin/bashif [ $# -eq 1 ];then            if [ -f $1 ];then                echo "$1 is file"            elif [ -d $1 ];then                echo "$1 is directory "            elif [ -L $1 ];then                echo "$1 is  symlink file"            else                echo "Can't file $1 type"            fi          else            echo -e "Parameter Error!"          fi

7、写一个脚本,取得当前主机的主机名,判断

(1) 如果主机名为空或为localhost,或为””(none)””,则将其命名为mail.magedu.com;
(2) 否则,显示现有的主机名即可;

#!/bin/bash         hostname=$(cat /etc/sysconfig/network | grep HOSTNAME | cut -d= -f2)         if [ "$hostname" = "none" -o "$hostname" = "" ];then           sed -i "s/localhost/www.magedu.com/g"  /etc/sysconfig/network         else           echo $(hostname)         fi

8、写一脚本,接受一个用户名为参数;

(1) 如果用户的id号为0,则显示其为管理员;
(2) 如果用户的id号大于0且小于500, 则显示其为系统用户;
(3) 否则,则显示其为普通用户;

id $1 &> /dev/null    result=$(id -u $1)    if [ $result -eq 0 ];then        echo "system admin"     elif [ $result -ge 1  -a $result -le 500 ];then        echo "system user"     else         echo "common user"    fi

9、写一个脚本,传递一个用户名参数给脚本;

(1) 如果用户的id号大于等于500,且其默认shell为以sh结尾的字符串,则显示“a user can log system.”类的字符串;
(2) 否则,则显示无法登录系统;

#!/bin/bash    result=$(id -u $1)    if [ $result -ge 500 ];then        shell=$(cat /etc/passwd | grep "$result" | cut -d: -f7)        echo "$shell" | grep "sh$"        shell_result=$?        if [ $shell_result -eq 0 ];then            echo "a user can log system."           else            echo "user $1 nologin system."        fi      else       echo "user id less than 500."    fi

10、写一个脚本,完成如下任务 :

(1) 按顺序分别复制/var/log目录下的每个直接文件或子目录至/tmp/test1-testn目录中;
(2) 复制目录时,才使用cp -r命令;
(3) 复制文件时使用cp命令;
(4) 复制链接文件时使用cp -d命令;
(5) 余下的所有类型,使用cp -a命令;

#!/bin/bash          file=/var/log/*          for i in $file;do                  if [ -f $i ];then                          echo "$i is common file"                          cp $i /tmp/test1-testn/                  elif [ -L $i ];then                          echo "$i is link file"                          cp -d $i /tmp/test1-testn/                  elif [ -d $i ];then                          echo "$i is directory"                          cp -r $i /tmp/test1-testn                  else                          echo "$i is other file"                          cp -a $i /tmp/test1-testn                  fi          done

本文由马哥Linux运维学员原创,首发于

转载地址:http://oktna.baihongyu.com/

你可能感兴趣的文章
GNU Chess
查看>>
漂亮的字体组合的秘密
查看>>
免费高品质的纹理素材网站
查看>>
《Linux From Scratch》第一部分:介绍 第一章:介绍-1.1 如何构建LFS系统
查看>>
Sketch的过去现在和未来
查看>>
TableEdit&amp;nbsp;UI_10
查看>>
[译] 通知是一种「暗模式」吗?
查看>>
企业在云迁移过程中需解决常见的IP地址问题
查看>>
AWS 张侠:为企业创新和转型提供助力
查看>>
阿里云王坚:运营才能缔造真正的云计算
查看>>
远程数据库的表超过20个索引的影响
查看>>
__attribute__ ((packed)) 的作用
查看>>
【Django】CentOS7安装Django笔记
查看>>
《Linux From Scratch》第三部分:构建LFS系统 第六章:安装基本的系统软件- 6.71. 再次清理无用内容...
查看>>
趋势科技CEO陈怡桦:敌人是谁?
查看>>
zabbix漏洞利用 Zabbix Server远程代码执行漏洞CVE-2017-2824 2.4.X均受影响
查看>>
带项目体会 合格的Leader 应该具备什么特质?
查看>>
Black Hat|黑客演示如何向卫星网络发送篡改信号
查看>>
揭秘中国数据库研究鲜为人知的那些事
查看>>
新年伊始你需要做的10个管理任务
查看>>