马哥教育网络班21期-第九周课程练习

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

#!/bin/bash
#
declare -i login_user=0
declare -i nologin_user=0
while read line ;do
  login_shell=$(echo $line | awk -F: '{print $7}')
  if [ $login_shell == '/sbin/nologin' ];then
    let nologin_user++
  else
    let login_user++
  fi
done < /etc/passwd
echo "nologin user have $nologin_user"
echo "login user have $login_user"

2、写一个脚本

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

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

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

#!/bin/bash
#
hostname=$(hostname)
if [ $hostname == 'localhost' ];then
   `hostname www.magedu.com`
else
  echo $hostname
fi

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

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

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

#!/bin/bash
#
if [ $# -ne 1 ];then
  echo "Usage: $0 dev_path"
  exit
fi
for list in $(ls /dev);do
  if [[ $1 = /dev/$list ]];then
    fdisk -l $1
  fi
done

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

   脚本能够接受一个参数;

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

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

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

#!/bin/bash
#
if [ $# -ne 1 ];then
  echo "Usage: $0 argument"
  exit
fi
case $1 in
  quit)
    exit ;;
  yes)
    echo "script will continue" ;;
  *)
    echo "execute abnormal"
    exit 11 ;;
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
#
while [ $# -eq 1 ];do
  case $1 in
    gzip)
     tar cfvz /backups/etc-20160613.tar.gz /etc
     exit
    ;;
    bzip2)
     tar cfjv /backups/etc-20160613.tar.bz2 /etc
     exit
    ;;
    xz)
     tar cfJv /backups/etc-20160613.tar.xz /etc
     exit
    ;;
    *)
     echo "the compression tool is wrong"
     exit 11
    ;;
  esac
done

   

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

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

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

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

   (4) 其它为无法判断;

#!/bin/bash
#
read -p "pls input a path:"  var
if [ -z "$var" ];then
  echo "Usage: $0 file_path"
  exit
fi
if [ -f $var ];then
  echo "$var is a normal file,you can access"
elif [ -d $var ];then
  echo "$var is a Directory,you can use cd command"
elif [ -L $var ];then
  echo "$var is a softlink to a access path"
else
  echo "unknown file"
fi

   

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

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

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

#!/bin/bash
#
pc=$(hostname)
if  [ -z "$pc" -o  "$pc" == localhost ];then
  hostname mail.magedu.com
elif [ "$pc" == "none" ];then
  hostname mail.magedu.com
else
  echo $pc
fi

   

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

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

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

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

#!/bin/bash
#
read -p "pls input a username: "  user
if ! id $user &> /dev/null ;then
  echo "$user is not exist"
  exit 11
fi
uid=$(id -u $user)
if  [ $uid -eq 0 ];then
  echo "$user is a administrator"
elif [ $uid -gt 0 -a $uid -lt 500 ];then
  echo "$user is system user"
else
  echo "$user is a common user"
fi

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

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

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

#!/bin/bash
#
if [ $# -ne 1 ];then
  echo "Usage: $0 username"
  exit 11
fi
if ! id $1 &> /dev/null;then
  echo "$1 is not exist"
  exit 12
fi
if [ $(id -u $1) -ge 500 ] && awk -F: '/sh$/{print $7}' /etc/passwd &> /dev/null;then
  echo " user $1 can login system "
else
  echo "user $1 can't login system"
fi

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

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

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

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

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

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

#!/bin/bash
#
dir_path="/var/log"
bak_path="/tmp/test"
declare -i num=1
for list in $(ls $dir_path);do
  cd $dir_path
  mkdir $bak_path$num
  if [ -d $list ];then
    cp -r $list $bak_path$num/$list
  elif [ -f $list ];then
    cp $list $bak_path$num/$list
  elif [ -L $list ];then
    cp -d $list $bak_path$num/$list
  else
    cp -a $list $bak_path$num/$list
  fi
  let num++
done

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

(0)
上一篇 2016-09-15 22:21
下一篇 2016-09-15 22:22

相关推荐

  • RPM和YUM的使用说明

    一、RPM包管理程序 centos系统上使用rpm命令管理程序包: 安装、卸载、升级、查询、校验、数据库维护 RPM包安装选项:   –test:测试安装,但不真正执行安装   –nodeps:忽略依赖关系   –nosignature:不检查来源合法性   –nodig…

    Linux干货 2016-08-24
  • TCP/IP

    TCP/IP协议族     互联网协议族(英语:Internet Protocol Suite,缩写IPS)是一个网络通信模型,以及一整个网络传输协议家族,为互联网的基础通信架构。它常被通称为TCP/IP协议族(英语:TCP/IP Protocol Suite,或TCP/IP Protocols),简称TCP/IP。因为该协议家…

    Linux干货 2017-06-26
  • Ansible浅谈

    ansible特性:         模块化,调用特定的模块,完成特定的任务;         基于Python语言实现,由Paramiko、PyYAML和Jinja2三个关键模块;         部署简单,agentless; &nbs…

    Linux干货 2016-12-15
  • vim编辑器总结与操作练习

    一、VIM总结如下: 模式化的编辑器 1、三种基本模式:     编辑模式(命令模式)     输入模式(插入模式)    末行模式:内置的命令行接口 2、如何使用VIM打开文件,编辑文件     打开文件:     #vim  【options】【file】     +n;打开文件后直接让光标处于第n行的行首     +/PATTERN:打开文件后,直接让…

    2017-11-29
  • 路由配置注意事项

    路由配置注意事项 在把linux主机当做路由的时候,切记把转发功能打开,防火墙关闭,否则到头来一场空。 红脸主机: 黄脸主机: 路由A: [root@localhost network-scripts]# ip route 192.168.240.0/24 via 10.0.0.11 dev eth1 172.16.0.0/16 dev eth0 proto…

    2017-05-03
  • 马哥教育网络19期+第五周练习博客

    1、显示/boot/grub/grub.conf中以至少一个空白字符开头的行;   grep "^[[:space:]]\+.*" /boot/grub/grub.conf 2、显示/etc/rc.d/rc.sysinit文件中以#开头,后面跟至少一个空白字符,而后又有至少一个非空白字符的行; &n…

    Linux干货 2016-06-19

评论列表(1条)

  • 马哥教育
    马哥教育 2016-09-19 18:12

    写脚本的时候不要使用系统的函数名作为变量名,切记