Linux第九周总结

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

#!/bin/bash
#
login_user=0
nologin_user=0
for i in $(cat /etc/passwd | cut -d : -f 7);do
    if [ $i == "/sbin/nologin" ];then
        let nologin_user++
    else
        let login_user++
    fi
done
 
echo "login_user=$login_user, nologin_user=$nologin_user"

2、写一个脚本

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

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

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

#!/bin/bash
#
hostname=$(/bin/hostname)
if [ $hostname == "localhost" ];then
    hostname www.magedu.com
    echo "111"
else
    hostname
fi

 

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

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

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

#!/bin/bash
#
if [[ $1 =~ /dev/sd* ]];then
    for i in $1;do
        fdisk -l $i
    done
else
    echo "Not a disk device file"
fi

 

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

   脚本能够接受一个参数;

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

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

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

#!/bin/bash
#
cat <<EOF
    1.quit
    2.yes
EOF
 
read -p "Please enter (quit or yes):" name
 
case $name in
quit)
    echo "Sign out"
    exit
    ;;
yes)
    echo "Continue implementation"
    ;;
*)
    exit 2
    ;;
esac

 

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

   传递一个参数给脚本,此参数为gzipbzip2或者xz三者之一;

   (1) 如果参数1的值为gzip,则使用targzip归档压缩/etc目录至/backups目录中,并命名为/backups/etc-20160613.tar.gz

   (2) 如果参数1的值为bzip2,则使用tarbzip2归档压缩/etc目录至/backups目录中,并命名为/backups/etc-20160613.tar.bz2

   (3) 如果参数1的值为xz,则使用tarxz归档压缩/etc目录至/backups目录中,并命名为/backups/etc-20160613.tar.xz

   (4) 其它任意值,则显示错误压缩工具,并执行非正常退出;

#!/bin/bash
#
cat <<EOF
    1.gzip
    2.bzip2
    3.xz
EOF
 
read -p "Please enter (gzip or bzip2 or xz):" name
 
cd /
mkdir /backups &> /dev/null
 
case $name in
gzip)
    tar -zcf /backups/etc-20160613.tar.gz etc
    echo "gz is ok"
    exit 1
    ;;
bzip2)
    tar -jcf /backups/etc-20160613.tar.bz2 etc
    echo "bz2 is ok"
    exit 1
    ;;
xz)
    tar -Jcf /backups/etc-20160613.tar.xz etc
    echo "xz is ok"
    exit 1
    ;;
*)
    echo "Error compression tool"
    exit 1
    ;;
esac

 

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

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

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

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

   (4) 其它为无法判断;

#!/bin/bash
#
read -p "Please enter the file type : " x
if [ -f $x ];then
        echo "You can access it properly"
exit 1
elif [ -d $x ];then
        echo "You can use the CD command"
exit 1
elif [ -h $x ];then
        echo "Is an access path"
exit 1
else
        echo "Unrecognized"
fi

 

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

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

#!/bin/bash
#
hostname=$(/bin/hostname)
if [ $hostname == "localhost" -o “(none)” ];then
    hostname www.magedu.com
    echo "111"
else
    hostname
fi

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

(0)
上一篇 2017-08-28 16:53
下一篇 2017-08-28 18:35

相关推荐

  • 用户和组管理类命令的使用

    1.列出当前系统所有已经登录的用户的用户名,注意:同一个用户登录多次,则只显示以此即可; who | cut -d' ' -f1 | sort | uniq 2.取出最后登录到当前系统的用户的相关信息; who | head&nb…

    Linux干货 2016-11-21
  • N22-第十一周作业

    第十一周作业 1、详细描述一次加密通讯的过程,结合图示最佳 (1)为了做到数据的安全,应该同时满足 保密性 完整性 可用性 (2)假设A,B通信,A是客户机,B是服务器 a、客户端向服务器端发送自己支持的加密方式,并且向服务器端请求其CA颁发给的证书 b、服务器选择共同支持的加密方式并发送自己的证书; c、客户端收到其证书,并验证证书,证书必须同时满足以下条…

    Linux干货 2016-12-06
  • linux安全机制与加密工具使用

    一、加密需要和安全机制 1.不加密流量的易受攻击性 密码/数据嗅探 数据操作 验证操作 相当于邮寄明信片 2.不安全的传统协议 telnet、FTP、POP3等等;不安全密码http、sendmail、NFS等等;不安全信息Ldap、NIS、rsh等等;不安全验证 3.NIST定义的安全属性:美国国家标准与技术研究院 1) 保密性:  &…

    Linux干货 2016-09-25
  • 简单救援模式应用

                                  …

    2017-08-12
  • Linux运维实战之2-2:bash的工作特性

    这次博文我们主要来谈谈bash的工作特性哈。 主要内容: bash是一种shell解释程序     bash工作特性之命令状态返回值 bash工作特性之命令行展开 bash工作特性之命令补全 bash工作特性之路径补齐 bash工作特性之命令引用 bash工作特性之命令别名 bash工作特性之文件名通配 bash工作特性之命令hash 问…

    Linux干货 2016-11-06
  • gawk基础及进阶

    GUN awk: 文本处理三工具:grep,sed,awd grep,egrep,fgrep:文本过滤工具:pattern sed:行编辑器 模式空间、保持空间 awk:报告生成器,格式化文本输出; AWK:Aho,Weinberger,Kernighan –> New AWK,NAWK GNU awk,gawk gawk – …

    Linux干货 2017-05-22