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

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

#!/bin/bash
#
declare -a loginuser
declare -i sum_login=0
declare -i sum_nologin=0
list=($(cat /etc/passwd |awk -F: '{print $NF}'))

for ((i=1;i<=${#list[*]};i++));do
   if [[ "${list[i]}" == "/sbin/nologin" ]];then
       let sum_nologin=$sum_nologin+1
   else [[ "${list[i]}" == "/bin/bash" ]]
       let sum_login=$sum_login+1
   fi
done
   echo "no login users is $sum_nologin"
   echo "login users is $sum_login"

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

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

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

#!/bin/bash
#
if [ $# -lt 1 ];then
   echo "Usage:`basename $0` devicename"
   exit 3
fi

if [ -e $1 ];then
   fdisk -l $1
else
   echo "Without this device"
fi

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

#!/bin/bash
#
read -p "Please input your choice:" option

while [[ $option == "yes" ]];do
   read -p "Please input your choice again:" option
done

if [[ $option == "quit" ]];then
   echo "Quit"
   exit 0
else
   echo "Error"
   exit 3
fi

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 [ $# -lt 1 ];then
   echo "Usage:`basename $0` {gzip|bzip2|xz}"
   exit 3
fi

if [ -d /backups ];then
   return
else
   mkdir /backups &>/dev/null
fi

case $1 in
gzip)
tar -zcvf /backups/etc-$(date "+%Y%m$d").tar.gz /etc
;;
bzip2)
tar -jcvf /backups/etc-$(date "+%Y%m$d").tar.bz2 /etc
;;
xz)
tar -Jcvf /backups/etc-$(date "+%Y%m$d").tar.xz /etc
;;
*)
echo "Unkown"
;;
esac

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

#!/bin/bash
#
if [ $# -lt 1 ];then
   echo "Usage:`basename $0` Path1"
   exit 3
fi

if [[ -f $1 ]];then
   echo "This is a common file"
elif [[ -d $1 ]];then
   echo "This is a directory."
elif [[ -L $1 ]];then
   echo "This is a Links file"
else
   echo "Unknow"
fi

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

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

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

#!/bin/bash
#
if [ $# -lt 1 ];then
   echo "Usage:`basename $0` USERNAME"
   exit 3
fi

if ! id -u $1 &>/dev/null ;then
   echo "User $1 is not exists."
else
   if [ `id -u $1` -eq 0 ];then
       echo "User $1 is admin user"
   elif [ `id -u $1` -lt 500 ];then
       echo "User $1 is system user"
   else
       echo "User $1 is common user"
   fi
fi

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

#!/bin/bash
#
if [ $# -lt 1 ];then
   echo "Usage:`basename $0` USERNAME"
   exit 3
fi

if ! id -u $1 &>/dev/null ;then
   echo "User $1 is not exists"
else
   if [ "`id -u $1`" -ge "500" -a "`cat /etc/passwd |grep $1 |grep -o  sh$`" == "sh" ];then
       echo "A user can log system"
   else
       echo "Can not login to the system"
   fi
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 i in $file;do
   if [ -d $i ];then
       cp -r $i /tmp/test1-testn
   elif [ -f $i ];then
       cp $i /tmp/test1-testn
   elif [ -L $i ];then
       cp -d $i /tmp/test1-testn
   else
       cp -a $i /tmp/test1-testn
   fi

done

原创文章,作者:N22-白蚁,如若转载,请注明出处:http://www.178linux.com/65482

(0)
N22-白蚁N22-白蚁
上一篇 2017-01-03 11:05
下一篇 2017-01-03 11:05

相关推荐

  • SSH会话劫持实现端口转发

    在进行渗透测试时,我们有时候会碰到搭建的测试环境、产品服务器、DMZ或者其他类似的机器群的情况,这时我们完全可以把它们看作跳板。这些系统被设计成对外交互的接口,这时候我们考虑对其他域里的用户进行SSH会话劫持是个不错的选择。 那么如果你拥有了某一个跳板的控制权限,想要通过另一个域的用户对远程域进行访问会怎么办呢?当然,这时候你是没有密码、密钥的,你不能抛弃二…

    系统运维 2015-03-23
  • 计算机基础第一部分

    ** 第一课:计算机基础知识** 第一章计算机的组成 计算机是由硬件(Hardwaer)和软件(Software)来组成两大类,他是一台可以自由传输数据, 储存数据,娱乐,工作等等的智能设备。 第一节计算机硬件 主板架构图 内存====用来存储临时数据,弱点喜欢松动一般电脑黑屏都是他松动了,导致电脑不能机 基本上%80以上的电脑不能开机都是他出了问题,服务器…

    Linux干货 2017-05-19
  • 磁盘文件系统基础(一)

    磁盘的主要硬件单元有:     1、磁头:通过电磁感应的方式对磁盘数据进行读写。     2、磁道:在磁盘自传过程中磁头划过的圆形轨迹,这些轨迹是肉眼看不见的特色磁化区域。     3、扇区:磁盘上的每个磁道被等分为若干个圆弧,这些圆弧被称…

    Linux干货 2016-10-27
  • 使用sudo对用户进行权限管理

    使用sudo对用户进行权限管理 因为root用户权限太大,一般在实际应用的时候 ,为了避免造成错误泛滥和找不到责任人都需要对使用服务器人员进行权限分配,除了系统管理员外,其他人禁止使用root,但可以通过sudo命令,给自己提权。同时通过日志审计进行监控操作,操作如下: 1.禁止普通用户使用su命令到root # usermod -g wheel user0…

    Linux干货 2017-03-26
  • Linux 的shell脚本编程

    shell脚本编程 程序:指令+数据 程序编辑风格:             过程式:以指令为中心,数据服务于指令             对象式:以数据为中心,指令服务于数据 shell程序:提供了编程能力,解释执行 计算机:运行二进制指…

    Linux干货 2016-08-15
  • 02day-Linux基础入门及简单的命令了解

    Linux哲学思想: 1、一切皆文件;          把几乎所有资源,包括硬件设备都组织为文件格式; 2、由众多单一目的小程序组成;一个程序只实现一个功能,而且要做好;          组合小程…

    Linux干货 2016-06-29

评论列表(1条)

  • 马哥教育
    马哥教育 2017-01-04 16:08

    脚本写的很棒,排版也很漂亮,但是注意,不要使用系统的命令来作为变量名,加油