马哥教育网络班20期+第9周博客作业

1、写一个脚本,判断当前系统上所有用户的shell是否为可登录shell(即用户的shell不是/sbin/nologin);

分别这两类用户的个数;通过字符串比较来实现;

    #!bin/bash

    export clogin=0
    export ulogin=0

    for i in $(cat /etc/passwd | cut -d: -f7); do
       if [ "$i" == "/sbin/nologin" ]; then
           let clogin++
           echo "$i;can't login in"
       else
           let ulogin++
           echo "$i;can login"
           fi
        done

      echo "can't login in:$clogin"
      echo "can login in:$ulogin"

2、写一个脚本

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

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

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

      #!bin/bash

      for i in $(hostname);do
        if [ "$i" == "localhost" ];then
            hostname www.magedu.com
        else
           echo "$i"
        fi
      done

      测试:
      [root@web1 ~]# hostname localhost
      [root@web1 ~]# bash hostname.sh
      [root@web1 ~]# hostname
      www.magedu.com
      [root@web1 ~]#

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

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

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

      #!bin/bash

      if [ -e $1 ]; then 
           df -h $1
           fi 

      [root@web1 ~]# vim disk.sh
      [root@web1 ~]# bash disk.sh /dev/sda3
      Filesystem      Size  Used Avail Use% Mounted on
      /dev/sda3       4.8G   11M  4.5G   1% /home
      [root@web1 ~]#

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

   脚本能够接受一个参数;

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

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

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

    #!bin/bash

    for i in $*;do
       if [ "$1" == "quit" ];then
          echo "quit"
          exit 0
       elif [ "$1" == "yes" ];then
          echo "running"
       else
          echo "wrong" 
          exit 3
        fi

      done
      
      
    测试:
    [root@web1 ~]# bash run.sh yes
    running
    [root@web1 ~]# bash run.sh quit
    quit
    [root@web1 ~]# bash run.sh ooooo
    wrong
    [root@web1 ~]#

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

    fo i in {gzip,bzip2,xz};do
       if [ "$1" == gzip ];then
          tar -z /etc /backups/etc-20160613.tar.gz
       elif [ "$1" == bzip ];then
          tar -j /etc /backups/etc-20160613.tar.bz2
       elif [ "$i" == xz ];then
          tar -J /etc /backups/etc-20160613.tar.xz
       else 
          echo "wrong"
         exit 4
         fi
       done

    测试:
    [root@web1 practice-script]# bash -n pr.sh
    [root@web1 practice-script]# bash pr.sh
    wrong
    [root@web1 practice-script]#

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

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

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

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

   (4) 其它为无法判断;

    #!bin/bash

    if [ -f $1 ];then
       echo "visit normal"
    elif [ -d $1 ];then
       echo "can use cd"
    elif [ -l $1 ];then
      echo "is a path"
    else
      echo "wrong"
      fi


    测试:
    [root@web1 practice-script]# bash vi.sh /etc/fstab
    visit normal
    [root@web1 practice-script]#

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

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

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

    #!bin/bash

    for i in $(hostname); do
       if [ -z "$i" -o "$i" == "localhost" -o "$i" == "(none)" ]; then
               hostname mail.magedu.com
            else
               echo "$i"
              fi
          done

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

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

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

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

     #!bin/bash

     if [ `id -u $1` -eq 0 ];then
        echo "administion"
        fi
     if [ `id -u $1` -gt 0 -a `id -u $1` -lt 500 ];then
        echo "sysuser"
     else 
        echo "common user"
        fi

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

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

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

    if [ `id -u $1 /etc/passwd` -ge 500 ];then
     if [ `cut -d: -f7 /etc/passwd | grep "sh$"` == sh ] ;then
       echo "a user can log system"
       fi
    else
      echo "can't login"
      fi

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

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

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

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

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

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

    #!bin/bash

    file=/var/log/*
    mkdir /tmp/test1-testn

    for i in `ls -l /var/log/ | cut -d' ' -f1`; do
       if [ "$i" == "^d*$" ]; then
         cp -r $file /tmp/test1-testn
       elif [ "$i" == "^-*$" ]; then
         cp $file /tmp/test1-testn
       elif [ "$i" == "^l*$" ]; then
         cp -d $file /tmp/test1-testn
       else
         cp -a $file /tmp/test1-testn
         fi
       done

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

(0)
mississippimississippi
上一篇 2016-09-10
下一篇 2016-09-10

相关推荐

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

    4、写一个脚本   (1) 能接受四个参数:start, stop, restart, status    start: 输出“starting 脚本名 finished.”    …   (2) 其它任意参数,均报错退出;     #!bin/b…

    学员作品 2016-12-05
  • RAID与磁盘管理

    1、创建一个10G分区,并格式为ext4文件系统; [root@localhost ~]# fdisk /dev/sda 欢迎使用 fdisk (util-linux 2.23.2)。 更改将停留在内存中,直到您决定将更改写入磁盘。 使用写入命令前请三思。 命令(输入 m 获取帮…

    学员作品 2016-08-22
  • vim编辑器

    一、vim简介    vi: Visual Interface,文本编辑器     文本: ASCII, Unicode     文本编辑种类:         行编辑器: sed…

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

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

    学员作品 2016-09-15
  • 文本处理工具sed及文本编辑器vim课程作业

    文本处理工具sed课程作业     1、删除/etc/grub2.conf文件中所有以空白开头的行行首的空白字符         sed -n 's@^[[:space:]]\+@@p' /etc/grub2.cfg &…

    学员作品 2016-08-10
  • sed 流编辑器 练习

    8-9 sed 练习 1、删除/etc/grub2.conf文件中所有以空白开头的行行首的 空白字符 sed 's@^[[:space:]]@@g' /etc/grub2.conf  2、删除/etc/fstab文件中所有以#开头,后面至少跟一个空 白字符的行的行首的#和空白字符 sed 's@^#[[:space:]]\{1…

    学员作品 2016-08-10