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
下一篇 2016-10-17

相关推荐

  • grep虐我千百遍,我待grep如初恋

    N21第四周博客作业 1、  复制/etc/skel目录为/home/tuser1,要求/home/tuser1及其内部文件的属组和其它用户均没有任何访问权限。 [root@Centos6 ~]# cp -r /etc/skel /home/tuser1 [root@Centos6 ~]#…

    Linux干货 2016-07-16
  • Linux作业管理、网络客户端工具和bash循环

    Linux系统作业控制;                   job:         前台作业foregroud:通过终端启动,且启动后会一直占据终端;         后台作业…

    Linux干货 2017-01-05
  • n28-第四周

    1、复制/etc/skel目录为/home/tuser1,要求/home/tuser1及其内部文件的属组和其它用户均没有任何访问权限 答:install 复制文件并设置属性 -d, –directory:复制所有参数为目录名 -m, –mode=MODE:设置文件属性,相当于chmod # install -d -m u=rwx /e…

    Linux干货 2017-12-24
  • 初学Linux之用户、组和权限

    1、用户和组管理命令 
    2、理解文件权限和默认权限 
    3、设置文件权限
    4、特殊权限 
    5、ACL

    2017-12-08
  • UID SGID与chmod 777的一些问题

    先来看问题 问题来了:echo的行为返回是对的还是vi是对的? 现场分析: vi 和 echo 都被设置为SGID权限。 abc文件所在的父目录权限是777 echo无法写abc文件,而vi是可以的 当时被问到这个问题时,我也是一征,怎么会这样。加之SUID,SGID在企业应用很少,如此这么久早忘了一干二净,只是赶紧去补课~,但经过30MIN后依然没有找到问…

    Linux干货 2016-08-08
  • nginx AIO机制与sendfile机制

    nginx AIO机制与sendfile机制 从0.8.11版本开始, nginx 开始支持Linux native aio,如何在nginx里配置使用这套机制是本文介绍的重点。在下面的示例配置中,几个重要相关选项的具体含义如下: aio: Syntax: aio on | off | sendfi…

    Linux干货 2016-10-27

评论列表(1条)

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

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