N21-天天-第九周课程练习

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

#!/bin/bash
awk -F: '$NF~"/sbin/nologin" {shell++} $NF!~"/sbin/nologin" {noshell++} END{printf "shell: %d \t noshell: %d \n",shell,noshell}' /etc/passwd

2、写一个脚本

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

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

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

#!/bin/bash
hostname=$HOSTNAME
if [ $hostname == "localhost" ];then
sed -i 's/HOSTNAME=.*/HOSTNAME=www.magedu.com/' /etc/sysconfig/network
else
echo $HOSTNAME
fi

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

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

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

#!/bin/bash
if [ $# -lt 1 ];then
echo "input a device file!"
exit 1
fi
if [ -b $1 ];then
fdisk -l $1
else
echo "The input is not a device file!"
exit 2
fi

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

   脚本能够接受一个参数;

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

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

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

#!/bin/bash
if [ $# -lt 1 ];then
echo "Enter a argument."
exit 0
fi
case $1 in
quit)
echo "scripts is quit!"
exit 0
;;
yes)
echo "scripts is go on!"
;;
*)
echo "scripts break!"
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
day=$(date +%Y%m%d)
dir=/backups
[ -d $dir ] || mkdir $dir
if [ $# -lt 1 ];then
    echo "Enter a argument."
    exit 0
fi
case $1 in
    gzip)
        tar zcf $dir/etc-$day.tar.gz /etc
        ;;
    bzip2)
        tar jcf $dir/etc-$day.tar.bz2 /etc
        ;;
    xz)
        tar Jcf $dir/etc-$day.tar.xz /etc
        ;;
    *)
        echo "choose a wrong tools."
        exit 2
        ;;
esac

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

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

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

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

   (4) 其它为无法判断;

#!/bin/bash
if [ $# -lt 1 ];then
    echo "Enter a argument."
    exit 0
fi
if [ -f $1 ];then
    echo "It is a regular file,can be access!"
elif [ -d $1 ];then
    echo "A directory,can used by cd command!"
elif [ -L $1 ];then
    echo "A symbolic file!"
else
    echo "can not recognize!"
    exit 1
fi

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

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

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

#!/bin/bash
hostname=$HOSTNAME
if [ $hostname == "localhost" ] || [ -z $hostame ] || [ $hostname == "(none)" ];then
#if [ $hostname == "localhost" -o -z $hostame -o $hostname == "(none)" ];then
    sed -i 's/HOSTNAME=.*/HOSTNAME=www.magedu.com/' /etc/sysconfig/network
else
    echo $HOSTNAME
fi

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

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

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

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

#!/bin/bash
if [ $# -lt 1 ];then
    echo "Enter a user."
    exit 0
fi
id -u $1 &> /dev/null
if [  ! $? -eq 0 ];then
    echo "Wrong user!"
    exit 1
fi
if [ `id -u $1` -eq 0 ];then
    echo "user $1 is administrator"
elif [ `id -u  $1` -lt 500 ];then
    echo "user $1 is system user"
else
    echo "user $1 is common user"
fi

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

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

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

#!/bin/bash
if [ $# -lt 1 ];then
    echo "Enter a user."
    exit 0
fi
id -u $1 &> /dev/null
if [  ! $? -eq 0 ];then
    echo "Wrong user!"
    exit 1
fi
grep "^$1\>" /etc/passwd | grep sh$  &> /dev/null
if [ `id -u $1` -gt 500 ] && [ $? -eq 0 ];then
    echo "user $1 can login"
else
    echo "user $1 can not login"
fi

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

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

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

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

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

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

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

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

(0)
N21-天天N21-天天
上一篇 2016-09-01
下一篇 2016-09-01

相关推荐

  • SHELL脚本编程之变量的种类

    变量 在进行脚本编程的时候,经常会使用到不同类型的变量,根据变量的生效范围,可大致分为以下的几类: 本地变量:生效范围为当前shell进程,对当前shell之外的其他shell进程,包括当前shell进程的子shell进程都是无效的,它的作用域就是当前shell进程 环境变量:生效范围是当前shell进程及其子进程 局部变量:生效范围是当前shell进程中某…

    Linux干货 2016-08-12
  • 四大开源协议比较:BSD、Apache、GPL、LGPL

          现今存在的开源协议很多,而经过Open Source Initiative组织通过批准的开源协议目前有58种。我们现在常见的开源协议如BSD, GPL, LGPL,MIT等都是OSI批准的协议。如果要开源自己的代码,最好也是选择这些被批准的开源协议。   这里我们来看四种最常用的开源协议及它们的适用范围,供那些准备开…

    系统运维 2016-08-15
  • 内核参数修改 内核编译 第14天

    Linux内核:单内核,模块化 内核的某些模块 编译进内核本体 [*] 编译成内核模块 [M] 不选择使用     [ ] 内核的组成部分 /boot/vmlinuz-VERSION /lib/modules/VERSION/ *.ko 模块间有可能有依赖关系 内核模块管理 lsmod:显…

    Linux干货 2016-01-18
  • 马哥教育第一天

    来到马哥教育第一天,初步接触IT,第一次写博客,不知道写点啥,记几个地址吧。

    2018-03-26
  • Linus Torvalds 语录 Top 10

    下面是Linux的创始人Linus Torvalds的一些言论,这是我个人认为最有意思的10句。如果你想看更多的Linus Torvalds说过的话,你可以看看他在维基百科上的词条:Linux Torvalds。我们在下面给出中英文对照,希望你能喜欢。 “Really, I’m not out to dest…

    Linux干货 2015-04-03
  • Redis数据库安全手册

    Redis是一个高性能的key-value数据库,这两年可谓火的不行。而Redis的流行也带来一系列安全问题,不少攻击者都通过Redis发起攻击。本文将讲解这方面的内容,包括Redis提供的访问控制和代码安全问题,以及可以由恶意输入和其他类似的手段触发的攻击。 Redis通用安全模块 Redis被设计成只能由可信环境的可信机器访问。这意味着将它直接暴露在互联…

    2015-03-12

评论列表(1条)

  • 马哥教育
    马哥教育 2016-09-07 18:42

    脚本写得非常的漂亮,思路清晰,1题的排版需要修改一下的,脚本的缩进注意一下哈,加油!