马哥教育网络班20期-第九周课程作业

Table of Contents

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

#!/bin/bash
#
for shell in `cut -d':' -f7 /etc/passwd`; do
    if [ $shell == "/sbin/nologin" ]; then
        let "NOLOGIN++"
    else
        let "LOGIN++"
    fi
done

echo "可登录用户数: $LOGIN"
echo "不可登录用户数: $NOLOGIN"

2、写一个脚本

  1. 获取当前主机的主机名,保存于hostname变量中;

  2. 判断此变量的值是否为localhost,如果是,则将当前主机名修改为www.magedu.com;

  3. 否则,则显示当前主机名;

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

3、写一个脚本,完成如下功能

  1. 传递一个磁盘设备文件路径给脚本,判断此设备是否存在;

  2. 如果存在,则显示此设备上的所有分区信息;

#!/bin/bash
#
ARG_WRONG=87

if [ $# -ne 1 ]; then
    echo "usage: $0 dev_name"
    exit $ARG_WRONG
fi

if [ -b $1 ]; then
    fdisk -l $1
else
    echo "$1不存在或格式错误"
fi

4、写一个脚本,完成如下功能

脚本能够接受一个参数;

  1. 如果参数1为quit,则显示退出脚本,并执行正常退出;

  2. 如果参数1为yes,则显示继续执行脚本;

  3. 否则,参数1为其它任意值,均执行非正常退出;

#!/bin/bash
#
ARG_WRONG=87
if [ $# -ne 1 ]; then
    echo "usage: $0 {yes|quit}"
    exit $ARG_WRONG
fi

case $1 in
    'quit')
        echo "退出脚本"
        exit 0
        ;;
    'yes')
        echo "继续执行脚本"
        ;;
    *)
        exit 1
        ;;
esac

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
#
ARG_WRONG=87
if [ $# -ne 1 ]; then
    echo "usage: $0 {gzip|bzip2|xz}"
    exit $ARG_WRONG
fi

case $1 in
    gzip)
        tar -czf /backups/etc-`date %Y%m%d`.tar.gz /etc
        ;;
    bzip2)
        tar -cjf /backups/etc-`date %Y%m%d`.tar.gz /etc
        ;;
    xz)
        tar -cJf /backups/etc-`date %Y%m%d`.tar.gz /etc
        ;;
    *)
        echo "错误压缩工具"
        exit 1
        ;;
esac

6、写一个脚本,接受一个路径参数:

  1. 如果为普通文件,则说明其可被正常访问;

  2. 如果是目录文件,则说明可对其使用cd命令;

  3. 如果为符号链接文件,则说明是个访问路径;

  4. 其它为无法判断;

#!/bin/bash
#
ARG_WRONG=87
if [ $# -ne 1 ]; then
    echo "usage: $0 FILENAME"
    exit $ARG_WRONG
fi

if [ -f $1 ]; then
    echo '其可被正常访问'
    exit 0
fi

if [ -d $1 ]; then
    echo '可对其使用cd命令'
    exit 0
fi

if [ -L $1 ]; then
    echo '是个访问路径'
    exit 0
fi

echo '无法判断'
exit 1

7、写一个脚本,取得当前主机的主机名,判断

  1. 如果主机名为空或为localhost,或为""(none)"",则将其命名为mail.magedu.com;

  2. 否则,显示现有的主机名即可;

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

8、写一脚本,接受一个用户名为参数;

  1. 如果用户的id号为0,则显示其为管理员;

  2. 如果用户的id号大于0且小于500, 则显示其为系统用户;

  3. 否则,则显示其为普通用户;

#!/bin/bash
#
ARG_WRONG=87
if [ $# -ne 1 ]; then
    echo "usage: $0 USERNAME"
    exit $ARG_WRONG
fi

if id $1; then
    if [ `id -u $1` -eq 0 ]; then
        echo "该用户是管理员"
    elif [ `id -u $1` -lt 500 ]; then
        echo "该用户是系统用户"
    else
        echo "该用户是普通用户"
    fi
else
    echo "不存在该用户"
    exit 1
fi

10、写一个脚本,传递一个用户名参数给脚本;

  1. 如果用户的id号大于等于500,且其默认shell为以sh结尾的字符串,则显示“a user can log system.”类的字符串;

  2. 否则,则显示无法登录系统;

#!/bin/bash
#
ARG_WRONG=87
if [ $# -ne 1 ]; then
    echo "usage: $0 USERNAME"
    exit $ARG_WRONG
fi

if id $1; then
    if [ `id -u $1` -ge 500 -a grep -q "^\<$1\>.*sh$" /etc/passwd ]; then
        echo "a user can log system."
        exit 0
    fi
fi

echo "无法登录系统"
exit 1

11、写一个脚本,完成如下任务 :

  1. 按顺序分别复制/var/log目录下的每个直接文件或子目录至/tmp/test1-testn目录中;

  2. 复制目录时,才使用cp -r命令;

  3. 复制文件时使用cp命令;

  4. 复制链接文件时使用cp -d命令;

  5. 余下的所有类型,使用cp -a命令;

#!/bin/bash
#
DESTINATION=/tmp/test1-testn
for file in `ls /var/log`; do
    if [ -d $file ]; then
        cp -r $file $DESTINATION
    elif [ -f $file ]; then
        cp $file $DESTINATION
    elif [ -L $file ]; then
        cp -d $file $DESTINATION
    else
        cp -a $file $DESTINATION
    fi
fi

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

(0)
Net20_木皮Net20_木皮
上一篇 2016-08-05 16:16
下一篇 2016-08-05 16:16

相关推荐

  • CentOS7下的网络配置管理

    一、让配置永久有效的办法:修改配置文件 与网卡相关(课配置网卡的IP,掩码,网关,DNS)     /etc/sysconfig/network-scripts/ifcfg-INTERFACE 字段解释: TYPE        &nbsp…

    Linux干货 2016-03-28
  • 常见RAID总结

    RAID浅析 目录索引 一、定义 二、特点 三、常用RAID级别      四、RAID实现方式 五、实际环境测试 一、定义: 磁盘阵列(Redundant Arrays of Independent Disks,RAID),有“独立磁盘构成的具有冗余能力的阵列”之意。 独立磁盘冗余阵列(RAID,redundant array…

    Linux干货 2016-04-12
  • ansible基础应用

    ansible基础 一、运维主要工作 ansible聚集以上功能于一身,能够完整轻易的实现应用部署和批量命令功能,适用于主机数量不太多,再大的用puppet。 二、ansible特性 (1)模块化:调用特定的模块,完成特定任务; (2)基于python语言实现,由paramiko,PYYAML和JINJa2三个关键模块组成 (3)部署简单:agentless…

    Linux干货 2017-01-04
  • sed使用方法

      sed编辑器被称作流编辑器(stream editor)。流编辑器在处理数据之前基于预先提供的一组规则来编辑数据流。 一、命令格式   sed options '"地址""编辑命令"' file   常用选项:     -n:静默模式,不显示模式…

    Linux干货 2015-12-28
  • Bash 三种排序算法的简单实现

    Bash 三种排序算法的简单实现

    2017-07-09
  • raid5 阵列

    1 fdisk 分区sdb2,sdd1,sde1, 2  新建raid5 [root@localhost ~]# mdadm -C /dev/md5 -a yes  -l 5  -n 3 -x 1 /dev/sdd1 /dev/sde1  /dev/sdf  /dev/sdb2  3   …

    Linux干货 2017-04-25

评论列表(1条)

  • 马哥教育
    马哥教育 2016-08-05 17:05

    写的很好,排版也很棒,加油