马哥教育网络班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

相关推荐

  • 管道、重定向和用户管理练习

    前面一章学习了硬链接和软链接,回顾上一章节内容:    硬链接:在inode表中记录一个条目,所有的元数据和原始文件元数据相同。        ·相当于两个名字。        ·删除原始文件,另一个条目也能够…

    Linux干货 2016-08-04
  • 马哥Linux学习之查询篇(命令查询和文件查询)

        Linux运维工作一般都使用命令完成,在如此多的各种命令中,要想全部记住显然是不太可能也是不必要的,另外,文件的查找在日常操作中也是必不可少的。下面我就总结一下Linux中如何查找命令以及文件。     命令的运行文件路径查询。这个查找的方法是同样是使用命令,这个命令叫w…

    Linux干货 2015-04-13
  • vim文本编辑器之快捷键满天飞

    vim文本编辑器不同于nano的是其功能非常强大,强大的功能还支持各种快捷键,让我们编辑文本的时候更方便更快捷。 本文将会按照下图所展示的功能来对命令一一讲解,           打开文件:       &n…

    Linux干货 2016-08-11
  • five

    1;显示当前系统上root, fedora或user1用户的默认shell。 #   grep "^\(root\|fedora\|user1\)" /etc/passwd #   grep -E "^(root|fedora|u…

    Linux干货 2017-01-16
  • heartbeat实现高可用集群(1)

    环境 node1 192.168.1.35 node2 192.168.1.36 fip 192.168.1.80 daemon httpd nfs 192.168.1.15 配置HA集群的前提 1.节点时间必须同步,使用ntp协议实现 2.节点间需要通过主机互相通信,必须解析主机名至IP地址 a.建议名称解析功能能使用hosts文件实现 b.通信中使用的名…

    Linux干货 2017-11-03
  • shell脚本之变量类型、算数运算符、条件测试

    一、bash中的变量类型     本地变量:仅对当前shell有效,对其子shell无效             变量赋值:name=value      &n…

    Linux干货 2016-08-15

评论列表(1条)

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

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