马哥教育网络班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

相关推荐

  • linux磁盘管理及其磁盘分区工具的使用

    一、 几种分区工具: 1.图形化工具gnome-disks使用简单,在此不在赘述。 2.fdisk使用: fdisk支持MBR,也支持GPT分区,对于一块硬盘最多只能理解15个分区,一般使用fdisk做MBR分区,gdisk做GPT分区。下面为fdisk分区示例: [root@centos7 ~]# fdisk /dev/sde…

    Linux干货 2016-08-29
  • sed 流编辑器使用详解

    一、Stream EDitor, 行编辑器   sed是一种流编辑器,它一次处理一行内容。处理时,把当前处理的行存储在临时缓冲区中,称为“模式空间”(pattern space),接着用sed命令处理缓冲区中的内容,处理完成后,把缓冲区的内容送往屏幕。接着处理下一行,这样不断重复,直到文件末尾。文件内容并没有改变,除非你使用重定向存储输出…

    2016-08-10
  • 马哥教育网络班20期+第11周博客作业

    1、详细描述一次加密通讯的过程,结合图示最佳。 例如:     bob给alice发送一份数据:只能alice看到,不能被篡改。     bob:     首先用单向加密提取数据的特征码,然后用自己的私钥加密这个特征码并放在原有数据的后面;…

    学员作品 2016-09-15
  • Selinux的基本命令及练习

    配置SELinux 相关命令:       getenforce: 获取selinux当前状态       sestatus :查看selinux状态      &nbs…

    学员作品 2016-09-19
  • 文本处理三剑客:sed篇

    Stream EDitor, 行编辑器 Sed主要用来自动编辑一个或多个文件,简化对文件的反复操作,编写转换程序等。 工作原理: sed是一种流编辑器,如上图所示,它一次处理一行内容,将读入的那行内容送入模式空间,然后根据sed的编辑命令对其进行响应的操作,处理完成后sed默认会把模式空间中的内容打印至标准输出,如果指定了-n选项,则会禁止这种默认的打印行为…

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

    系统的INPUT和OUTPUT默认策略为DROP; # iptables -P INPUT DROP # iptables -P OUTPUT DROP 1、限制本地主机的web服务器在周一不允许访问;新请求的速率不能超过100个每秒;web服务器包含了admin字符串的页面不允…

    学员作品 2016-11-14

评论列表(1条)

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

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