Linux基础(九)-shell编程练习

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

#!/bin/bash
declare -i nologin=0
declare -i login=0
while read line
do
#输出读到的每一行的结果
if [ $(echo $line | cut -d: -f7) == '/sbin/nologin'  ];then
     let nologin++
else
     let login++
fi
done < /etc/passwd

echo "可以登录用户数量为$login,不能登录用数量为$nologin"

2、写一个脚本

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

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

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

#!/bin/bash
if [ $(hostname) == 'localhost' -o $(hostname) == 'localhost.localdomain' ];then
    echo "主机名为localhost将修改为www.magedu.com"
    hostnamectl set-hostname www.magedu.com
    if [ $? -eq 0  ];then
        echo "修改成功"
        hostnamectl
    fi  
else
    hostname
fi

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

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

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

#!/bin/bash
if [ $# -ne 1  ];then
    echo "请传入一个设备文件路径" && exit 1
fi

if [ -b $1 ];then
    fdisk -l $1
else
    echo "设备不存在"
fi

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

脚本能够接受一个参数;

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

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

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

#!/bin/bash
read -p "请输入命令:" command
if [ -n $command  ];then
    case $command in
        "quit")
            echo "即将退出"
            exit 0
        ;;
         "yes")
            echo "继续执行脚本"
            exit 0
        ;;
          *)
            echo "非正常退出"
            exit 1
    esac    
else
    echo "非正常退出"
    exit 2  
fi

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 [ $# -ne 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 "错误参数" && exit 2
fi

exit 0

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

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

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

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

(4) 其它为无法判断;

#!/bin/bash
if [ $# -ne 1 ];then
    echo '请输入文件路径' && exit 1
fi
if [ -f $1 ];then
    echo "普通文件可以正常访问"
elif [ -d $1 ];then
    echo "目录文件可以使用cd命令"
elif [ -h $1 ];then
    echo "链接文件"
else
    echo "unknown文件"
fi

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

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

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

#!/bin/bash
if [ -z $(hostname) -o $(hostname) == "localhost" ];then
    hostnamectl set-hostname mail.magedu.com
else
    hostname
fi

8、写一脚本,接受一个用户名为参数;

(1) 如果用户的id号为0,则显示其为管理员;

(2) 如果用户的id号大于0且小于500, 则显示其为系统用户;

(3) 否则,则显示其为普通用户;

#!/bin/bash
#环境centos7.2
[ $# -lt 1  ] && echo '请输入用户名' && exit 1

! id $1 &> /dev/null  && echo "用户不存在" && exit 2

userid=$(id -u $1)

if [ $userid -eq 0 ];then
    echo "root"
elif [ $userid -ge 1000 ];then
    echo "普通登录用户"
else
    echo "管理员用户"
fi

9、写一个脚本,传递一个用户名参数给脚本;

(1) 如果用户的id号大于等于500,且其默认shell为以sh结尾的字符串,则显示“a user can log system.”类的字符串;

(2) 否则,则显示无法登录系统;

因为这里使用的是CentOS7.2所以id改为大于1000

#!/bin/bash
if [ $# -ne 1 ];then
    echo "请传入一个用户名" && exit 1
fi
! id $1 &> /dev/null && echo "用户不存在" && exit 2
if [ $(id -u $1) -ge 1000 -a  -n "$(cat /etc/passwd | grep -E "^\<$1\>.*sh$")" ];then
    echo "user can login system"
else
    echo "userid < 1000 or cant login system"
fi

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

(0)
luoluoluoluo
上一篇 2016-11-20
下一篇 2016-11-20

相关推荐

  • N21-北京-兔锅-马哥教育网络班21期+第3周课程练习

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

    系统运维 2016-07-07
  • SELinux介绍

    SELinux介绍 SELinux: Secure Enhanced Linux, 是美国国家安全局(NSA=The National Security Agency)和SCC(Secure Computing Corporation)开发的 Linux的一个强制访问控制的安全模块。 2000年以GNU GPL发布, Linux内核2.6版本后集成在内核中D…

    Linux干货 2016-10-08
  • N23-卡卡琦-第二周

    1、文件管理类命令 常规命令:copy、mv、rm (1).copy 文件复制 用法: 注意:复制文件只是复制文件的数据而不是元数据,但是可以保留元数据的信息。 单源复制:目录是否存在都可以 多源复制:目录必须是存在的 -i:提醒用户操作确认(交互式) -f:强行覆盖 -r:递归复制目录 -p:保留源数据 -a:用于实现归档,做备份 -d:不跟踪符号链接所指…

    Linux干货 2016-12-11
  • iptables/netfilter入门

      iptables是Linux中的重要组件,它是对报文进行过滤,在2001年的1月Linux 2.4内核发布以来,就已经是Linux的一部分了。     现在的iptbales已经成为了功能很大的防火墙,具备了专有的商业防火墙的大多数的功能了。 1、防火墙简介 2、iptables/netfilter简介 …

    Linux干货 2017-01-31
  • 网络管理之虚拟网卡实现一个网卡多个地址

    一.概述 在虚拟机中实现一个网卡多个地址 完成这个功能之前需要先关闭NetworkManager功能(在centos 6系统)         chkconfig NetworkManager off   而且我们要实现虚拟网卡一个网卡多个地址只是对虚拟机有用 网卡别名…

    Linux干货 2016-09-16
  • 文本处理三剑客之sed

    文本处理三剑客之sed sed概述 sed使用示例 sed的高级应用 sed概述 sed, 作为文本三剑客之一,其定位就是一个编辑器, 而且sed是一个流式编辑器(stream editor),其主要功能是过滤和转换文本。 sed – stream editor for filtering and&…

    Linux干货 2016-08-12

评论列表(1条)

  • 马哥教育
    马哥教育 2016-11-30 21:13

    脚本完成的干净利落,基础很扎实。期待后续的作业~