N26-第九周

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

#!/bin/bash
#
#
#
NUM1=0
NUM2=0
for i in `cut -d: -f7 /etc/passwd` ;do
        if [[ "$i" = '/bin/bash' ]];then
        let NUM1+=1
        else
        let NUM2+=1
        fi
done
echo " default shell is '/bin/bash' number is $NUM1"" default shell is not '/bin/bash' number is $NUM2" 

2、写一个脚本

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

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

    

#!/bin/bash
#
#
#
hostname=$HOSTNAME
  [[ ! "$hostname" == 'localhost' ]] && echo $hostname || hostname www.magedu.com

3、写一个脚本,完成如下功能
    (1) 传递一个磁盘设备文件路径给脚本,判断此设备是否存在;

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

#!/bin/bash
#
#
#
[[ $# -ne 1  ]] && echo "use $0 arg" && exit
[ -b $1 ]&& fdisk -l $1 || echo "$1 is not exist"
~ 

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

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

[[ $# -ne 1  ]] && echo "use $0 arg" && exit
case $1 in
        quit)
        exit 0
        ;;
        yes)
        echo "use $0 again"
        break
        ;;
        *)
        exit 2
        ;;
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
#
#
#
[[ $# -ne 1  ]] && echo "use $0 gzip or bzip2 or xz" && exit
case $1 in
        gzip)
        tar -Pczf /backups/etc-20160613.tar.gz /etc & >/dev/null
        ;;
        bzip2)
        tar -Pcjf /backups/etc-20160613.tar.bz2 /etc & >/dev/null
        ;;
        xz)
        tar -PcJf /backups/etc-20160613.tar.xz /etc & >/dev/null
        ;;
        *)
        echo "error" 
        exit 2
        ;;
esac

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

   (4) 其它为无法判断;

#!/bin/bash
#
#
#

[[ $# -ne 1  ]] && echo "use $0 arg" && exit

if [ -d $1 ];then
        echo "$1 is a directory "
elif [ -f $1 ];then
        echo "$1 is a ordinary file"
elif [ -l $1 ];then
        echo "$1 is a link file"
else
        echo "unknown"

fi

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

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

#!/bin/bash
#
#
#

hostname1=${HOSTNAME:-"mail.magedu.com"}
[[ $hostname1 = "mail.magedu.com" ]]&& echo $hostname1 && exit
if [[ $hostname1 = "localhost" ]] ;then
        hostname "mail.magedulcom"
elif [[ $hostname1 = "(none)" ]];then
        hostname "mail.magedu.com"
else
        echo $hostname1
fi                      

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

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

#!/bin/bash
#
#
#
[[ $# -ne 1 ]]&& echo "use $0 username" && exit
if ! id  $1 &> /dev/null ;then
        echo "$1 is not a username"
fi
NUM=`id -u $1`
if [[ $NUM -eq 0 ]];then
        echo "$1 is a administrator"
elif [[ $NUM -gt 0 ]]&& [[  $NUM  -le 500 ]]; then
        echo "$1 is a system user"
else
        echo "$1 is a ordinary user"
fi

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

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

#!/bin/bash
#
#
#
[[ $# -ne 1 ]] && echo "use $1 username " && exit 2
if ! id $1 &> /dev/null ;then
echo "$1 is not a username"
fi
NUM=`id -u $1`
if [[ $NUM -ge 500 ]]&& grep "$1.*sh$" /etc/passwd ;then
        echo "$1 can log system"
else
        echo "$1 can not log system"
fi

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

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

#!/bin/bash###for i in `ls /var/log/`;do        if [[ -d /var/log/$i ]];then        cp -r /var/log/$i /tmp/test1-testn        elif [[ -f /var/log/$i ]];then        cp /var/log/$i /tmp/test1-testn        elif [[ -L /var/log/$i ]] ;then        cp -d /var/log/$i /tmp/test1-testn        else        cp -a /var/log/$i /tmp/test1-testn        fidone

原创文章,作者:胡安慧,如若转载,请注明出处:http://www.178linux.com/70808

(0)
胡安慧胡安慧
上一篇 2017-03-15 14:25
下一篇 2017-03-15

相关推荐

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

    计算机的组成及其功能 计算机主要由五大部分组成:控制器、运算器、存储器、输入设备、输出设备,即CPU(控制器、运算器)、内存、I/O(输入/输出设备)。 控制器 是整个计算机的中枢神经,其功能是对程序规定的控制信息进行解释,根据其要求进行控制,调度程序、数据、地址,协调计算机各部分工作及内存与外设的访问等。 运算器 对数据进行各种算术运算和逻辑运算,即对数据…

    Linux干货 2016-08-15
  • mkdir用法实践

    mkdir:make directories mkdir [OPTION]… DIRECTORY… -p: 自动按需创建父目录; -v: verbose,显示详细过程; -m MODE:直接给定权限;   1、创建/tmp目录下的:a_c,a_d, b_c, b_d ~]# mkdir -v /tmp/{a,b}_{c,d}…

    Linux干货 2016-11-06
  • Linux进程及作业控制

    inux进程 进程的概念 当一个系统启动时,刚开机是第一个运行的是内核代码!先把内核放到cpu上运行,等内核控制和掌管了一切,有内核启动进程!然后创建第一个进程 init进程  内核空间 用户空间也都已被创建成功!后期的一切管理工作都由init来负责 init不能代表系统完成一些内核特权的执行!但由他负责向内核提交 他…

    Linux干货 2016-09-10
  • 网络概念简述和Linux网络管理命令

    网络概念简述和Linux网络管理命令 1. 网络分类 我们通常接触到的网络通常是广域网、局域网 局域网(Local Area Network,LAN)是指在某一区域内由多台计算机互联成的计算机组。 广域网(Wide Area Network,WAN):网络跨越国界、洲界,甚至全球范围。  因特网(Internet)是世界范围内最大的广域网。 2. …

    Linux干货 2016-04-19
  • Linux 2.6.39-rc3的一个插曲

    2011年4月12日,Linux 2.6.39-rc3发布了,Linus Torvalds写了一个发布邮件,其中包含了一个长长的为这个版本做过贡献的人员名单,这个名单中有很多看上去应该是中国人的名字,我挺为他们感到骄傲的(不知道你是否还记得以前本站的”Linux是由谁写的“)。 不过,没过一会,发现了一个bug,经过大家的调查(2.6.38版没有发现这个问题…

    Linux干货 2016-06-09
  • Iptables入门到进阶

    Iptables入门到进阶 一、前言 Firewall(防火墙): 隔离工具;Packets Filter Firewall(包过滤防火墙);工作于主机或网络的边缘,对经由的报文根据预先定义的规则(匹配条件)进行检测,对于能够被规则匹配到的报文实行某预定义的处理机制的一套组件; 防火墙类型 从防火墙的实现形式来分的话,防火墙可以分为软件防火墙和硬件防火墙 硬…

    Linux干货 2017-02-11

评论列表(1条)

  • 马哥教育
    马哥教育 2017-03-30 14:26

    可以看出脚本运用的已经比较熟练了, 再接再励。