马哥教育网络班19期+第九周课程练习

1、写一个脚本,判断当前系统上所有用户的shell是否为可登录shell(即用户的shell不是/sbin/nologin);分别这两类用户的个数;通过字符串比较来实现;
#!/bin/bash
#
declare -i noNum=0
declare -i lNum=0
for bashName in `cat /etc/passwd | cut -d: -f7` ;do
        if [ "$bashName" == "/sbin/nologin" ];then
                echo "$bashName is nologin"
                let noNum++
        else
                echo "$bashName is login"
                let lNum++
        fi
done
echo -e "nologin user is $noNum\nlogin user is $lNum"
2、写一个脚本
 (1) 获取当前主机的主机名,保存于hostname变量中;
 (2) 判断此变量的值是否为localhost,如果是,则将当前主机名修改为www.magedu.com;
 (3) 否则,则显示当前主机名;

#!/bin/bash
#
hostname=`hostname`
if [ "$hostname" == "localhost" ];then
        hostname www.magedu.com
else
        hostname
fi
3、写一个脚本,完成如下功能
 (1) 传递一个磁盘设备文件路径给脚本,判断此设备是否存在;
 (2) 如果存在,则显示此设备上的所有分区信息;

#!/bin/bash
#
if [ $# -eq 1 ];then
    if [ -b "$1" ];then
        if blkid $1 &>/dev/null ;then
            echo "error 3 try again"
        else
            fdisk -l $1[1-99]
        fi
    else
        echo "error 2 try again"
    fi        
else
    echo "error 1 try again"
fi
4、写一个脚本,完成如下功能
脚本能够接受一个参数;
 (1) 如果参数1为quit,则显示退出脚本,并执行正常退出;
 (2) 如果参数1为yes,则显示继续执行脚本;
 (3) 否则,参数1为其它任意值,均执行非正常退出;

#!/bin/bash
#
read -p "input a word: " wordName
while [ $wordName != "quit" ];do
    if [ $wordName == "yes" ];then
        echo "try again!"
        read -p "input a word: " wordName
    else
        echo "input error 1"
        exit 1
    fi
done
echo "exit ok"
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 ! [ -d /backups ];then
mkdir -p /backups
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 tools!"
            exit 1
            ;;
esac
6、写一个脚本,接受一个路径参数:
   (1) 如果为普通文件,则说明其可被正常访问;
   (2) 如果是目录文件,则说明可对其使用cd命令;
   (3) 如果为符号链接文件,则说明是个访问路径;
   (4) 其它为无法判断;

#!/bin/bash
#
if [ $# -eq 1 ];then
    if [ -L $1 ];then
        echo "a path"
    elif [ -d $1 ];then
        echo "a dir"
    elif [ -f $1 ];then
        echo "a file"
    else
        echo "no type"
    fi
else
    echo "error 1"
fi
7、写一个脚本,取得当前主机的主机名,判断
   (1) 如果主机名为空或为localhost,或为""(none)"",则将其命名为mail.magedu.com;
   (2) 否则,显示现有的主机名即可;

#!/bin/bash
#
hName=`hostname`
nName=$(echo '""(none)""')
if [ -z "$hName" ]||[ "$hName" == "localhost" ]||[ "$hName" == "$nName" ];then
    hostname mail.magedu.com
else
    echo $hName
fi
8、写一脚本,接受一个用户名为参数;
   (1) 如果用户的id号为0,则显示其为管理员;
   (2) 如果用户的id号大于0且小于500, 则显示其为系统用户;
   (3) 否则,则显示其为普通用户;

#!/bin/bash
#
if [ $# -eq 1 ] && id $1 &>/dev/null;then
    num=`cat /etc/passwd | grep "^$1\>" | cut -d: -f3`
    if [ $num -eq 0 ];then
        echo "user is root"
    elif [ 0 -lt $num ]&& [ $num -lt 500 ];then
        echo "user is s user"
    else
        echo "user is n user"
    fi
else
    echo "error 1"
fi
9、写一个脚本,传递一个用户名参数给脚本;
   (1) 如果用户的id号大于等于500,且其默认shell为以sh结尾的字符串,则显示“a user can log system.”类的字符串;
   (2) 否则,则显示无法登录系统;

#!/bin/bash
#
if [ $# -eq 1 ]&& id $1 &>/dev/null;then
    idNum=`cat /etc/passwd | grep "^$1\>" |cut -d: -f3 `
    if [ $idNum -ge 500 ]&& cat /etc/passwd | grep "^$1\>.*sh$" &>/dev/null;then
        echo "a user can log system."
    else
        echo " a user can't log system."
    fi
else
    echo "error 1"
fi
10、写一个脚本,完成如下任务 :
   (1) 按顺序分别复制/var/log目录下的每个直接文件或子目录至/tmp/test1-testn目录中;
   (2) 复制目录时,才使用cp -r命令;
   (3) 复制文件时使用cp命令;
   (4) 复制链接文件时使用cp -d命令;
   (5) 余下的所有类型,使用cp -a命令;"

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

原创文章,作者:N23_夕立时雨,如若转载,请注明出处:http://www.178linux.com/20992

(0)
N23_夕立时雨N23_夕立时雨
上一篇 2016-06-29 14:31
下一篇 2016-06-29 17:45

相关推荐

  • sed命令的用法和vim编辑器的使用

    一、文本处理工具sed sed [option]….'script] [input-file]… 简介: sed是一种流编辑器,他一次处理一行的内容,处理时把当前处理的行存储在临时缓冲区中,这个缓冲区被称为模式空间,接着用sed命令处理,处理完成后把模式空间的内容送往屏幕,接着处理下一行,知道文件末尾,而文件的内容…

    Linux干货 2016-08-15
  • N26 第二周博客作业

    1、Linux上的文件管理类命令都有哪些,其常用的使用方法及其相关示例演示。 常用的文件管理工具有: cp mv rm cp 命令 : copy 的简写 语法格式:    1) 单源复制 cp [OPTION]… [-T] SOURCE DEST      …

    Linux干货 2017-02-24
  • 分布式文件系统MogileFS

    1、分布式系统的目标:加强A、P,在C上进行妥协     BASE模型 CAP理论: C:Consistency(一致性)  任何一个读操作总是能够读取之前完成的写操作。 A:Availability(可用性) 每一次操作总是能够在确定的时间返回。 P: Partition Tolerance ( 分区容错性 )   在出现网络分区的情况下,仍然能够满足一致…

    2017-11-23
  • 初识Linux基础

    一:计算机的组成及其基本功能 计算机主要由五大基础部件组成:控制器,运算器,存储器,输入设备,输出设备。 1、控制器:计算机的核心组件,协调各程序的运行,对计算机的各项资源进行控制分配; 2、运算器:计算机实现算术运算以及逻辑运算的部件; 3、存储器:计算机用来存放数据和程序的基本部件,存储器由若干存储单元组成,每个存储单元都有一个             …

    Linux干货 2018-03-04
  • GRUB——防止root密码被破解

    GRUB(Boot Loader): ·grub:GRand Unified Bootloader          grub 0.x:grub leagacy          grub 1.x:g…

    Linux干货 2016-09-11
  • 进程查看及管理

        在Linux系统中,触发任意一个事件时,系统都会将它定义为一个进程,并且给予这个进程一个ID,称为PID,同时依据触发这个进程与用户相关的属性关系,给予这个PID一组有效的权限设置。 进程(Process)是计算机中的程序关于某数据集合上的一次运行活动,是系统进行资源分配和调度的基本单位,是操作系统结构的基础。…

    Linux干货 2016-11-27

评论列表(1条)

  • 马哥教育
    马哥教育 2016-06-29 15:02

    写的很好,多注意一下排版,脚本还可以优化一下,有几个脚本可能会有一些小瑕疵,仔细检查一下