马哥教育网络班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
下一篇 2016-08-08

相关推荐

  • 8月5日课堂及课后作业

    课堂作业 1.找出ifconfig命令结果中的IP地址 [root@localhost ~]# ifconfig |head -2|grep "inet" |tr " " ":"|cut -d:&nb…

    2016-08-08
  • 文本处理工具笔记

    1.文件查看相关命令      (1)cat命令      cat [OPTION]… [FILE]…      -E:显示行结束符      -n:对显示除的每一行进行编号 …

    学员作品 2016-08-10
  • 网卡别名及Bonding实例

    centos6网卡别名 网卡别名: 作用;为同一个网卡设备配置的多个不同ip地址 配置要求: (1)为每个设备别名生成独立的接口配置文件 (2)需关闭NetworkManager服务               &nbs…

    学员作品 2016-09-02
  • for,while,until循环

    一、用until实现下列作业 1、每隔3秒钟到系统上获取已经登录的用户的信息;如果发现用户hacker登录,则将登录时间和主机记录于日志/var/log/login.log中,并提示该用户退出系统。 #!/bin/bash until  who | grep "^\<hacker\>" > /var/log/l…

    学员作品 2016-08-22
  • linux中用ACL实现灵活的权限管理

    ACL是什么?? ACL英文原意是Access Control List(访问控制列表).它能够实现灵活的权限管理,除了文件的所有者,所属组和其他人,设置相应的权限外,ACL允许你给任何用户或是用户组设置任何文件/目录的访问权限(注意的是有些不支持数字模式的权限给定) ACL有什么用?? 作为UGO权限管理的补充,acl有GUO办不到或者是难以办到的功能 &…

    Linux干货 2016-08-05
  • Linux文本处理工具sed

    sed工作原理:sed从文件中读取出来一行,并不会直接进行编辑处理而是会放在自己的模式空间内进行处理,处理的结果将会送到标准输出,默认情况下sed可以对每行文本进行处理,也可以让sed处理符合条件的行,我们可以利用正则表达式做文本过滤,模式空间有两种输出结果,一种是可以匹配到的,会根据编辑要求进行处理,例如删除,过滤字符串。另外一种则是匹配失败的,会直接进行…

    学员作品 2016-08-10

评论列表(1条)

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

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