马哥教育网络班20期-第九周课程作业

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

#!/bin/bash
nologinsum=$(awk -F: '$NF~/\/sbin\/nologin$/{print $1}' /etc/passwd |wc -l)
loginsum=$(awk -F: '$NF!~/\/sbin\/nologin$/{print $1}' /etc/passwd |wc -l)
echo "login user:$loginsum"
echo "nologin user:$nologinsum"

2、写一个脚本

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

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

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

#!/bin/bash
if [ "$HOSTNAME" == "localhost" ];then
        hostname www.magedu,com
        else
        echo "$HOSTNAME" 
fi

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

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

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

#!/bin/bash
if [ $# -ne 1 ];then
        echo "you input a unknow device!"
        exit 2
fi
fdisk -s $1 &> /dev/null
if [ $? -eq 0 ];then
        fdisk -l $1
else
        echo "The device is no exist!"
fi

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

脚本能够接受一个参数;

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

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

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

#!/bin/bash
read -p "please input quit,yes,or others:" string
until [ "$string" ==  "quit" ];do
        if [ "$string" ==  "yes" ];then
                echo "try again"
                read -p "please input quit,yes,or others:" string
        else
                echo "error"
                exit 2
        fi
done
        echo "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 [ ! -e /backups ];then
mkdir /backups
fi
read -p "please input gzip,bzip,xz:" option
case "$option" in
gzip)
         tar -zcf /backups/etc-20160613.tar.gz /etc
        ;;
bzip)
        tar -jcf /backups/etc-20160613.tar.bz2 /etc
        ;;
xz)
        tar -Jcf /backups/etc-20160613.tar.xz /etc
        ;;
*)
        echo "please input gzip,bzip,xz!"
        exit 0
        ;;
esac

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

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

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

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

   (4) 其它为无法判断;

#!/bin/bash
read -p "please input a filepath:" path
if      [ -d $path ];then
        echo "It's a folder!"
elif    [ -f $path ];then
        echo "It.s a  regular file!"
elif    [ -h $path ];then
        echo "It's a  accessory path;"
else
        echo "unknow options!"
fi

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

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

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

#!/bin/bash
if [ -z "$HOSTNAME" -o "$HOSTNAME" == "localhost" -o "$HOSTNAME" == "none" ];then
        hostname mail.magedu.com
else
        echo "$HOSTNAME"
fi

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

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

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

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

#!/bin/bash
read -p "please input a username:" username
id -u $username &> /dev/null
if [ $? -eq 0 ];then
        if      [ $(id -u $username) -eq 0 ];then
                echo "It's a Admin user!"
        elif    [ $(id -u $username) -lt 500 ];then
                echo "It's a system user!"
        else
                echo "It's a registered users!"
        fi
else
        echo "The user is no exist!"
fi

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

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

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

#!/bin/bash
  read -p "please input a username:" username
  id -u $username &> /dev/null
  if [ $? -eq 0 ];then
  #       if [ $(id -u $username) -ge 500 ] && [ $(awk -f: '/^"$username"/{print $NF}') == "/bin/bash" ];then
          if [ $(id -u $username) -ge 500 ] && [ "$(cat /etc/passwd |grep "^root" |cut -d: -f7)" == "/bin/bash" ];then
                  echo "a user can log system!"
           else    
                   echo "a user can't log system"
          fi
  else    
          echo "the user is not exist!"
  fi

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

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

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

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

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

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

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

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

(1)
Net20_有马Net20_有马
上一篇 2016-09-08
下一篇 2016-09-08

相关推荐

  • Selinux的基本命令及练习

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

    学员作品 2016-09-19
  • 马哥教育网络班20期+第8周博客作业

    1、请描述网桥、集线器、二层交换机、三层交换机、路由器的功能、使用场景与区别。   网桥:链接层设备,基于MAC地址过滤。   集线器:物理层设备,基本都属于半双工模式。集线器与网桥在现在的局域网中基本都不用了。   二层交换机:基本MAC转发数据,功能齐全的可支持VLAN等功能。常见的有100/1…

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

    1、写一个脚本,判断当前系统上所有用户的shell是否为可登录shell(即用户的shell不是/sbin/nologin);分别这两类用户的个数;通过字符串比较来实现; #!/bin/bash declare -i other=0 declare -i nologin=0 for i in&nbs…

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

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

    Linux干货 2016-08-05
  • 正则表达式

    grep:Global search REgular expression and Print out the line         文本搜索工具,根据用户指定的”模式“对目标文本逐行进行匹配检查;打印匹配到的行        模式:由正则表达式字符及文本字符所编写的过滤条件…

    Linux干货 2016-08-08
  • 马哥教育网络班20期-第十周课程作业

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

    学员作品 2016-09-08