马哥教育网络班21期-第九周课程练习

第九周作业

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

#!/bin/bash
#
declare -i nologin=0
declare -i other=0

    for i in $(cut -d: -f7 /etc/passwd);do
        if [ $i == /sbin/nologin ]; then
            let nologin++
        else
            let other++
        fi
    done

echo "nologin user numer:$nologin"
echo "other user number:$other"
~  

测试:
[root@qq scripts]# bash -x 9-1.sh 
+ declare -i nologin=0
+ declare -i other=0
++ cut -d: -f7 /etc/passwd
+ for i in '$(cut -d: -f7 /etc/passwd)'
+ '[' /bin/bash == /sbin/nologin ']'
+ let other++
+ for i in '$(cut -d: -f7 /etc/passwd)'
+ '[' /sbin/nologin == /sbin/nologin ']'
+ let nologin++
+ for i in '$(cut -d: -f7 /etc/passwd)'
+ '[' /sbin/nologin == /sbin/nologin ']'
+ let nologin++
……
+ echo 'nologin user numer:26'
nologin user numer:26
+ echo 'other user number:10'
other user number:10

2、写一个脚本

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

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

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

    #!/bin/bash
    
    hostname=$(hostname)
    
    if [ $hostname == 'localhost' ];then
        hostname www.magedu.com && echo "hostname change:'www.magedu.com'"
    else
        echo 'hostname is:' $hostname
    fi
    
    测试:
    [root@qq scripts]# bash -x 9-2.sh 
    ++ hostname
    + hostname=qq.localdomain
    + '[' qq.localdomain == localhost ']'
    + echo 'hostname is:' qq.localdomain
    hostname is: qq.localdomain
    [root@qq scripts]#

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

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

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

    #!/bin/bash
    #
    
    read -p "enter dev path:" dev
    
    if [ -e $dev ];then
        parted $dev print
    else
        echo "This dev is not exist"
    fi
    
    测试:
    [root@qq scripts]# bash -x 9-3.sh 
    + read -p 'enter dev path:' dev
    enter dev path:/dev/sda
    + '[' -e /dev/sda ']'
    + parted /dev/sda print
    Model: VMware, VMware Virtual S (scsi)
    Disk /dev/sda: 268GB
    Sector size (logical/physical): 512B/512B
    Partition Table: msdos
    
    Number  Start   End     Size    Type      File system     Flags
     1      1049kB  211MB   210MB   primary   ext4            boot
     2      211MB   52.6GB  52.4GB  primary   ext4
     3      52.6GB  94.6GB  41.9GB  primary   ext4
     4      94.6GB  268GB   174GB   extended
     5      94.6GB  131GB   36.7GB  logical   ext4
     6      131GB   152GB   21.0GB  logical   ext4
     7      152GB   168GB   15.7GB  logical   ext4
     8      168GB   184GB   15.7GB  logical   ext4
     9      184GB   194GB   10.5GB  logical   ext4
    10      194GB   198GB   4295MB  logical   linux-swap(v1)
    
    [root@qq scripts]#

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

  • 脚本能够接受一个参数;

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

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

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

    #!/bin/bash
    #
    
    if [ $# -le 0 ];then
        echo "usage:bash 9-4.sh quit|yes|other"
        exit 2
    else
        case $1 in
        quit)
        echo "quiting"
        exit 0;;
        yes)
        echo "conutine";;
        *)
        echo "error..."
        exit 1
        esac
    fi
    测试:
    [root@qq scripts]# bash 9-4.sh 
    usage:bash 9-4.sh quit|yes|other
    [root@qq scripts]# 
    [root@qq scripts]# 
    [root@qq scripts]# bash 9-4.sh quit
    quiting
    [root@qq scripts]# bash 9-4.sh yes
    conutine
    [root@qq scripts]# bash 9-4.sh d
    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) 其它任意值,则显示错误压缩工具,并执行非正常退出;

    #!/bin/bash
    #
    if [ $# -le 0 ]; then
        echo "usage:bash 9-5.sh gzip|bzip2|xz|..."
        exit 2
    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;;
        esac
    fi
    测试:
    [root@qq scripts]# bash  9-5.sh xz
    [root@qq scripts]# ls /backups/
    etc-20160613.tar.xz
    [root@qq scripts]#

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

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

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

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

  • (4) 其它为无法判断;

    #!/bin/bash
    #
    if [ $# -le 0 ];then
        echo "Usage:bash 9-6.sh /PATH/FILE."
        exit 2
    fi
    
    if [ -h $1 ]; then
        echo "This is accessable path."
    elif [ -d $1 ]; then
        echo "This is directory command 'cd' can be use."
    elif [ -f $1 ]; then
        echo "This file can be access."
    else
        echo "Unknow File."
    fi
    
    测试:
    [root@qq scripts]# bash 9-6.sh /tmp/2.txt 
    This is accessable path.
    [root@qq scripts]# bash 9-6.sh /tmp/1.txt 
    This file can be access.
    [root@qq scripts]# bash 9-6.sh /tmp/
    This is directory command 'cd' can be use.

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

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

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

    #!/bin/bash
    #
    HostName=`hostname`
    if [ -z "HostNmae" -o "$HostName" == "localhost" -o "$HostName" == "(none)" ]; then
        hostname mail.magedu.com
    else
        echo "$HostName"
    fi
    测试:
    [root@qq scripts]# bash 9-7.sh 
    qq.localdomain

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

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

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

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

    #!/bin/bash
    #
    
    read -p "Please enter one user:" user
    uid=`id -u $user`
    
    if [ $uid -eq 0 ]; then
        echo "$user is admin."
    elif [ $uid -gt 0 -a $uid -lt 500 ]; then
        echo "$user is system user."
    else
        echo "$user is common user."
    fi
    测试:
    [root@qq scripts]# bash 9-8.sh 
    Please enter one user:root
    root is admin.
    [root@qq scripts]# bash 9-8.sh
    Please enter one user:mysql
    mysql is system user.
    [root@qq scripts]# bash 9-8.sh
    Please enter one user:centos
    centos is common user.

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

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

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

    #!/bin/bash
    #
    if [ $# -le 0 ]; then
        echo "Usage:bash 9-10.sh username"
        exit 2
    fi
    
    if id $1 &> /dev/null; then
        userid=`grep ^$1 /etc/passwd | grep sh$ | cut -d: -f3`
        if [ $userid -ge 500 ]; then
        echo "a user can login system."
        else
        echo "a user can not login system."
        fi
    fi
    测试:
    [root@qq scripts]# bash 9-10.sh root
    a user can not login system.
    [root@qq scripts]# bash 9-10.sh gg
    a user can login system.
    [root@qq scripts]# cat /etc/passwd | grep gg
    gg:x:603:603::/home/gg:/bin/sh

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

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

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

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

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

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

    #!/bin/bash
    dir="/var/log/"
    des="/tmp/test1-testn"
    mkdir $des
    for i in `ls $dir`; do
        if [ -c $i ]; then
            cp -r $dir$i $des/
        elif [ -f $i ]; then
            cp $dir$i $des/
        elif [ -h $i ]; then
            cp -d $dir$i $des/
        else
            cp -a $dir$i $des/
        fi
    done

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

(2)
Net21_仲樂Net21_仲樂
上一篇 2016-09-19
下一篇 2016-09-19

相关推荐

  • LVS管理平台使用手册(第一版)[原创]

     为了更好管理、维护LVS平台,本人基于Django+certmaster+func开发了一套管理平台,主要功能模块分为性能图表、数据中心、虚拟IP池、主机管理、监控模块等功能,基本上是按F5-LTM管理平台思路来设计,下面只要对这几大块功能进行说明。1、性能图表 功能说明:以小时、日、星期、月、年的图表展示LVS SERVER、VIP、SERVE…

    Linux干货 2015-03-28
  • 用户组和权限管理2

    十七、linux文件系统上的特殊权限     suid:s表示,sgid:s表示,sticky:t表示          安全上下文     前提:进程有属主和属组,文件有属主和属组  &n…

    Linux干货 2016-08-04
  • 计算机网络基础

    计算机网络基础 分层的网络模型 网络发展到今天,规模很庞大,内容很复杂,不利于网络的管理和教学。网络分层可以:降低网络结构的复杂性、把各层的接口标准化、简化模块设计、确保技术的互操作性、加快发展速度以及简化教学过程。 OSI模型——国际标准:根据国际标准化组织( ISO,International Standards Orgnization)提案,计算机网络…

    Linux干货 2016-11-22
  • linux命令查找locate find要点

           在文件系统上查找符合的文件        locate, find locate:          依赖于事先构建好的索引库:             &…

    Linux干货 2016-11-07
  • 使用keepalive实现nginx反向代理高可用

    简介: 在网站架构中,为了分散客户端对服务器的访问压力,可以使用nginx作为反向代理。但是使用一个nginx作为代理服务器必定会面对单点故障的情况,所以一般使用多台nginx反代服务器,而使用多台nginx服务器还要面对如何协调调度的问题。在此,我给大家介绍使用keepalive协调调度nginx反代服务器的方法。   keepalive简介 说…

    2017-05-15
  • N24期第四周作业

    1、复制/etc/skel目录为/home/tuser1,要求/home/tuser1及其内部文件的属组和其它用户均没有任何访问权限。 2、编辑/etc/group文件,添加组hadoop。 vim /etc/group,增加此行 3、手动编辑/etc/passwd文件新增一行,添加用户hadoop,其基本组ID为hadoop组的id号;其家目录为/home…

    Linux干货 2016-11-22

评论列表(1条)

  • 马哥教育
    马哥教育 2016-09-19 18:14

    写脚本的时候,不要用系统的函数名作为变量名