马哥教育网络班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
下一篇 2016-08-05

相关推荐

  • docker学习记录系列(一)

    虚拟化与容器

    Linux笔记 2018-06-02
  • awk灵活运用

    awk:报告生成器,格式化文本输出        有多种版本:New awk (nawk ),GNU awk(gawk)gawk:模式扫描和处理语言基本用法:awk [options] ‘program’ var=value file…awk [options] -f progr…

    Linux干货 2017-04-08
  • Linux系统操作练习-2

    1、显示当前系统上root、fedora或user1用户的默认shell: 2、找出/etc/rc.d/init.d/functions文件中某单词后面跟一组小括号的行,形如:hello(): 3、使用echo命令输出一个绝对路径,使用grep取出基名;扩展:取出路径名: 扩展: 4、找出ifconfig命令结果中的1-255之间的数字: 5、挑战题:写一个…

    2017-11-25
  • Python函数式编程指南(四):生成器

    生成器是迭代器,同时也并不仅仅是迭代器,不过迭代器之外的用途实在是不多,所以我们可以大声地说:生成器提供了非常方便的自定义迭代器的途径。 这是函数式编程指南的最后一篇,似乎拖了一个星期才写好,嗯…… 转载请注明原作者和原文地址:) 4. 生成器(generator) 4.1. 生成器简介 首先请确信,生成器就是一种迭代器。生成器拥有next方法并且行为与迭代…

    Linux干货 2015-03-11
  • 用户、组和权限

    安全3A Authentication:认证 Authorization:授权 Accouting|Audition:审计 用户user 令牌token,identity Linux用户:username/UID 管理员:root,0(玉玺) 普通用户:1-65535 系统用户:1-499,1-999(centos7)(通关文牒) 对守护进程获取资源进行权限…

    2018-04-04
  • sed的模式匹配用法探讨

    原创作品,允许转载,转载时请务必以超链接形式标明文章 原始出处 、作者信息和本声明。否则将追究法律责任。http://nolinux.blog.51cto.com/4824967/1405753 [root@sunsky Desktop]# cat sunsky a b c d e f [root@sunsk…

    Linux干货 2016-08-15

评论列表(1条)

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

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