Homework Week-9 bash脚本之顺序、选择、循环

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

#!/bin/bash
#Elephant
echo "nologin users:"
user1=$(cat /etc/passwd | grep "nologin$" | wc -l )
echo "$user1"
echo "other users:"
user2=$(cat /etc/passwd | wc -l)
declare -i i
i=$user2-$user1
echo "$i"

 

2、写一个脚本

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

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

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

#!/bin/bash
#Elephant
hostname | grep "localhost" &>/dev/null
if [ $? -eq 0 ];then
  echo "www.magedu.com" > /etc/hostname # change after reboot  
fi

 

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

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

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

#!/bin/bash
#Elephant
if ! [ $# -eq 1 ];then
  echo "Please input one disk path!"
  exit 2;
else
  ls $1 &> /dev/null
  if [ $? -eq 0 ];then
     fdisk -l $1
  fi
fi

 

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

   脚本能够接受一个参数;

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

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

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

#!/bin/bash
#Elephant
if ! [ $# -eq 1 ];then
  echo "Please input one argument!"
  exit 2
else
  case $1 in
  "quit")
      echo "Quit the bash!" 
  ;;
  "yes")
      echo "Go on!"
  ;;
  *)
   exit 3
  ;;
  esac
fi

  

5、写一个脚本,完成如下功能传递一个参数给脚本,此参数为gzipbzip2或者xz三者之一;

   (1) 如果参数1的值为gzip,则使用targzip归档压缩/etc目录至/backups目录中,并命名为/backups/etc-20160613.tar.gz

   (2) 如果参数1的值为bzip2,则使用tarbzip2归档压缩/etc目录至/backups目录中,并命名为/backups/etc-20160613.tar.bz2

   (3) 如果参数1的值为xz,则使用tarxz归档压缩/etc目录至/backups目录中,并命名为/backups/etc-20160613.tar.xz

   (4) 其它任意值,则显示错误压缩工具,并执行非正常退出;

#!/bin/bash
#Elephant
#gzip or bzip2 or xz
if ! [ $# -eq 1 ];then
  echo "Please input one argument!"
  exit 2
else
  rm -rf /backups 
  case $1 in
    "gzip")
      if ! [ -f /backups ] ;then
         mkdir /backups
      fi
      tar -cf /backups/etc-20160613.tar  /etc  &> /dev/null
      gzip -c /backups/etc-20160613.tar > /backups/etc-20160613.tar.gz
      ls -l /backups    
    ;;
    "bzip2")
      if ! [ -f /backups ];then
        mkdir /backups
      fi
      tar -cf /backups/etc-20160613.tar /etc  &> /dev/null
      bzip2 -k /backups/etc-20160613.tar
      ls  -l  /backups
    ;;
    "xz")
      if ! [ -f /backups ];then
        mkdir /backups
      fi
      tar -cf /backups/etc-20160613.tar /etc  &> /dev/null
      xz -k /backups/etc-20160613.tar
      ls -l  /backups
    ;;
    *)
      echo "Wrong input , quit !"
      exit 3
    ;;
  esac
fi

 

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

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

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

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

   (4) 其它为无法判断;

#!/bin/bash
#Elephant
if ! [ $# -eq 1 ];then
  echo "Please input one argument!"
else
  file $1 | grep "cannot open" &> /dev/null
  if [ $? -eq 0 ];then
    echo "Unknow type."
  else
  file $1 | grep "ASCII text" &> /dev/null
  if [ $? -eq 0 ];then
    echo "ASCII text file , you can use it."
  else
    file $1 | grep "symbolic link " &> /dev/null
    if [ $? -eq 0 ];then
      echo "This is a link file."
    else
      file $1 | grep "directory" &> /dev/null
      if [ $? -eq 0 ];then
        echo "This is a directory."
      fi
    fi
  fi
 fi
fi

 

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

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

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

#!/bin/bash
#Elephant
hostname | grep "localhost" &>/dev/null
if [ $? -eq 0 ];then
  echo "mail.magedu.com" >/etc/hostname
else
  hostname
fi

 

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

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

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

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

#!/bin/bash
#Elephant
if ! [ $# -eq 1 ];then
  echo "Please input one user."
else 
  id $1 | grep "$1" &>/dev/null
  if [ $? -eq 0 ];then  
     declare -i id
     id=$(cat /etc/passwd | grep "^$1\>" | cut -f 3 -d:)
     echo "$id"
     if [ $id -eq 0 ];then
            echo "$1 is admin."
     else
            if [ $id -gt 0 -a $id -le 500 ];then
                echo "$1 is systemuser."
            else
                echo "$1 is normal user."
            fi
     fi
   else
        exit 3
   fi
fi

 

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

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

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

#!/bin/bash
#Elephant
if ! [ $# -eq 1 ];then
   echo "Please input one user."
   exit 2
else
   id $1|grep $1 &>/dev/null
   if [ $? -eq 0 ];then
      declare -i id
      id=$(cat /etc/passwd | grep "^$1\>" | cut -f 3 -d:)
      if [ $id -gt 500 ];then
          cat /etc/passwd | grep "sh$"&>/dev/null
          if [ $? -eq 0 ];then
             echo "$1 can log system."
          fi
      else
         echo "$1 can not log system."
      fi
   fi
fi

 

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

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

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

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

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

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

#!/bin/bash
#Elephant
mkdir /tmp/
touch /tmp/list.tmp
ls -l /var/log | awk 'BEGIN{i=0} {print $1" "substr($1,1,1)" /tmp/test" i "/ /var/log/"$9;i++}'  | sed -e '1d'  >> /tmp/list.tmp
awk'{switch($2)
         {case "d":system("mkdir "$3" &>/dev/null");system("cp -r "$4" "$3"");
          case "-":system("mkdir "$3" &>/dev/null");system("cp "$4" "$3"");
          case "l":system("mkdir "$3" &>/dev/null");system("cp -d "$4" "$3"");
          default:system("mkdir "$3" &>/dev/null");system("cp -a "$4" "$3"");
         }
     }' /tmp/list.tmp

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

(0)
N22_ElephantN22_Elephant
上一篇 2016-10-17 08:36
下一篇 2016-10-17 08:36

相关推荐

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

    请详细总结vim编辑器的使用并完成以下练习题 1、复制/etc/rc.d/rc.sysinit文件至/tmp目录,将/tmp/rc.sysinit文件中的以至少一个空白字符开头的行的行首加#;     cp /etc/rc.d/rc.sysinit  /tmp   &n…

    Linux干货 2016-10-19
  • keepalived+nginx

    keepalived可以认为是VRRP协议在Linux上的实现,主要有三个模块,分别是core、check和vrrp。core模块为keepalived的核心,负责主进程的启动、维护以及全局配置文件的加载和解析。check负责健康检查,包括常见的各种检查方式。vrrp模块是来实现VRRP协议的。本文基于如下的拓扑图: 配置keepalived+nginx的方…

    Linux干货 2016-11-04
  • 第九周博客作业

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

    Linux干货 2017-06-06
  • 08.04 笔记总结

    1.ps axo  user,ruser,group,rgroup,cmd  //  ruser  表示程序发起的用户,一般是指系统当前的用户  //  user  表示程序的所有者。在大数情况下,两个用户都是系统当前的用户, 之后当程序被赋予suid的时候,可能user会发生变化。 2.…

    Linux干货 2016-08-08
  • Linux 启动流程

    Linux启动流程 POST–>Boot Sequence–>MBR–>Grub–>Kernel(initramfs)–>rootfs–chroot(根切换)–>/sbin/init–>RunLevel–&gt…

    Linux干货 2016-06-09
  • 2016-08-12作业

    1、查找/var 目录下属主为root ,且属组为mail 的所有文件 [root@localhost bin]# find /var -user root -group mail /var/spool/mail /var/spool/mail/root   2、查找/var 目录下不属于root 、lp 、gdm 的所有文件 find /var …

    Linux干货 2016-08-15

评论列表(1条)

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

    脚本思路很好,下次可以好好学下如何排版