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

相关推荐

  • 文件权限特殊管理之ACL

    ACL:access control list 权限访问列表 应用范围:所属主和所属组和其他用户之外的他叔用户 ACL是Linux系统权限额外支持的一项功能,需要文件系统的支持,例如:ReiserFS , EXT2 , EXT3 , EXT4 , JFS , XFS等都支持ACL功能 centos7 中:安装系统分区和装完系统之后自己手动添加的分区自动支持a…

    Linux干货 2016-08-05
  • inode的理解

    一、inode是什么 理解inode,要从文件储存说起。 文件储存在硬盘上,硬盘的最小存储单位叫做"扇区"(Sector)。每个扇区储存512字节(相当于0.5KB)。 操作系统读取硬盘的时候,不会一个个扇区地读取,这样效率太低,而是一次性连续读取多个扇区,即一次性读取一个"块"(block)。这种由多个扇区组成的&q…

    Linux干货 2017-01-16
  • Elasticsearch 5.0 集群

    IT运维 www.chinasa.net 下载地址:https://www.elastic.co/downloads/elasticsearch 1、JDK 安装略过 node1 部署 2、Elasticsearch安装 #tar zxvf elasticsearch-5.0.0.tar.gz -C /opt/ #cd /opt #mv elast…

    系统运维 2016-12-27
  • 开学第一天

      今天是我来到马哥教育的第一天,来之前心情非常之忐忑,因为没有接触过linux系统,感觉是个新事物,来到教室里,一百多人的大集体,年龄的差异,使我感觉到压力。首先马哥和张sir的讲话,非常的帮,其中令我记忆最深刻的是那句话,取上者得中,取中者得下。一个人在奋斗的时候如果给自己的目标定的低,那就收获的还要低。所以要高标准的要求自己,一开始给自己定一…

    Linux干货 2018-03-26
  • MySQL复制

    目录: 1.备份与恢复 2.主从复制 3.主主复制 4.半同步复制 5.MHA 6.centos7搭建mariadb Galera集群 1.备份和恢复 备份工具:mysqldump+复制binlog xtrabackup (1) mysqldump+复制binlog 备份: mysqldump -E -R –triggers –master-data=2 –…

    2017-11-21
  • Linux系统网络属性管理之配置文件

        Linux有许多管理网络属性的命令但基本都是只能临时有效,想要永久有效就要更配其配置文件。现在,让我们来看看有哪些关于网络配置的配置文件。     配置文件: IP/NETMASK/GW/DNS等属性的配置文件/etc/sysconfig/network-scripts/ifcfg…

    Linux干货 2016-09-18

评论列表(1条)

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

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