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

相关推荐

  • yum仓库配置

    yum仓库搭建 yum客户端在安装之前要在服务器下载相关的源数据缓存在 cachedir=/var/cache/yum/$basearch/$releasever中 gpgcheck=1检查数据包的签名完整性 导入钥匙或gpgcheck=0就不检查否侧安装不了yum 在/etc/yum.conf设置配置文件 在/etc/yum.repos.d中创建一个后缀是…

    2017-12-03
  • 方便实用的文件查找与压缩

    在平时的运维工作当中通常会编辑某些文件,但时间久了,突然一下子记不起文件的名字,遇到的事情又很紧急,需要立马去处理,而自己只知道那个文件部分的特征信息,我们需要在系统中去搜索自己想要的文件,那么有没有办法去实现呢,当然有,在我们的系统中,文件查找的工具有两个,locate和find。那么下面来介绍这两个工具的用法以及两个工具之间的差别。 在我们linux系统…

    Linux干货 2016-08-13
  • 批量创建用户(8月1日作业)

    1、创建用户gentoo,附加组为bin和root,默认shell为/bin/csh,注释信息为"Gentoo Distribution" 2、创建下面的用户、组和组成员关系 名字为admins的组;  用户natasha,使用admins作为附属组;  用户harry,也使用admins作为附属组 &nbs…

    Linux干货 2016-08-04
  • 20160802作业

    20160802作业 1、每日课堂笔记总结 2、预习 3、每日课堂pdf练习 4、在/data/testdir里创建的新文件自动属于g1组,组g2的成员如: alice能对这些新文件有读写权限,组g3的成员如:tom只能对新文件有读权限,其它用户(不属于g1,g2,g3)不能访问这个文件夹。 [root@Centos7 ~]# chmod…

    Linux干货 2016-08-04
  • Linux系统中的Inode节点表

    索引节点是指在许多类Unix文件系统中的一种数据结构。每个索引节点保存了文件系统中的一个文件系统对象的元信息数据,但不包括数据内容或者文件名。

    2017-11-16
  • shell脚本之until循环

    一、用until实现下列脚本 1、每隔3秒钟到系统上获取已经登录的用户的信息;如果发现用户hacker登录,则将登录时间和主机记录于日志/var/log/login.log中,并提示该用户退出系统。 #!/bin/bash #author:jackCui #description:Find out if the sys…

    Linux干货 2016-08-18

评论列表(1条)

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

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