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 19:09

相关推荐

  • linux 关于 AWK 解析

    关于awk awk是一个报告生成器,他拥有强大的文本格式化的能力。 其实我么可以利用awk命令将一些文本整理成我们想要的样子,比如把一些文本整理成“表”的样子。然后打印出来,至于格式化能力会举例出来,自然会明白。 awk是有Alfred Aho,Peter Weinberger好人Brian Kernighan 这三人创造的,awk由这三个人的姓氏的首个字母…

    2017-09-09
  • IO,用户与组管理,文件,目录权限管理

           文件统配匹配模式:元字符文件名通配符*匹配任意长度的任意字符[root@localhost ~]# ls /root/D*/root/Desktop  /root/Documents  /root/Downloads ?匹配单个任意字符[root@localhost ~]# …

    Linux干货 2016-08-05
  • iptables实验1

    Iptables 实验1 基于状态放行telnet, ftp, ssh, http, samba, icmp等服务; (1) 对本机的ping请求每分钟不得超出20个; (2) 每客户端对本机的ssh的并发连接数不得超过3个; (3) 本机的telnet服务仅允许工作时间内访问; 本机IP地址192.168.42.113 下面我们先放行所有入站状态为ESTA…

    Linux干货 2016-10-24
  • Hadoop hdfs 分布式文件系统

    Hadoop简介:一个分布式系统基础架构,由Apache基金会开发。用户可以在不了解分布式底层细节的情况下,开发分布式程序。充分利用集群的威力高速运算和存储。Hadoop实现了一个分布式文件系统(Hadoop Distributed File System),简称HDFS。HDFS有着高容错性的特点,并且设计用来部署在低廉的(low-cost)硬件…

    Linux干货 2015-08-05
  • Nginx 原理

    Web服务器处理并发连接请求的工作模型有以下几种方式: 1、单线程web服务器(Single-threaded web servers)此种架构方式中,web服务器一次处理一个请求,结束后读取并处理下一个请求。在某请求处理过程中,其它所有的请求将被忽略,因此,在并发请求较多的场景中将会出现严重的性能问题。(即一次只能处理一个请求) 2、多进程/多线…

    Linux干货 2017-05-07
  • MYSQL数据库基础教程

    一、数据库介绍 1.数据库管理系统的产生背景 (1)数据时代的到来要求对数据进行有效和安全的管理 涉及的数据量大 数据不随程序的结束而消失 数据被多个应用程序共享 大数据时代的到来 (2)传统文件系统管理上的缺陷要求改变数据管理方式 编写应用程序不方便 数据冗余不可避免 应用程序依赖性 不支持对文件的并发访问 数据间联系弱 难以按用户视图表示数据 无安全控制…

    Linux干货 2017-10-05

评论列表(1条)

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

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