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 17:10
下一篇 2016-11-20 18:06

相关推荐

  • nginx配置文件中文文档

    Nginx配置参数中文说明。 #定义Nginx运行的用户和用户组user www www; #nginx进程数,建议设置为等于CPU总核心数。worker_processes 8; #全局错误日志定义类型,[ debug | info | notice | warn | error | crit ]error_log /var/log/nginx/error…

    Linux干货 2017-08-08
  • samba

    samba samba概述 samba原理 samba服务 samba的命令 samba搭建实例 使用GUI工具SWAT管理samba samba概述 什么是samba? samba是基于smb(Server Message Block)协议的一种实现方式。 samba的功能是什么? samba能够用来在windows,unix平台间实现文件共享服务,不同于…

    Linux干货 2016-04-28
  • 权限管理

    linux文件权限:     在linux系统中,每个文件或目录都包含有相应的权限,这些权限决定了哪些用户或组能够对此文件做哪些操作,如读取、删除、写入等操作 文件权限分为三类:r,w,x     应用于文件:      &nbs…

    Linux干货 2016-08-07
  • 从Linux小白到大牛——与狼共舞的日子11

    马哥教育网络班21期+第10周课程练习 1、详细描述一次加密通讯的过程,结合图示最佳。 加密过程 1.使用单向加密算法,提取A的文件的特征码。 2.使用A的私钥对提取出来的特征码进行加密,把加密后的特征码附加在A的文件的后面。 3.使用对称加密对刚刚的A的文件和加密后的特征码进行加密,生成对称加密密钥 4.使用B的公钥对第3步骤的对称加密的密钥进行加密,加密…

    Linux干货 2016-12-05
  • 对软连接进行cp,rm

    软连接的原理 图1 由 1 号inode 读取到连结档的内容仅有档名,根据档名链接到正确的目录去取得目标文件的inode , 最终就能够读取到正确的数据了。 软连接的使用 创建软连接,从下图可以看出软连接的大小是11个字节,对比/etc/passwd和passwdlns可知他们不是同一个文件。 在复制cp的时候对软连接的处理 对指向文件的的软连接:使用cp …

    Linux干货 2017-02-25
  • 一年直接在于春

    day01

    2018-03-26

评论列表(1条)

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

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