马哥教育网络班20期+第9周课程练习

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

#!/bin/bash
declare -i other=0
declare -i nologin=0
for i in $(cut -d: -f7 /etc/passwd);do
if [ $i==/sbin/nologin ];then
let nologin++
else
let other++
fi
done
echo "other user total:$other"
echo "nologin user total:$nologin"

2、写一个脚本

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

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

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

#!/bin/bash
hostname=$(hostname)
if [ $hostname=='localhost' ];then
    hostname www.magedu.com
    echo "hostnamme change : 'www.magedu.com'."
else
    echo 'hostname is: $hostname'
fi

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

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

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

#!/bin/bash
read -p "Enter a disk path:" disk
[ -z "$disk" ]&&echo "please input true path!"&&exit 1
    if fdisk -l | grep "^Disk $disk";then
        fdisk -l $disk
    else
        echo "Wrong disk path!"
        exit 2
    fi

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

脚本能够接受一个参数;

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

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

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

#!/bin/bash
cat<<EOF
quit)exit script
yes)continue script
==================================
EOF
read -p "Enter a option:" option
case $option in
quit)
    echo "Exit!"
    exit 0
    ;;
yes)
    echo "yes!continue!"
    ;;
*)
    echo "force exit!"
    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
cat<<EOF
 gzip) use tar and gzip;
bzip2) use tar and bzip2;
   xz) use tar and xz;
==================================
EOF
read -p "Enter a option:" option
case $option in
gzip)
    mkdir /backups &> /dev/null
    tar czvf /backups/etc-20160613.tar.gz /etc &> /dev/null
    echo "gzip success!"
    exit 0
    ;;
bzip2)
    mkdir /backups &> /dev/null
    tar cjvf /backups/etc-20160613.tar.bz2 /etc &> /dev/null
    exit 0
    ;;
xz)
    mkdir /backups &> /dev/null
    tar cJvf /backups/etc-20160613.tar.xz /etc &> /dev/null
    echo "xz success!"
    exit 0
    ;;
*)
    exit "force exit!"
    exit 12
    ;;
esac

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

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

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

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

(4) 其它为无法判断;

#!/bin/bash
read -p "Enter a file :" filename
if [ -z "$filename" ];then
    echo "please enter a true file path."
    exit 2
fi
if [ ! -e $filename ];then
    echo "No such file."
    exit 3
fi
if [ -f $filename ];then
    echo "$filename is a common file."
elif [ -d $filename ];then
    echo "$filename is a directory file. You can use 'cd'."
elif [ -L $filename ];then
    echo "$filename is a symbolic link file."
else
    echo "Unknow file type."
fi

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

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

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

#!/bin/bash
changename(){
    hostname mail.magedu.com
    echo "hostnamme change : 'mail.magedu.com'."
}
if [ $hostname=='localhost' ];then
    changename
elif [ $hostname=='none' ];then
    changename
else
    echo 'hostname is: $hostname'
fi

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

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

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

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

#!/bin/bash
read -p "Enter a username:" user
if id $user &> /dev/null;then
    uid=`id -u $user`
else
    echo "please enter a true username!"
    exit 0
fi
if [ $uid -eq 0 ];then
    echo "$user is root user."
elif [ $uid -lt 500 ]&&[ $uid -gt 0 ];then
    echo "$user is system user."
else
    echo "$user is common user."
fi

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

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

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

#/bin/bash
read -p "Enter a username:" user
if id $user &> /dev/null;then
uid=`id -u $user`
else
echo "please enter a true username!"
exit 0
fi
if [ $uid -ge 500 ];then
if `grep "^$user" /etc/passwd | grep sh$ &> /dev/null`;then
echo "a user can log system."
fi
else
echo "$user can't log system"
fi

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

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

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

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

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

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

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

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

(0)
上一篇 2016-08-08 16:17
下一篇 2016-08-08 20:10

相关推荐

  • 【惊爆】马哥linux2016最新全套课程(内部泄密版)

    你知道么,马哥linux2016最新全套课程(内部泄密版)被曝光了,小编刚刚得到消息,然后就给大家分享出来了,大家快来点评下,话说2016版课程如何?且听小编慢慢为你道来 全新内容,全新阵容,引入ELK和Docker内容,更加贴合生产环境应用,全新的Centos7搭载完善的实战实验室,强大的不像实力派,特别需要说明的一点:0首付0利率,机会不容错过!!! 高…

    学员作品 2015-10-21
  • Linux学习总结及练习&day08-sed文本处理工具

    第一部分、Linux文本处理三剑客之sed(Stream EDitor)文本编辑工具     一、sed的基本功能工作原理     sed是一种流编辑器,它一次处理一行内容。处理时,把当前处理的行存储在临时缓冲区中,称为“模式空间”(pattern space),接着用sed命令…

    Linux干货 2016-08-10
  • iptables防火墙实战

    iptables 防火墙 iptbales是通过调用内核空间的netfiter来实现防火墙功能,在第三代版本后衍生出了五个钩子(hook)来进行约束访问控制。 chain 与 hook 五条钩子分别对应五条链(chain),而链则是iptables 命令约束的参数,链的名字必须大写 钩子【hiook】 链【chain】 功能: preouting PREOU…

    2018-12-05
  • 马哥教育网络班20期-第十周课程作业

    请详细描述CentOS系统的启动流程(详细到每个过程系统做了哪些事情) 1)POST:加电自检 2)BOOT Sequence:按次序查找各引导设备,第一个有grub的设备即为本次启动用到设备 3)加载kernel,先自身初始化,探测可识别到的所有硬件设备,加载硬件驱动程序,以只读方式挂载根文件系统,运行用户空间的第一个应用程序:/sbin/init 4)i…

    学员作品 2016-09-08
  • 马哥教育网络班20期+第10周课程练习

     1. 请详细描述CentOS系统的启动流程(详细到每个过程系统做了哪些事情) 1. 加电自检:POST     通电后主板CMOS中的BIOS(基本输入输出系统)将进行硬件自检并简单设置,根据硬盘等     相关设备情况进入下一步   &…

    学员作品 2016-08-15
  • 马哥团队带你揭秘互联网巨头公司—腾讯

    马哥团队带你揭秘互联网巨头公司—腾讯 前几日,马哥团队成员受邀,到国内互联网巨头–腾讯参观和交流,并用照片记录下了一些精彩瞬间,这里分享给大家。(希望大家多多努力,早日进入顶级公司) 刚到腾讯大厦,上到公司门口,是腾讯的前台,(没想到前台是个男同胞) 进来后,腾讯的照片墙,十分有质感 访客必须先登记,会给发放一个腾讯的访客门牌。 公司…

    学员作品 2015-04-14

评论列表(1条)

  • 马哥教育
    马哥教育 2016-08-17 14:23

    写的很好,排版也很棒,加油