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

相关推荐

  • Centos6系统救援模式

    CentOS 6系统救援模式 在学习了CentOS 5、6系统启动流程与启动故障排除之后,为了加深印象进行了如下破坏性尝试。 删除/boot目录与/etc/fstab文件后尝试修复系统 1. 首先是第一步删除/boot目录与/etc/fstab 删除/boot /etc/fstab 可以看到虽然boot目录无法删除但是目录中的文件已经全部删掉了。 2. 重新…

    Linux干货 2016-11-24
  • Linux文件系统管理

    Linux文件系统: ext2, ext3, ext4, xfs, btrfs, reiserfs, jfs, swap swap: 交换分区(虚拟内存) 光盘: iso9660       windows: fat32, NTFS       Unix: FFS, U…

    Linux干货 2016-08-15
  • 第二周:文件管理练习

    1.Linux上的文件管理类命令都有哪些,其常用的使用方法及其相关示例演示 目录管理管理类命令 mkdir make directories mkdir [OPTION]… DIRECTORY… 注意:路径基名作为命令的作用对象时,基名之前的路径必须要存在;     -p:自动按需创建父目录…

    Linux干货 2016-09-23
  • 马哥linux0805作业内容

    在/date/testdir/里穿件的新文件自动属于g1组,组g2的成员如:alice能对这些新文件有读写权限,组g3的成员如:tom只能对新文件有读权限,其他用户(不属于g1,g2,g3)不能访问这个文件夹 设置user1,使之新建文件权限为rw——- 3.设置/testdir/f1的权限,使user1用户不可以读写执行,g1组可以…

    Linux干货 2016-08-11
  • 马哥教育网络班22期-第4周博客作业

    1、复制/etc/skel目录为/home/tuser1,要求/home/tuser1及其内部文件的属组和其它用户均没有任何访问权限。 [root@zck ~]# cp -r /etc/skel /home/tuser1 [root@zck ~]# ll -d /hom…

    Linux干货 2016-09-02
  • Week5 grep和find命令及正则表达式练习

    1、显示当前系统上root、fedora或user1用户的默认shell;   cat /etc/passwd  | grep -E "^\<root\>|^\<fedora\>|^\<\user1\>" |&nb…

    Linux干货 2017-02-14

评论列表(1条)

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

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