第九周

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

#!/bin/bash
for i in `cut -d':' -f7 /etc/passwd`;do
    if [ $i == "/sbin/nologin" ];then
        let x++
    else
        let y++
    fi
done
echo "nologin user number: $x"
echo "login user number: $y"

2、写一个脚本

(1) 获取当前主机的主机名,保存于hostname变量中;
(2) 判断此变量的值是否为localhost,如果是,则将当前主机名修改为www.magedu.com;
(3) 否则,则显示当前主机名;
#!/bin/bash
hostname=`hostname -s`
if [ $hostname == "localhost" ];then
    hostname www.magedu.com
else
    echo `hostname`
fi

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

(1) 传递一个磁盘设备文件路径给脚本,判断此设备是否存在;
(2) 如果存在,则显示此设备上的所有分区信息;
#!/bin/bash
if [ $# -le 0 ];then
    echo "must have one argument"
    exit 1
elif [ -b $1 ];then
    fdisk -l $1
else
    echo "argument is not block file"
fi

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

脚本能够接受一个参数;
(1) 如果参数1为quit,则显示退出脚本,并执行正常退出;
(2) 如果参数1为yes,则显示继续执行脚本;
(3) 否则,参数1为其它任意值,均执行非正常退出;
if [ $# -le 0 ];then
    echo "must have one argument"
    exit 1
elif [ $1 = "quit" ];then
    echo "quit script"
    exit 0
elif [ $1 = "yes" ];then
    echo "continue"
else
    echo "error"
    exit 1
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
if [ $# -le 0 ];then
    echo "must have one argument"
    exit
fi
case $1 in
    gzip) 
        tar -zcf /backups/etc-20160613.tar.gz /etc
        ;;

    bzip2)
        tar -jcf /backups/etc-20160613.tar.bz2 /etc
        ;;

    xz)
        tar -Jcf /backups/etc-20160613.tar.xz /etc
        ;;
    *)
        echo "error compression tools"
        ;;
esac

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

(1) 如果为普通文件,则说明其可被正常访问;
(2) 如果是目录文件,则说明可对其使用cd命令;
(3) 如果为符号链接文件,则说明是个访问路径;
(4) 其它为无法判断;
#!/bin/bash
if [ $# -le 0 ];then
    echo "must have one argument"
    exit
fi
if [ -f $1 ];then
    echo "text file"
elif [ -d $1 ];then
    echo "to use the CD command"
elif [ -L $1 ];then
    echo "It is a access path"
else
    echo "not determinable"
fi

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

(1) 如果主机名为空或为localhost,或为""(none)"",则将其命名为mail.magedu.com;
(2) 否则,显示现有的主机名即可;
#!/bin/bash
hostname=`hostname -s`
if [ -z "$hostname" -o "$hostname" = "(none)" -o "$hostname"==*localhost ];then
    hostname www.magedu.com
else
    echo `hostname`
fi

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

(1) 如果用户的id号为0,则显示其为管理员;
(2) 如果用户的id号大于0且小于500, 则显示其为系统用户;
(3) 否则,则显示其为普通用户;
#!/bin/bash
if [ $# -le 0 ];then
    echo "must have one argument"
    exit
fi

id $1 &> /dev/null
if [ $? -eq 0 ];then
    if [ `id -u $1` -eq 0 ];then
        echo "user is a administrator" 
    elif [ `id -u $1` -gt 0 -a `id -u $1` -lt 500 ];then
        echo "user is a system consumer" 
    else
        echo "user is a domestic consumer"
    fi
fi

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

(1) 如果用户的id号大于等于500,且其默认shell为以sh结尾的字符串,则显示“a user can log system.”类的字符串;
(2) 否则,则显示无法登录系统;
#!/bin/bash
if [ $# -le 0 ];then
    echo "must have one argument"
    exit
fi

id $1 &> /dev/null
if [ $? -eq 0 ];then
    userid=`grep ^$1 /etc/passwd | grep .*sh$ | cut -d: -f3`
    if [ $userid -ge 500 ];then
        echo "user can loggin system" 
    else
        echo "user can not loggin system"
    fi
fi

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

(1) 按顺序分别复制/var/log目录下的每个直接文件或子目录至/tmp/test1-testn目录中;
(2) 复制目录时,才使用cp -r命令;
(3) 复制文件时使用cp命令;
(4) 复制链接文件时使用cp -d命令;
(5) 余下的所有类型,使用cp -a命令;
#!/bin/bash
[ -d /tmp/test1-testn ] || mkdir -p /tmp/test1-testn
for file in `ls /var/log`;do
    if [ -d $file ];then
        cp -r /var/log/$file /tmp/test1-testn
    elif [ -f $file ];then
        cp  /var/log/$file /tmp/test1-testn
    elif [ -L $file ];then
        cp -d /var/log/$file /tmp/test1-testn
    else
        cp -a /var/log/$file /tmp/test1-testn
    fi
done

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

(0)
N21_smileN21_smile
上一篇 2016-09-26
下一篇 2016-09-26

相关推荐

  • linux 系统日志管理

         在linux系统上面,系统可以记录从开机到当前系统上面何时发生了那些事情,并将其分类,分级别写到特定的日志文件当中,如系统自身产生的问题,用户登录信息,网络数据信息等等。我们可以根据这些日志信息来解决系统方面的错误,网络服务问题等等。日志对于安全来说,非常重要,它记录了系统每天发生的各种各样的事情,你可以通过它来检查错…

    2017-08-14
  • N26 第一周博客作业

    1、描述计算机的组成及其功能。 现代的计算机大多遵循的是 冯·诺依曼 计算机体系,主要有如下几个组成部分: 运算器      :也被称为算术逻辑单元(ALU),可视为计算机的大脑,它主要进行算术运算和逻辑运算; 逻辑控制器  :则负责将计算机的其他部件联系起来,其功能是从存储设备和输入输出设备中读取指令和数据,对指令进…

    Linux干货 2017-01-08
  • Mariadb基于ssl的主从复制

    Mariadb基于ssl的主从复制 一、前言 备份数据库是生产环境中的首要任务,重中之重。一般配置中mariadb的主从传输是明文传输,但是有时候对一些特殊业务来说是不允许的,为了保证数据在传输过程中的安全性,因此使用基于SSL的复制会大大加强数据的安全性。 二、准备工作 1、实验系统环境: CentOS7.2,SELinux关闭,iptables关闭,安装…

    Linux干货 2017-02-24
  • FHS文件系统各目录功能

    FHS       Filesystem Hierarchy Standard(文件系统目录标准)的缩写,多数Linux版本采用这种文件组织形式,类似于Windows操作系统中c盘的文件目录,FHS采用树形结构组织文件。FHS定义了系统中每个区域的用途、所需要的最小构成的文件和目录,同时还给出了例外处理与矛盾处理。下为…

    Linux干货 2016-10-16
  • Python之入门篇

    一、环境准备 环境准备 –> pyenv (安装python解释器,管理Python版本,管理python虚拟环境) https://github.com/pyenv/pyenv https://github.com/yyuu/pyenv-installer # yum -y install git # curl -L https://ra…

    Linux干货 2015-02-07
  • Linux常用命令

    马哥教育网络班22期第四周课程练习 linux常用命令介绍(2) linux权限及命令组合使用示例 1、复制/etc/skel目录为/home/tuser1,要求/home/tuser1及其内部文件的属组和其它用户均没有任何访问权限。 ~]# cp -r /etc/skel /home/tuser1 &amp…

    Linux干货 2016-09-19

评论列表(2条)

  • 马哥教育
    马哥教育 2016-09-27 09:25

    第2 7写的不对,自己测试一下看看主机名可以改过来吗?

    • N21_smile
      N21_smile 2016-09-27 10:19

      @马哥教育老师,我又都测了一遍,可以改的呀