N25-第九周作业

第九周

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

#!/bin/bash
#

sum_login=0
sum_nologin=0

for i in $(awk -F: '{print $7}' /etc/passwd);do
        if [ "$i" == "/sbin/nologin" ];then
                echo "user nologin."
                let sum1++
        else let sum2++
        fi
done
        echo "可登录用户数为:$sum_login,不可登录用户数为:$sum_nologin."

[root@zf scripts]# bash user_shell.sh 
user nologin.
user nologin.
....
user nologin.
user nologin.
可登录用户数为:33,不可登录用户数为:25.

2、写一个脚本 

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

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

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

#!/bin/bash
#

Hostname=$(hostname)

if [ "$Hostname" == "localhost" ];then
        hostname www.magedu.com
        echo "主机名已修改."
else hostname        
fi

[root@zf scripts]# hostname 
zf.localdomain
[root@zf scripts]# bash hostname.sh 
zf.localdomain
[root@zf scripts]# hostname localhost
[root@zf scripts]# bash hostname.sh  
主机名已修改.

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

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

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

#!/bin/bash
#
if [ $# -lt 1 ];then
    echo "请输入一磁盘路径"
    exit 1
fi    

if [ -b $1 ];then
        fdisk -l $1
        else echo "disk is not existed."
                exit 2
fi

[root@zf ~]# bash disk.sh /dev/sda

Disk /dev/sda: 21.5 GB, 21474836480 bytes
255 heads, 63 sectors/track, 2610 cylinders
Units = cylinders of 16065 * 512 = 8225280 bytes
Sector size (logical/physical): 512 bytes / 512 bytes
I/O size (minimum/optimal): 512 bytes / 512 bytes
Disk identifier: 0x00026079

   Device Boot      Start         End      Blocks   Id  System
/dev/sda1   *           1          39      307200   83  Linux
Partition 1 does not end on cylinder boundary.
/dev/sda2              39        1344    10485760   83  Linux
/dev/sda3            1344        1605     2097152   82  Linux swap / Solaris
/dev/sda4            1605        2610     8073689    5  Extended
/dev/sda5            1605        2610     8073657+  83  Linux

4、写一个脚本,完成如下功能 脚本能够接受一个参数;

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

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

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

#!/bin/bash
#

if [ $# -lt 1 ];then
        echo "请输入一个参数"
        exit 1
fi

if [ "$1" == "quit" ];then
        echo "退出脚本“"
        exit 0
elif [ "$1" == "yes" ];then
        echo "继续执行脚本"
else echo "输入错误"
        exit 2
fi

[root@zf ~]# bash quit.sh quit
退出脚本“
[root@zf ~]# bash quit.sh yes
继续执行脚本
[root@zf ~]# bash quit.sh y
输入错误

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 [ ! -d /backups ];then
    mkdir /backups
fi

if [ $# -lt 1 ];then
        echo "请输入一个参数"
        exit 1
fi

if [ "$1" == "gzip" ];then
        tar -zcf  /backups/etc-$(date +%Y%m%d).tar.gz  /etc
elif [ "$1" == "bzip2" ];then
        tar -jcf  /backups/etc-$(date +%Y%m%d).tar.bz2  /etc
elif [ "$1" == "xz" ];then
        tar -Jcf  /backups/etc-$(date +%Y%m%d).tar.xz  /etc
else echo "Input error."
         exit 2
fi

或
#!/bin/bash
#

if [ ! -d /backups ];then
        mkdir /backups
fi

if [ $# -lt 1 ];then
        echo "请输入一个参数"
        exit 1
fi

case $1 in
gzip)
        tar -zcf  /backups/etc-$(date +%Y%m%d).tar.gz  /etc
        ;;
bzip2)
        tar -jcf  /backups/etc-$(date +%Y%m%d).tar.bz2  /etc
        ;;
xz)
        tar -Jcf  /backups/etc-$(date +%Y%m%d).tar.xz  /etc
        ;;
*)
        echo "Input error."
        exit 2
        ;;
esac

[root@zf ~]# bash yasuo.sh gzip 
tar: 从成员名中删除开头的“/”
[root@zf ~]# bash yasuo.sh bzip2
tar: 从成员名中删除开头的“/”
[root@zf ~]# bash yasuo.sh xz   
tar: 从成员名中删除开头的“/”
[root@zf ~]# bash yasuo.sh jj
Input error.
[root@zf ~]# ls /backups
etc-20170307.tar.bz2  etc-20170307.tar.gz  etc-20170307.tar.xz

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

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

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

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

 (4) 其它为无法判断;

#!/bin/bash
#

if [ $# -lt 1 ];then
        echo "请传递一个路径参数."
fi

if [ -f $1 ];then
        echo "$1 可被正常访问."
elif [ -d $1 ];then
        echo "可对$1使用cd命令."
elif [ -L $1 ];then
        echo "$1 是访问路径."
else echo "无法判断."
fi

[root@zf ~]# bash  jiaoben.sh /etc/fstab   
/etc/fstab 可被正常访问.
[root@zf ~]# bash  jiaoben.sh /dev/dvd
/dev/dvd 是访问路径.
[root@zf ~]# bash  jiaoben.sh /dev/
可对/dev/使用cd命令.
[root@zf ~]# bash  jiaoben.sh /dev/sda
无法判断.

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

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

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

#!/bin/bash
#

Hostname=$(hostname)

if [ -z "$Hostname" -o "$Hostname" == "localhost" -o "$Hostname" == "(none)" ];then
        hostname mail.magedu.com
        echo "主机名已修改."
else  hostname
fi

[root@zf ~]# hostname 
zf.localdomain
[root@zf ~]# bash  hostname.sh      
zf.localdomain
[root@zf ~]# hostname localhost
[root@zf ~]# bash  hostname.sh         
主机名已修改.
[root@zf ~]# hostname "(none)"         
[root@zf ~]# bash  hostname.sh 
主机名已修改.

原创文章,作者:N25-深圳-寻觅,如若转载,请注明出处:http://www.178linux.com/70912

(0)
N25-深圳-寻觅N25-深圳-寻觅
上一篇 2017-03-10 15:22
下一篇 2017-03-10 17:03

相关推荐

  • 使用NFS和Samba文件服务搭建博客站点

    使用NFS和Samba文件服务搭建博客站点 实验目的:分别使用NFS和Smaba文件服务实现wordpress 实验要求: (1) server导出/data/application/web,在目录中提供wordpress; (2) client挂载nfs server导出的文件系统至/var/www/html;(3) 客户端1(lamp),部署w…

    2017-04-30
  • Linux磁盘管理

    一、磁盘管理总体分类  1)磁盘结构  2)分区类型  3)管理分区 4)管理文件系统  5)挂载设备 6)管理虚拟内存 ……………………………………………………………………………………………………………………… 重要分类模块详解 ………………………………………………………………………………………………………………………

    Linux干货 2016-08-29
  • CentOS多网卡单个ip和单个网卡多个ip的设置

    一、单个网卡设置一个IP地址     1.初始状态已添加一个网卡eth0,并设置的均为自动获取IP地址,如下图所示:网卡为eth0,ip地址为10.1.249.36;为了后续实验的顺利进行,我们把NetworkManager服务关闭     chkconfig NetworkMa…

    Linux干货 2016-09-06
  • Zabbix-3.2.3实现微信(WeChat)告警

    Zabbix-3.2.3实现微信(WeChat)告警 zabbix Zabbix可以通过多种方式把告警信息发送到指定人,常用的有邮件,短信报警方式,但是越来越多的企业开始使用zabbix结合微信作为主要的告警方式,这样可以及时有效的把告警信息推送到接收人,方便告警的及时处理。 关于邮件报警可以参考:Zabbix Web 邮件报警 一、微信企业号申请 地址: …

    2017-04-21
  • 推荐-使用iptables作为网络防火墙构建安全的网络环境

    使用iptables作为网络防火墙构建安全的网络环境 使用iptables作为网络防火墙构建安全的网络环境 前言 网络防火墙的优势 实验拓扑图 实验环境 实验步骤 防火墙未设置前对所有服务器的测试 针对不同服务器进行”非法”访问 定义网络防火墙规则 再次针对不同服务器进行”非法”访问 测试服务器是否可访问 总结 前言 一般情况下iptables只作为主机防火…

    Linux干货 2016-03-31
  • 8月4号作业

    正则表达式表示18位身份证号 egrep "\b[0-9]{17}(x|X|[0-9])\b" 正则表达式表示手机号 egrep "\b1[3,5,8,7][0-9]{9}\b" phone 正则表达式表示邮箱 grep -E "\b[[:alnum:]].*@[[:alnum:]]{2,3}.[[:alnu…

    Linux干货 2016-08-08

评论列表(1条)

  • 马哥教育
    马哥教育 2017-03-15 00:39

    赞,几个脚本的功能完成的不错~~给阅读者一种很舒服的感觉~~继续加油~