N25-第九周

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

#!/bin/bash
#统计shell及非shell个数
#author:dodo
declare -i loginnum=0
declare -i nologinnum=0

while read line;do
        if [[ "${line}" =~ "/sbin/nologin" ]];then
                let nologinnum++
        else
                let loginnum++
        fi
done < /etc/passwd

echo "可登录shell用户数: $loginnum"
echo "非登陆sheel用户数: $nologinnum"

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

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

#!/bin/bash
hostname=`hostname`
if [[ ${hostname} == 'localhost' ]];then
        hostname www.magedu.com
    else
        echo ${hostname}
fi

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

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

#!/bin/bash
#显示磁盘分区信息
#author:dodo

if [[ $1 != /dev/[sh]d[a-z]* ]];then
           echo "${1} 错误的磁盘设备!"
elif [ -e $1 ];then
           fdisk -l $1
else
        echo "${1} 该磁盘设备不存在!"
fi

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

#!/bin/bash
#判断
#author:dodo  

read -p "请输入一个参数:" num

while true;do
  case $num in
    quit)
      exit 0;;
    yes)    
      read -p "请继续输入一个参数:" num
      ;;
    *)
      exit 1;;
  esac
done

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
#判断
#author:dodo 
[ $# -lt 1 ] && echo "请输入一种压缩工具" && exit 1 
if [ ! -d /backups ];then 
mkdir /backups 
fi

case $1 in
    gzip)
            tar -zcvf /backups/etc-$(date +%Y%m%d).tar.gz /etc &> /dev/null
        ;;
   bzip2)
        tar -jcvf /backups/etc-$(date +%Y%m%d).tar.bz2 /etc &> /dev/null
            ;;
    xz)
            tar -Jcvf /backups/etc-$(date +%Y%m%d).tar.xz /etc &> /dev/null
*)
        echo "错误压缩工具!"
        exit 1
        ;;
esac

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

   (4) 其它为无法判断;

#!/bin/bash
#判断路径参数
#author:dodo
[ $# -lt 1 ] && echo -e "Usage: $0 DIRECTORY|FILE|LINKFILE" && exit 1

if [ -d $1 ];then
            echo "$1是一个目录文件,可以对其使用cd命令"
elif [ -L $1 ];then
            echo "$1是一个链接文件,链接的文件为$(ls -l $1 | cut -d ' ' -f 9,10,11)"
elif [ -f $1 ];then
            echo "$1是一个普通文件,可以正常访问"
else
        echo "无法判断此文件属性"
        exit 3
fi

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

#!/bin/bash
#判断主机名
#author:dodo
hostname=$(hostname)
    if [[ -z $hostname  || $hostname =~ [[:space:]]+ || $hostname =~ "localhost" || $hostname == "none" ]];then
        hostname "mail.magedu.com" && hostname
else
        hostname
fi


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

(0)
lyj821202lyj821202
上一篇 2017-05-27
下一篇 2017-05-27

相关推荐

  • linux高级文件系统管理

    磁盘配额:         (1)如果存放的文件空间不足,虽然分区后不能直接扩容,但是可以迁移,下面以/home目录示例: 1、新建分区,同步分区表 /dev/sda62、mkfs.ext4 /dev/sda6             &n…

    Linux干货 2017-03-14
  • 制作python模块安装包[原创]

     python的第三方模块越来越丰富,涉及的领域也非常广,如科学计算、图片处理、web应用、GUI开发等。当然也可以将自己写的模块进行打包或发布。一简单的方法是将你的类包直接copy到python的lib目录,但此方式不便于管理与维护,存在多个python版本时会非常混乱。现介绍如何编写setup.py来对一个简单的python模块进行打包。 一、…

    Linux干货 2015-03-27
  • 计算机的组成及其功能

        计算机是一种能接受和存储信息,并按照存储在其内部的程序对输入的信息进行加工、处理,然后把处理结果输出的高度自动化的电子设备。计算机是由运算器,控制器,存储器,输入装置和输出装置五大部件组成,每一部件分别按要求执行特定的基本功能。如下图所示: (1)  运算器或称算术逻辑单元(Arithmetical and Logica…

    Linux干货 2016-10-30
  • 内核参数修改 内核编译 第14天

    Linux内核:单内核,模块化 内核的某些模块 编译进内核本体 [*] 编译成内核模块 [M] 不选择使用     [ ] 内核的组成部分 /boot/vmlinuz-VERSION /lib/modules/VERSION/ *.ko 模块间有可能有依赖关系 内核模块管理 lsmod:显…

    Linux干货 2016-01-18
  • 马哥教育网络19期+第十四周课程练习

    系统的INPUT和OUTPUT默认策略为DROP; 先把策略设置为DROP # iptables -t filter -P OUTPUT DROP # iptables -t filter -P INPUT DROP 1、限制本地主机的we…

    Linux干货 2016-08-22
  • VSFTPD+PAM+[基于文件虚拟用户认证 | 基于MYSQL虚拟用户认证]

    VSFTPD+PAM+[基于文件虚拟用户认证 | 基于MYSQL虚拟用户认证] VSFTPD+PAM+[基于文件虚拟用户认证 | 基于MYSQL虚拟用户认证] 一、实验环境 二、实验步骤 1、通过mysql数据库方式虚拟用户认证 1.1数据库配置 1.2FTP配置 1.3测试 2、通过文件方式进行虚拟用户认证 一、实验环境 CentOS 6.7+vsftpd…

    Linux干货 2016-04-18