马哥教育网络班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)
hhaa0352hhaa0352
上一篇 2016-09-19
下一篇 2016-09-19

相关推荐

  • 马哥教育网络班22期+第四周课程练习

    1、复制/etc/skel目录为/home/tuser1,要求/home/tuser1及其内部文件的属组和其它用户均没有任何访问权限。 ~]# cp -r /etc/skel/ /home/tuser1/ ~]# chmod 700 /home/tuser1/ -R 2、编辑/e…

    Linux干货 2016-09-06
  • 文本查看、处理工具的应用及组、用户的相关操作

            一、列出当前系统上所有已经登录的用户的用户名,注意:同一个用户登录多次,则只显示一次即可      查看已经登录的用户用“who”命令,为了试验我用root多登录了几次。    &nb…

    2017-07-16
  • Linux 目录结构

    Linux 目录结构 1.     前言     Linux 是一种开源的,且非常流行的操作系统,发行版本众多。为了统一和规范linux系统的主要目录名及其用途,提出了FHS标准,FHS是File Hierarchy Standard的简写。Linu…

    Linux干货 2015-07-26
  • rsync+inotify实现数据实时备份

    rsync+inotify实现数据实时备份 §·rsync简单介绍 1 §·什么是rsync 1 §·rsync的功能特性 1 §·rsync的优点和不足 2 §·初识inotify 2 §·rsync命令工作模式 2 §·rsync常用命令选项 3 §·配置rsync以守护进程的方式运行 3 ※·安装并启动 xinetd 3 ※·为rsync服务器提供配置…

    Linux干货 2016-10-30
  • vim小结

    1. 简介 Vim(Vi[Improved])编辑器是功能强大的跨平台文本文件编辑工具,继承自Unix系统的Vi编辑器,支持Linux/Mac OS X/Windows系统,利用它可以建立、修改文本文件。进入Vim编辑程序,可以在终端输入下面的命令: $vim [filename] 其中filename是要编辑器的文件的路径名。如果文件不存在,它将…

    Linux干货 2016-08-12

评论列表(1条)

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

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