N22-妙手-第九周课程练习

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

#!/bin/bash
#

declare -i numberOfLoginUser=0
declare -i numberOfUnloginUser=0

while read lines; do

    shellType=${lines##*:}
    if [ "$shellType" == "/sbin/nologin" ]; then
        let numberOfUnloginUser++
    else
        let numberOfLoginUser++
    fi
done < /etc/passwd

echo "How many login shell: "$numberOfLoginUser"
echo "How many unlogin shell" $numberOfUnloginUser"

2、写一个脚本

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

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

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

#!/bin/bash
#

hostname=$(hostname)
if [ "$hostname" == "www.magedu.com" ]; then
    hostnamectl set-hostname localhost.localdomain
    echo $(hostname)
else
    echo $hostname
fi

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

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

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

#!/bin/bash
#
if [ -b $1 ]; then
    fdisk -l $1
else
    echo "Please send the device file"
fi

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

脚本能够接受一个参数;

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

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

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

#!/bin/bash

case $1 in
quit) 
    echo "Exit the shell script"
    exit 
    ;;
yes)
    echo "continue excute the shell script"
    ;;
*)
    echo "pleaes input quit or yes"
    exit 2
    ;;
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
#

format=$1

case $format in

gzip)
    tar -cf /backups/etc-20161013.tar.gz /etc/
    ;;
bzip2) 
    tar -jcf /backups/etc-21061013.tar.bz2 /etc/
    ;;
xz)    
    tar -Jcf /backups/etc-20161013.tar.xz /etc/
    ;;
*)
    echo "Please use the right compresss tool"
    exit 2
    ;;
esac

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

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

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

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

(4) 其它为无法判断;

#!/bin/bash
#
para1=$1

if [ -f $para1 ]; then
    echo "This file can be accessed normally."
elif [ -d $para1 ]; then
    echo "This file is directory file and can use cd command to this directory"
elif [ -L $para1 ]; then
    echo "This is a symbol link file"
else 
    echo "The file can not be identified"
fi

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

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

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

#!/bin/bash
#

hostName=$(hostname)

if [ -z "$hostName" ] || [ "$hostName" == "localhost" ] || [ "$hostName" == "(none)" ]; then
    hostnamectl set-hostname mail.magedu.com
    echo $(hostname)
else
    echo $(hostname)
fi

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

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

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

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

#!/bin/bash
#
read -p "Please Enter username: " username

if id $name >& /dev/null; then
    userid=$(id -u $username)
    if [ $userid -eq 0 ]; then
        echo "Root user"
    elif [ $userid -gt 0 ] && [ $userid -le 500 ]; then
        echo "System user"
    else
        echo "Common user"
    fi

else
    echo "please input valid username"
    exit 2
fi

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

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

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

#!/bin/bash
#

if [ $# -lt 1 ]; then
    echo "Please send at lease 1 username"
    exit 1
fi

if id $1 >& /dev/null; then
    userid=$(id -u $1)
    userinfo=$(cat /etc/passwd | grep $1)
    if [ $userid -gt 500 ] && [ "${userinfo: -2}" == "sh" ];then
        echo "a user can log system"
    else    
        echo "this user can not log to system"
    fi
else
    echo "Please input a valid username"
fi

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

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

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

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

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

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

#!/bin/bash
#

dir=/test/test1-testn

if !(( -d $dir )); then
    mkdir -pv /test/test1-testn
fi

for i in /tmp/*; do
    if [ -d $i ]; then
        cp -r $i $dir
    elif [ -f $i ]; then
        cp $i $dir
    elif [ -L $i ]; then
        cp -d $i $dir
    else
        cp -a $i $dir
    fi
done

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

(0)
mxb93mxb93
上一篇 2016-10-19 14:19
下一篇 2016-10-19 14:19

相关推荐

  • Linux—文本处理(查看,统计,排序,抽取,合并,grep,基本正则表达式)

    Linux的文本管理有着众多的文本命令工具,这些工具基本可以满足不同的文本处理要求,很是灵活,掌握文本管理命令对系统的维护是必备基础技能。 1.文本查看命令:     (1)cat        语法:        cat [OPTION]… […

    Linux干货 2016-08-07
  • N25_第三周博客作业

    1、列出当前系统上所有已经登录的用户的用户名,注意:同一个用户登录多次,则只显示一次即可。 [root@test ~]# who root     tty1         2016-12-03&nb…

    Linux干货 2016-12-16
  • CA服务器的搭建以及证书签署、dropbear的编译安装

    CA服务器的搭建以及证书签署、dropbear的编译安装 一、CA Server和Client: 1、CA server:创建私钥CA (1)   openssl的配置文件:/etc/pki/tls/openssl.conf   如果Client端的申请是来自不同的国家,则需要将下图中红色框内的三项,由“match”改为“opt…

    Linux干货 2016-09-23
  • shell与kernel的理解

    Shell 的英文释义是外壳,与kernel 内核名词遥相呼应,一外一内,一壳一核。内核就像瑞士银行的金库,存放着客户的黄金等众多的(硬件)资产,闲杂人等(包括客户)当然是严格禁止入内的,而作为客户要存取金库中的资产则需要通过专门的特定管理人员代为操作完成,并把存取(操作)的结果呈现给客户。在Linux操作系统中,shell的职能就类似于金库的操作人员,客户…

    Linux干货 2016-02-14
  • locate与find不得不说的事

    本文内容: locate与find 练习     locate与find是linux中最常用的两种查找方式,二者各有优缺点,locate查找迅速,却由于数据库非实时更新,导致可能查找不全,而find由于是从指定路径开始遍历,速度相对较慢,却更为准确,而且用法也更加灵活,因此find运用更加广泛,也是本文的重点。 文件查找: locate搜…

    Linux干货 2016-08-18
  • Python装饰器与面向切面编程

    新年好~ 那么,很久没有更新了,其实想想也没多少可以写的,因为Python的文档似乎很全面的说……能做的差不多只有翻译和整理了,英文过关的朋友不妨直接去doc.python.org这里查看相关资料 :) 转载请注明原作者和原文地址,多谢! 今天来讨论一下装饰器。装饰器是一个很著名的设计模式,经常被用于有切面需求的场景,较为经典的有插入日志、性能测试、事务处理…

    Linux干货 2015-03-12

评论列表(1条)

  • 马哥教育
    马哥教育 2016-10-25 13:28

    注意审题,不要理解反了,好好看看第二个问题的要求