N21_第09周_shell脚本

作业题目:

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

预置条件:
[root@zhouyong148 N21_09]# cat /etc/passwd
root:x:0:0:root:/root:/bin/bash
bin:x:1:1:bin:/bin:/sbin/nologin
daemon:x:2:2:daemon:/sbin:/sbin/nologin
adm:x:3:4:adm:/var/adm:/sbin/nologin
lp:x:4:7:lp:/var/spool/lpd:/sbin/nologin
sync:x:5:0:sync:/sbin:/bin/sync
shutdown:x:6:0:shutdown:/sbin:/sbin/shutdown
halt:x:7:0:halt:/sbin:/sbin/halt
mail:x:8:12:mail:/var/spool/mail:/sbin/nologin
uucp:x:10:14:uucp:/var/spool/uucp:/sbin/nologin
operator:x:11:0:operator:/root:/sbin/nologin
games:x:12:100:games:/usr/games:/sbin/nologin
gopher:x:13:30:gopher:/var/gopher:/sbin/nologin
ftp:x:14:50:FTP User:/var/ftp:/sbin/nologin
nobody:x:99:99:Nobody:/:/sbin/nologin
dbus:x:81:81:System message bus:/:/sbin/nologin
vcsa:x:69:69:virtual console memory owner:/dev:/sbin/nologin
saslauth:x:499:76:"Saslauthd user":/var/empty/saslauth:/sbin/nologin
postfix:x:89:89::/var/spool/postfix:/sbin/nologin
sshd:x:74:74:Privilege-separated SSH:/var/empty/sshd:/sbin/nologin
mongodb:x:500:500::/home/mongodb:/bin/bash
shell脚本:
[root@zhouyong148 N21_09]# cat N21_09_01.sh 
#!/bin/bash
declare -i loginable=0
declare -i unloginable=0
  for i in $(cut -d':' -f7 /etc/passwd); do
        if [ $i == /sbin/nologin  ]; then
                let unloginable++
        else
                let loginable++
        fi
  done
echo "用户的shell可以登录的有:$loginable个"
echo "不可以登录的用户shell有:$unloginable个"
执行并查看结果:
[root@zhouyong148 N21_09]# sh N21_09_01.sh 
用户的shell可以登录的有:5个
不可以登录的用户shell有:16个

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

预置条件:
[root@zhouyong148 N21_09]# hostname
zhouyong148
shell脚本:
[root@zhouyong148 N21_09]# vi N21_09_02.sh 
#!/bin/bash
hostname=$(hostname)
if [[ "$hostname" == localhost ]];then
        hostname www.magedu.com
        echo "hostname is: 'www.magedu.com'"
else
        echo "hostname is: $hostname"
fi
运行及查看结果:
[root@zhouyong148 N21_09]# sh N21_09_02.sh 
hostname is: zhouyong148

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

[root@zhouyong148 N21_09]# vi N21_09_03.sh 
#!/bin/bash
if [ $# -le 0 ];then
        echo "参数的个数不能为0,请带入参数,例 N21_09_03.sh /dev/DEVICE_NAME"
        exit 1
else
        dev=$1
        if [ -e $dev ];then
                echo "设备信息存在"
                fdisk -l $dev
        else
                echo "This device don't exist"
        fi
fi

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

[root@zhouyong148 N21_09]# vi N21_09_04.sh 
#!/bin/bash
if [ $# -le 0 ];then
        echo "参数个数为空,请输入参数quit|yes"
        exit 1
else
        case $1 in
        quit)
          echo "quiting..."
          exit 0;;
        yes)
          echo "countine...";;
        *)
          echo "error..."
          exit 1;;
        esac
fi
[root@zhouyong148 N21_09]# sh N21_09_04.sh 
参数个数为空,请输入参数quit|yes
[root@zhouyong148 N21_09]# sh N21_09_04.sh yes
countine...
[root@zhouyong148 N21_09]# sh N21_09_04.sh error
error...

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) 其它任意值,则显示错误压缩工具,并执行非正常退出;

[root@zhouyong148 N21_09]# vi N21_09_05.sh
#!/bin/bash
if [ $# -le 0 ]; then
        echo "参数个数不能为空,请输入参数gzip|bzip2|xz|..."
        exit 1
else
        case $1 in
        gzip)
                tar czvf /backups/etc-20160613.tar.gz /etc;;
        bzip2)
                tar cjvf /backups/etc-20160613.tar.bz2 /etc;;
        xz)
                tar cJvf /backups/etc-20160613.tar.xz /etc;;
        *)
        echo "error..."
        exit 1;;
        easc
fi

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

[root@zhouyong148 N21_09]# vi N21_09_06.sh
#!/bin/bash
if [ $# -le 0 ];then
        echo "参数个数不能为空,例N21_09_06.sh /filePath/fileName"
        exit 1
fi
if [ -f $1 ];then
        echo "This file can be access."
elif [ -d $1 ];then
        echo "command 'cd' can be use."
elif [ -L $1 ];then
        echo "this is accessable file."
else
        echo "filetype unkonw."
fi
[root@zhouyong148 N21_09]# sh N21_09_06.sh /home/logCreate.sh 
This file can be access.

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

[root@zhouyong148 N21_09]# vi N21_09_07.sh
#!/bin/bash
hostname=$(hostname)
if [ -z "$HOSTNAME" -o "$HOSTNAME" = "(none)" -o "$HOSTNAME" == localhost ];then
        hostname mail.magedu.com
        echo "hostname is: 'mail.magedu.com'"
else
        echo "hostname is: $hostname"
fi
[root@zhouyong148 N21_09]# sh N21_09_07.sh 
hostname is: zhouyong148

8、写一脚本,接受一个用户名为参数;
   (1) 如果用户的id号为0,则显示其为管理员;
   (2) 如果用户的id号大于0且小于500, 则显示其为系统用户;
   (3) 否则,则显示其为普通用户;

[root@zhouyong148 N21_09]# vi N21_09_09.sh 
#!/bin/bash
#
if [ $# -le 0 ];then
    echo "Usage:bash N21_09_09.sh username"
    exit 1
fi
if id $1 &> /dev/null;then
    userid=`grep ^$1 /etc/passwd | cut -d: -f3`
    if [ $userid -eq 0 ];then
        echo "$1 is Administrator."
    elif
       [ $userid -gt 0 -a $userid -lt 500 ];then
        echo "$1 is System User."
    else
        echo "$1 is Common User."
    fi
fi
[root@zhouyong148 N21_09]# sh N21_09_09.sh root
root is Administrator.
[root@zhouyong148 N21_09]# sh N21_09_09.sh mongodb
mongodb is Common User.

10、写一个脚本,传递一个用户名参数给脚本;
   (1) 如果用户的id号大于等于500,且其默认shell为以sh结尾的字符串,则显示“a user can log system.”类的字符串;
   (2) 否则,则显示无法登录系统;

#!/bin/bash
#
if [ $# -lt 1 ];then
    echo "Usage:bash 9.10.sh username"
    exit 1
fi
if id $1 &> /dev/null;then
    userid=`grep ^$1 /etc/passwd | grep sh$ | cut -d: -f3`
    if [ $userid -gt 0 -a $userid -eq 500 ];then
        echo "a user can log system."
    else
        echo "a user can not log system."
    fi
fi
[root@zhouyong148 N21_09]# sh N21_09_10.sh 
Usage:bash 9.10.sh username
[root@zhouyong148 N21_09]# sh N21_09_10.sh root
a user can not log system.
[root@zhouyong148 N21_09]# sh N21_09_10.sh mongodb
a user can log system.

11、写一个脚本,完成如下任务 :
   (1) 按顺序分别复制/var/log目录下的每个直接文件或子目录至/tmp/test1-testn目录中;
   (2) 复制目录时,才使用cp -r命令;
   (3) 复制文件时使用cp命令;
   (4) 复制链接文件时使用cp -d命令;
   (5) 余下的所有类型,使用cp -a命令;

[root@zhouyong148 N21_09]# vi N21_09_11.sh 
#!/bin/bash
if ! [ -d /tmp/test1-testn ];then
    mkdir -p /tmp/test1-testn
fi
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
[root@zhouyong148 N21_09]# sh N21_09_11.sh

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

(0)
365365
上一篇 2016-11-14
下一篇 2016-11-14

相关推荐

  • 正则表达式与例题

    正则表达式与例题  一BRE 和ERE 由一类特殊字符及文本字符所编写的模式,其中有些字符(元字符)不表示字符字面意义,而表示控制或通配的功能 程序支持:grep ;sed ;  awk ; vim ; less ; nginx ; varnish 元字符分类:字符匹配  匹配次数  位置锚定  分组 二.基…

    Linux干货 2017-07-29
  • drbd+corosync+pacemaker

    存储分类: DAS:直接附加存储;例如ide,sata,scsi,sas等 NAS:网络附加存储;即文件级别共享存储;例如nfs等 SAN:存储区域网络;即块级别共享存储;例如ip-san,fc-san   共享存储选型比较: SAN性能优良,价格昂贵; NAS性能基于文件系统级别,性能低下; 因此,另一个DRBD诞生,全称为分布式复制块设备,Di…

    Linux干货 2017-11-13
  • 第七周博客作业

    1、创建一个10G分区,并格式为ext4文件系统; (1) 要求其block大小为2048, 预留空间百分比为2, 卷标为MYDATA, 默认挂载属性包含acl; [root@localhost tmp]# cat /proc/partitions major minor #blocks name 8 16 52428800 sdb 8 17 1049041…

    Linux干货 2017-03-06
  • 内部命令与外部命令——Linux基本命令(3)

    1.     内部命令与外部命令 内部命令:由shell自带的,而且通过某命令形式提供 内部命令在系统启动时就调入内存,是常驻内存的,所以执行效率高。 外部命令:在文件系统路径下有对应的可执行程序文件 外部命令是系统的软件功能,用户需要时才从硬盘中读入内存。 2.     命令类…

    2017-07-13
  • 文本处理(1)

    文本处理工具最全整理上半部

    Linux干货 2018-03-15
  • lvs基础知识

    简介  Cluster是什么?    Cluster其实就是组织多个主机构建高实现性能、高可靠、多并发、大容量的同一功能的系统。  常见的集群类型:   (1) Load Balancing: 负载均衡集群   (2) High Avaiability: 高可用集群   (3) …

    Linux干货 2015-06-23

评论列表(1条)

  • 马哥教育
    马哥教育 2016-11-16 15:45

    写的很棒,提个小小的意见,命名变量的时候,尽量不要使用系统的已有函数名