第九周作业

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

#!/bin/bash
LOGIN_USER=0
NOLOGIN_USER=0
for SHELLUSER in $(cat /etc/passwd | cut -d : -f 7);do
    if [ $SHELLUSER == "/sbin/nologin" ];then
            let NOLOGIN_USER++
    else
            let LOGIN_USER++
    fi
done
echo "login shell = $LOGIN_USER , nologin shell =$NOLOGIN_USER"
~                         

2、写一个脚本
    (1) 获取当前主机的主机名,保存于hostname变量中;
    (2) 判断此变量的值是否为localhost,如果是,则将当前主机名修改为www.magedu.com;
    (3) 否则,则显示当前主机名;

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

3、写一个脚本,完成如下功能
    (1) 传递一个磁盘设备文件路径给脚本,判断此设备是否存在;
    (2) 如果存在,则显示此设备上的所有分区信息;

#!/bin/bash
if [[ "$1" =~ /dev/[hs]d* ]];then
    if ls /dev/[hs]d* | grep "$1" &> /dev/null ; then
        fdisk -l $1
    else
        echo "no this partitions"
        exit 2
    fi
else
        echo "wrong path"
fi

4、写一个脚本,完成如下功能
   脚本能够接受一个参数;
   (1) 如果参数1为quit,则显示退出脚本,并执行正常退出;
   (2) 如果参数1为yes,则显示继续执行脚本;
   (3) 否则,参数1为其它任意值,均执行非正常退出;

#!/bin/bash
read -p "Please give a parameter(yes or quit)" -t 5 NAME
if [ -z $NAME ];then
        echo "need a parameter"
        exit 2
elif [ $NAME == yes ]; then
        echo "continue scripting"
elif [ $NAME == quit ]; then
        echo "Normal exit"
        exit 0
else
        echo "wrong paramter"
        exit 2
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
NAME=/backups/etc-20160613.tar
read -p "chose a compression tool(gzip/bzip2/xz)" -t 5 TOOL
cd /
mkdir backups &> /dev/null
if [ $TOOL == gzip ];then
        tar -zcf $NAME.gz etc
elif [ $TOOL == bzip2 ];then
        tar -jcf $NAME.bz2 etc
elif [ $TOOL == xz ];then
        tar -Jcf $NAME.xz etc
else
        echo "wrong compression tool"
fi

6、写一个脚本,接受一个路径参数:
   (1) 如果为普通文件,则说明其可被正常访问;
   (2) 如果是目录文件,则说明可对其使用cd命令;
   (3) 如果为符号链接文件,则说明是个访问路径;
   (4) 其它为无法判断;

#!/bin/bash
read -p "please give a path to (file|dir|ln)"  NAME
if [[ -f $NAME ]];then
        echo "this is a file,you can access"
elif [[ -d $NAME ]];then
        echo "this is a Directory file,you can cd"
elif [[ -L $NAME ]];then
        echo "this is a path to file"
else
        echo "cannot judge"
fi  

7、写一个脚本,取得当前主机的主机名,判断
   (1) 如果主机名为空或为localhost,或为”(none)”,则将其命名为mail.magedu.com;
   (2) 否则,显示现有的主机名即可;

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

原创文章,作者:M36-Masuri,如若转载,请注明出处:http://www.178linux.com/79373

(0)
M36-MasuriM36-Masuri
上一篇 2017-07-03 21:13
下一篇 2017-07-03 21:17

相关推荐

  • Find命令的使用

    Find命令的基本用法 在Linux系统中find命令是一个强大文件查找类工具,它支持根据文件名,权限,文件大小,访问以及修改时间查找,使用方法如下: find [option] [查找起始路径] [查找条件] [处理动作] 起始路径:指定查找文件或目录的路径,默认为当前目录 查找条件:可根据文件名,权限,文件大小以及从属关系查找文件 处理动作:动查找到的文…

    Linux干货 2017-08-28
  • 访问控制列表ACL使用说明

    一、什么是ACL ACL(Access Control List)可灵活地,更细粒度地定义访问文件或目录的权限。 二、为什么使用ACL Linux上文件系统的文件系统权限管理的对象分为三类:owner,group,other。这种分类非常简单,如果我希望有一个用户拥有不同于这三类对象的权限,或者再定义一个用户组的权限,传统的权限管理就不能实现,而ACL可以很…

    Linux干货 2016-08-08
  • 重定向和管道

     重定向    程序:指令+数据    读入数据:Input    输出数据:Output  linux给程序提供三种I/O设备    标准输入(stdin)-0 默认接受来自键盘的输入    标准输出(stdinout)-1默认输出到终端…

    Linux干货 2016-08-10
  • Liunx获取信息帮助与man文档章节的划分

    首先要判断命令的类型,可用 type COMMAND 来判断命令 如果显示结果为(….是 shell内嵌)即为shell内嵌命令,如需获取帮助,使用 help COMMAND 即可; 下图的例子是pwd是shell内嵌命令 内部命令属于Shell的一部分,所以并没有单独对应的系统文件,只要Shell解释器被运行,内部指…

    2017-07-02
  • IT基础设施工具—Puppet

    一、Puppet简介 Puppet是一款使用GPLV2X协议授权的开源管理配置工具,基于ruby语言开发的自动化系统配置工具,可以C/S模式或独立运行,支持对所有UNIX及类UNIX系统的配置管理,既可以通过客户端—服务器的方式运行,也可以独立运行。Puppet适用于服务器管的整个过程 ,比如初始安装、配置更新以及系统下线。puppet可以为系统管理员提供方…

    Linux干货 2017-11-26
  • Linux之iptables原理详解

    目录: 一、netfilter与iptables 二、filter、nat、mangle等规则表 三、INPUT、FORWARD等规则链和规则 四、Linux数据包路由原理 五、iptables编写规则  一、netfilter与iptables (1)Netfilter是由Rusty Russell提出的Linux 2.4内核防火墙框架,该框架既…

    2017-08-04

评论列表(1条)

  • 马哥教育
    马哥教育 2017-07-13 17:22

    不错,非常认真,脚本可以贴上运行的结果,加油!!!