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

相关推荐

  • 第六周 N21 总有刁民想害朕

    请详细总结vim编辑器的使用并完成以下练习题 1、复制/etc/rc.d/rc.sysinit文件至/tmp目录,将/tmp/rc.sysinit文件中的以至少一个空白字符开头的行的行首加#;    %s/\(^[[:space:]]\)/#\1/ 2、复制/boot/grub/grub.conf至/tmp目录中,删除/tmp/grub.…

    Linux干货 2016-08-08
  • CentOS6下的网络信息配置

    简介     我们都知道在我们互联网中,所有的通信都通过网络来完成的,有了网络当然也要有对应的地址,MAC地址是固定不变的,所以能变的只有IP的地址,那么今天来带给大家如何在CentOS6中如何配置网卡。当然一下的所有命令都是在CentOS6中进行的。 一、网卡的配置文件    1.操作网卡的命令 …

    Linux干货 2017-03-20
  • 软件包管理(rpm,yum,源码安装)

    API:Application Programming Interface  ==>软件开发接口     POSIX :Portable OS 程序源代码 –> 预处理 –> 编译 –> 汇编 –>链接   &n…

    Linux干货 2016-08-24
  • iptables

    一、机制 部队大院、高档私人住宅区都是在一个被保护起来的范围内,要想进入只能从各个大门进入,在进入的时候还在门口出示证件、或者是指纹识别、或者是保安身份认证等,只有通过了这些检查才能进入到大院、住宅区内部。 Linux系统也是这么一个大院,netfilter就是这个大院的围墙,prerouting、input、output、forward、postrouti…

    Linux干货 2017-01-13
  • HA之corosync+pacemaker+crmsh

    高可用集群框架 图片转载之http://www.178linux.com/16656 实验拓扑: 两台节点服务器: node1     192.168.150.137     node1.com node2     192.168.150.138     node2.com nf…

    Linux干货 2017-01-18
  • 系统启动及恢复

    一、知识整理 1、modinfo命令:显示模块的详细描述信息: -n 只显示模块文件路径 -p 显示模块参数 -a auther -d description -l license协议 modprobe命令:装载或卸载内核 -r卸载内核,同rmmod 配置文件:/etc/modprobe.d/*.conf depmod命令:内核模块依赖关系文件及系统信息映射…

    Linux干货 2016-09-22

评论列表(1条)

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

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