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

相关推荐

  • Mysql备份II

    Mysql备份II V.II.I单台或共用机器,数据量和访问量小50G< 1 Mysqldump(全导出,导库,导表) 锁表 如果这时有些入会锁住或者超时 2 至少停止写入 防止innodb配置还没刷到磁盘里 先flash tables /usr/local/mysql/bin/mysqladmin -S /tmp/mysql.so…

    Linux干货 2016-06-09
  • 链接分析算法之:主题敏感PageRank

      前面的讨论提到。PageRank忽略了主题相关性,导致结果的相关性和主题性降低,对于不同的用户,甚至有很大的差别。例如,当搜索“苹果”时,一个数码爱好者可能是想要看 iphone 的信息,一个果农可能是想看苹果的价格走势和种植技巧,而一个小朋友可能在找苹果的简笔画。理想情况下,应该为每个用户维护一套专用向量,但面对海量用户这种方法显然不可行。所…

    Linux干货 2016-02-17
  • N21天天第十一周课程练习

    1、详细描述一次加密通讯的过程,结合图示最佳。 SSL协议基础: SSL协议位于TCP/IP协议与各种应用层协议之间,本身又分为两层: 1)SSL记录协议:建立在可靠传输层协议(TCP)之上,为上层协议提供数据封装、压缩、加密等基本功能。 2)SSL握手协议:在SSL记录协议之上,用于实际数据传输前,通讯双方进行身份认证、协商加密算法、交换加密密钥等。 SS…

    Linux干货 2016-10-09
  • awk用法一

      gawk程序是Unix中的原始awk程序的GNU版本,它提供了一种编程语言而不只是编辑器命令。在CentOS中awk命令实际上是gawk程序的链接文件名。   基本语法:     awk [options] ‘program’ flie1 file2 ……

    Linux干货 2015-12-24
  • N26 – 第一周作业

    一、计算机组成及其功能     如图,计算机由硬件和软件组成。其中硬件可划分为控制器、运算器、存储器,以及输入和输出设备;软件则分为直接与硬件通信的系统软件,以及运行在其上的各类应用软件。      二、Linux发行版的不同系列     …

    Linux干货 2016-12-28
  • Linux用户与组管理详解

    在linux系统上,用户管理是基于用户名和密码的方式进行资源的分配,了解和掌握用户与组的管理是从事运维工作所必须具备的能力,也是将来从事运维行业的重要工作之一。

    2018-04-03

评论列表(1条)

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

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