9.脚本练习

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

 declare -a shell
    declare sum_login=0
    declare sum_nologin=0
    shell=($(cat /etc/passwd cut -d: -f7))
    for((i=0;i<${#shell[*]};i++));do
       if [  "${shell[i]}" "/sbin/nologin" ];then
             sum_login=$[$sum_login+1]
          else
             sum_nologin=$[$sum_nologin+1]
       fi
   
    done
    echo "nologin users is $sum_nologin."
    echo "login users is $sum_login."

2、写一个脚本
(1) 获取当前主机的主机名,保存于hostname变量中;
(2) 判断此变量的值是否为localhost,如果是,则将当前主机名修改为www.magedu.com;
(3) 否则,则显示当前主机名;

#!/bin/bash
     hostname=$(cat /etc/sysconfig/network | grep HOSTNAME | cut -d= -f2)
     if "$hostname" "localhost" ];then
       sed -i "s/localhost/www.magedu.com/g"  /etc/sysconfig/network
     else
       echo $(hostname)
     fi

3、写一个脚本,完成如下功能
(1) 传递一个磁盘设备文件路径给脚本,判断此设备是否存在;
(2) 如果存在,则显示此设备上的所有分区信息;

 

#!/bin/bash
      fdisk -l $1 &> /dev/null;
      if [ $? -eq 0 ];then
         fdisk -l $1
       else
          echo "fisk is not found!"
      fi

4、写一个脚本,完成如下功能
脚本能够接受一个参数;
(1) 如果参数1为quit,则显示退出脚本,并执行正常退出;
(2) 如果参数1为yes,则显示继续执行脚本;
(3) 否则,参数1为其它任意值,均执行非正常退出;

 

case "$1" in
    "yes")
            echo "running...."
            ;;
    "quit"echo "quit"
            exit 0
            ;;
    "*")
            echo "break"
            exit 1
            ;;
 esac

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 [ $# -eq 1 ];then
        case $1 in
            "gzip")
                tar -zcf /backup/etc-`date +%F`.tar.gz /etc/* ;;
            "bzip2")
                tar -jcf /backup/etc-`date +%F`.tar.gz /etc/* ;;
            "xz")
                tar -Jcf /backup/etc-`date +%F`.tar.gz /etc/* ;;
            *)
                echo -e "Error Pack Tool \nUsage: $0 gzip|bzip2|xz "
                exit 1 ;;
        esac
      else
        echo -e "Parameters Error \nUsage: $0 gzip|bzip2|xz"
    fi

6、写一个脚本,接受一个路径参数:
(1) 如果为普通文件,则说明其可被正常访问;
(2) 如果是目录文件,则说明可对其使用cd命令;
(3) 如果为符号链接文件,则说明是个访问路径;
(4) 其它为无法判断;
#!/bin/bash

if [ $# -eq 1 ];then
        if [ -f $1 ];then
            echo "$1 is file"
        elif [ -d $1 ];then
            echo "$1 is directory "
        elif [ -L $1 ];then
            echo "$1 is  symlink file"
        else
            echo "Can't file $1 type"
        fi
      else
        echo -e "Parameter Error!"
      fi

7、写一个脚本,取得当前主机的主机名,判断
(1) 如果主机名为空或为localhost,或为””(none)””,则将其命名为mail.magedu.com;
(2) 否则,显示现有的主机名即可;

 

#!/bin/bash
     hostname=$(cat /etc/sysconfig/network | grep HOSTNAME | cut -d= -f2)
     if "$hostname" "none" -o "$hostname" "" ];then
       sed -i "s/localhost/www.magedu.com/g"  /etc/sysconfig/network
     else
       echo $(hostname)
     fi

8、写一脚本,接受一个用户名为参数;
(1) 如果用户的id号为0,则显示其为管理员;
(2) 如果用户的id号大于0且小于500, 则显示其为系统用户;
(3) 否则,则显示其为普通用户;

id $1 &> /dev/null
result=$(id -u $1)
if [ $result -eq 0 ];then
    echo "system admin"
 elif [ $result -ge 1  -a $result -le 500 ];then
    echo "system user"
 else
     echo "common user"
fi

10、写一个脚本,传递一个用户名参数给脚本;
(1) 如果用户的id号大于等于500,且其默认shell为以sh结尾的字符串,则显示“a user can log system.”类的字符串;
(2) 否则,则显示无法登录系统;

#!/bin/bash
result=$(id -u $1)
if [ $result -ge 500 ];then
    shell=$(cat /etc/passwd grep "$result" cut -d: -f7)
    echo "$shell" grep "sh$"
    shell_result=$?
    if [ $shell_result -eq 0 ];then
        echo "a user can log system."
       else
        echo "user $1 nologin system."
    fi
  else
   echo "user id less than 500."
         
fi

11、写一个脚本,完成如下任务 :
(1) 按顺序分别复制/var/log目录下的每个直接文件或子目录至/tmp/test1-testn目录中;
(2) 复制目录时,才使用cp -r命令;
(3) 复制文件时使用cp命令;
(4) 复制链接文件时使用cp -d命令;
(5) 余下的所有类型,使用cp -a命令;

 

#!/bin/bash
 
      file=/var/log/*
      for in $file;do
              if [ -f $i ];then
                      echo "$i is common file"
                      cp $i /tmp/test1-testn/
              elif [ -L $i ];then
                      echo "$i is link file"
                      cp -d $i /tmp/test1-testn/
              elif [ -d $i ];then
                      echo "$i is directory"
                      cp -r $i /tmp/test1-testn
              else
                      echo "$i is other file"
                      cp -a $i /tmp/test1-testn
              fi
      done

本文来自投稿,不代表Linux运维部落立场,如若转载,请注明出处:http://www.178linux.com/87432

(0)
N27_jiangyefanN27_jiangyefan
上一篇 2017-09-19 16:22
下一篇 2017-09-20 00:07

相关推荐

  • 无插件Vim编程技巧

    相信大家看过《简明Vim教程》也玩了《Vim大冒险》的游戏了,相信大家对Vim都有一个好的入门了。我在这里把我日常用Vim编程的一些技巧列出来给大家看看,希望对大家有用,另外,也是一个抛砖引玉的过程,也希望大家把你们的技巧跟贴一下,我会更新到这篇文章中。另外,这篇文章里的这些技巧全都是vim原生态的,不需要你安装什么插件。我的Vim的版本是7.2。 浏览代码…

    Linux干货 2015-04-01
  • 单引号、双引号和反引号使用方法

        首先向马哥和马哥团队敬个礼,谢谢你们带我进入Linux的世界,刚开始接触linux时,经常看到单引号、双引号和反引号特殊符号,经常搞混淆和误用,应该用双引号,有时用到单引号。经过几天的混乱引用,总算搞明白了一些,简单总一下三者的使用和区别。  单引号 ‘’     单引号里的内容全部以普通字符的含义进…

    Linux干货 2015-07-29
  • python Django分页

    自定义html_helper.py  —>  Page_helper类 #coding:utf-8 from django.utils.safestring import mark_safe class Page_Helper(object):    …

    Linux干货 2016-08-22
  • 网络班21期第四周作业

    1、复制/etc/skel目录为/home/tuser1,要求/home/tuser1及其内部文件的属组和其它用户均没有任何访问权限。          mkdir /home/tuser1        &n…

    Linux干货 2016-08-22
  • LAMP+logzilla+sphinx+syslog-ng实现集中日志管理(第一版)[原创]

    一、前言        目前查看系统日志比较被动,遇到系统不正常或故障时才会主动去检查服务器系统日志,这样一来不能及时了解系统的运行情况,因此部署Logzilla+sphine+syslog-ng来弥补这不足。以下为安装、部署平台详细步骤。(Logzilla是什么新东西?其实前身就是php-syslog-ng,引用作者…

    Linux干货 2015-03-27
  • Bash Shell编程初学基础篇之二

    Bash Shell编程初学基础篇之二    时间如白驹过隙,一晃过去了几周,一切的计划都没有变化快。当你制定计划实施时,在这期间却会发生许多打乱我们计划的事情,但是我们还是要坚持下去,胜利是属于坚持到最后的人!实践出真理,中级基本结束了,需要回过头了好好总结一下了。心中总有好多话想找个同行唠唠;不废话了,估计大家都烦了!总有一天,你会成…

    Linux干货 2015-05-11