马哥教育网络班21期+第9周课程练习

1、写一个脚本,判断当前系统上所有用户的shell是否为可登录shell(即用户的shell不是/sbin/nologin);分别这两类用户的个数;通过字符串比较来实现;

#!/bin/bash
    #
    nolog=`awk -F: '$7=="/sbin/nologin"{print $1,$7}' /etc/passwd|wc -l`
    norlog=`awk -F: '$7!="/sbin/nologin"{print $1,$7}' /etc/passwd|wc -l`    
    echo "nologin user is $nolog"
    echo "normoal user is $norlog"

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

    #!/bin/bash
    #
    
    hostname=`/bin/hostname`    if [ $hostname == "localhost" ] ;then
        /bin/hostname www.magedu.com    else
        /bin/hostname
    fi

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

    #!/bin/bash
    #
    [ $# -eq 0 ] && echo "Usage:$0 device dir" && exit
    [ $# -ge 2 ] && echo "only one args can use" && exit
    [ -b $1 ] && fdisk -l $1 || echo "not a devicefile dir"

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

    #!/bin/bash
    #
    [ $# -eq 0 ] && echo "Usage :$0 args " && exit
    if [ $1 == "quit" ] ;then
    exit
    elif [ $1 == "yes" ];then
    continue
    else
    exit 3
    fi

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
    #
    [ -d /backups ] || mkdir /backups
    [ $# -eq 0 ] && echo "Usage $0 gzip|bzip2|xz" && exit
    [ $# -ge 2 ] && echo "args must one" && exit
    case $1 in 
        gzip)
        tar -zcvf /backups/etc-20160613.tar.gz /etc &>/dev/null
    ;;
        bzip2)
        tar -jcvf /backups/etc-20160613.tar.bz2 /etc &>/dev/null
    ;;
        xz)
        tar -Jcvf /backups/etc-etc-20160613.tar.xz /etc &>/dev/null
    ;;
        *)        echo "select wrong tool"
        exit 3
    ;;    esac

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

    #!/bin/bash
    #
    [ $# -eq 0 ] && echo "usage $0 dirpath" && exit
    [ $# -ge 2 ] && echo "args must one" && exit
    
    if [ -L $1 ];then
        echo "$1 是个链接"
    elif [ -d $1 ];then
        echo "$1 可被使用cd命令"
    elif [ -f $1 ];then
        echo "$1 是个普通文件"
    else
        echo "$1 无法判断"
    fi

7、写一个脚本,取得当前主机的主机名,判断
(1) 如果主机名为空或为localhost,或为"(none)",则将其命名为mail.magedu.com
(2) 否则,显示现有的主机名即可;

    #!/bin/bash
    #
    for i in `/bin/hostname`;do
    
    case $i in
        localhost|none)
            /bin/hostname mail.magedu.com
    ;;
        *)
            /bin/hostname
    ;;    esac
    done

8、写一脚本,接受一个用户名为参数;
(1) 如果用户的id号为0,则显示其为管理员;
(2) 如果用户的id号大于0且小于500, 则显示其为系统用户;
(3) 否则,则显示其为普通用户;

    #!/bin/bash
    #
    [ $# -eq 0 ] && echo "usage $0 arges " && exit
    [ $# -ge 2 ] && echo "must one arges " && exit
    declare -a aa
    aa=`awk -F: '{print $1}' /etc/passwd | xargs`    if echo ${aa[@]} | grep -w "$1" &>/dev/null;then
        echo "$1 is a user"
    if [ `id -u $1` -eq 0 ] ;then
        echo "$1 is adm" && exit
    elif [ `id -u $1` -gt 0 -a `id -u $1` -lt 500 ] ;then
        echo "$1 is sysuser" && exit
    else
        echo "$1 is normal user"
    fi
    
    else
        echo "$1 is not a user"
    fi

10、写一个脚本,传递一个用户名参数给脚本;
(1) 如果用户的id号大于等于500,且其默认shell为以sh结尾的字符串,则显示“a user can log system.”类的字符串;
(2) 否则,则显示无法登录系统;

    #!/bin/bash
    #
    #!/bin/bash
    #
    [ $# -eq 0 ] && echo "usage $0 arges " && exit
    [ $# -ge 2 ] && echo "must one arges " && exit
    declare -a aa
    aa=`awk -F: '{print $1}' /etc/passwd | xargs`    if echo ${aa[@]} | grep -w "$1" &>/dev/null;then
        echo "$1 is a user"
        [ `id -u $1` -gt 500 ] && awk -F: '$3>500 && $7~/sh$/ {print $1}' /etc/passwd | grep -w "$1" &>/dev/null  && echo "a user can log system."
    else
        echo "$1 is not a user"
    fi

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

    #!/bin/bash
    #
    dir='/var/log/'
    des='/tmp/test1-testn/'
    declare -a args
    args=`ls $dir | xargs`
    [ -d $des ] || mkdir $des
    for i in ${args[@]};do
     
    if [ -L $dir$i ] ;then
        cp -d $dir$i $des  
    elif [ -d $dir$i ];then
        cp -r $dir$i $des
    elif [ -f $dir$i ];then
        cp $dir$i $des
    else
        cp -a $dir$i $des
    fi
    done

原创文章,作者:hhaa0352,如若转载,请注明出处:http://www.178linux.com/47202

(0)
上一篇 2016-09-19 13:47
下一篇 2016-09-19 13:48

相关推荐

  • N25-第三周博客作业

    1、列出当前系统上所有已经登录的用户的用户名,注意:同一个用户登录多次,则只显示一次即可。 [root@node1 ~]# who | cut -d" " -f1 | uniq (unknown) root 2、取出最后登录到当前系统的用户的相关信息…

    Linux干货 2016-12-17
  • 自制linux系统

    自制linux系统  需要为虚拟机新增一个硬盘,作为自制linux系统的载体。也可以用U盘、移动硬盘或其他设备作为载体实验步骤: (1)为虚拟机新增一个大小为20G的硬盘(2)给新增的磁盘分区,划分/boot、swap、/三个分区比如,将第一个分区当作boot,大小为500M;第二个分区当作swap分区,大小为2G;第三个分区用作/,大小为10G。…

    Linux干货 2016-09-13
  • 磁盘管理

    上图sda disk information中对 255 heads,63 sectors/track,1958 cylinders的解析: sda磁盘总共有1958个cylinder(柱面),每个cylinder(柱面)有63个sectors(扇区),每个sectors(扇区)有255个heads(磁头) 那么这块sda的总的磁头数量为:255*63*19…

    2017-08-20
  • Linux基础小模块

    1.基础知识小块:shell 由shell程序的自带命令:即为内置命令(builtin) 独立的可执行程序文件、文件名 :即为外部命令  [root@localhost~]#ls      ~用户当前所在目录  #:命令提示符(管理员帐号root)  $:普通用户   &nbsp…

    Linux干货 2016-08-10
  • linux中nmcli命令使用及网络配置

      Red Hat Enterprise Linux 7 与 CentOS 7 中默认的网络服务由 NetworkManager 提供,这是动态控制及配置网络的守护进程,它用于保持当前网络设备及连接处于工作状态,同时也支持传统的 ifcfg 类型的配置文件。  NetworkManager 可以用于以下类型的连接:Ethernet,VLA…

    Linux干货 2016-09-10
  • N27_第一周作业

    一、描述计算机的组成及其功能 计算机由CPU、内存、输入设备和输出设备组成。 CPU:运算器、控制器、寄存器、缓存 *运算器:进行数字运算和逻辑运算。 *控制器: A、从内存中取出一条指令,并指出下一条指令在内存中的位置; B、对指令进行译码或测试,并产生相应的操作控制信号; C、控制并控制CPU、内存和输入/输出设备之间数据流动的方向。 *寄存器:暂存指令…

    Linux干货 2017-09-04

评论列表(1条)

  • 马哥教育
    马哥教育 2016-09-19 17:25

    第7题不需要用for循环来做,写脚本的时候,最好是一个命令一行,这样会易读一些