马哥教育网络班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 13:47
下一篇 2016-09-19 13:47

相关推荐

  • shell编程之条件判断和find查询

    使用read 来把输入值分配给一个或多个shell 变量: -p 指定要显示的提示 -t TIMEOUT read 从标准输入中读取值,给每个单词分配一个变量 所有剩余单词都被分配给最后一个变量 read -p “Enter a filename: “ FILE   条件选择if语句  多分支 if  CONDITION1 ; …

    Linux干货 2016-08-18
  • YUM LNMP 安装 wordpress

    1配置防火墙 Iptables -A INPUT -m state –state NEW -m tcp -p tcp –dport 80 -j ACCEPT #允许80端口通过防火墙 iptables-A&…

    Linux干货 2016-06-22
  • Codis集群3.03安装配置基础

    Codis基础 01.codis是一个分布式的Redis解决方案,对于上层的应用来说,连接Codis Proxy和连接原生的Redis Server没有明显的区别。 codis底层会处理请求的转发,不停机的数据迁移等工作,所有后边的一切事情,对于前面客户端来说是透明的,可以简单的认为后边连接是一个内存无限大的Redis服务。 codis架构图如下: 02.c…

    Linux干货 2016-09-26
  • MySQL慢日志监控脚本实例剖析

    原创作品,允许转载,转载时请务必以超链接形式标明文章 原始出处 、作者信息和本声明。否则将追究法律责任。http://nolinux.blog.51cto.com/4824967/1577326        公司线上的 MySQL 慢日志,之前一直没有做好监控。趁着上周空闲,我就把监控脚本写了下,…

    Linux干货 2016-08-15
  • 简述动静分离

        今天来简述一下如何实现wordpress的动静分离以及读写分离      首先来放出大图。   1.来看图说话     首先来介绍一下这张图    最前端的两台机器是  负责调度后端主机请求动…

    2017-05-18
  • Bash的基础特性(二)

    Bash的基础特性(二) glob文件通配符 (* ; ? ; [ ] ; [^ ] ) 星号* 匹配任意所有字符的 [root@lyp ~]# ls h* hello.sh hello.shbak ?匹配单个字符 ls ???? 查看四个字符命名的文件 [0-9]匹配数字 [a-z] 字母 字母的顺序安装 a A b B c C… z Z 匹配的a-z […

    Linux干货 2017-04-01

评论列表(1条)

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

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