第九周练习

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

#!/bin/bash
#
nologin=$(awk -F: '$NF=="/sbin/nologin"{print $NF}' /etc/passwd | wc -l)
all=$(cat /etc/passwd | wc -l)
login=$[$all-$nologin]
echo "login user:$login,nologin user:$nologin"

2、写一个脚本

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

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

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

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

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

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

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

#!/bin/bash
#
if [ $# -eq 0 ];then
    echo "At least one parameter,please try it again"
    exit 1
fi
for i in $*;do
    if [[ -a $i ]];then
        fdisk -l $i
    else
        echo "the path is not existing or not a block special"
    fi
done

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

脚本能够接受一个参数;

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

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

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

#!/bin/bash
#
if [ $# -eq 0 ];then
    echo "At least one parameter"
    exit 1
fi
if [[ "$1" == "quit" || "$1" == "QUIT" ]];then
    echo "This script is quiting"
    exit 0
elif [[ "$1" == "yes" || "$1" == "YES" ]];then
    echo "This script is still running"
else
    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 [ $# -eq 0 ];then
    echo "At least one parameter"
    exit 1
fi
mkdir -pv /backups
if [[ "$1" == "gzip" || "$1" == "GZIP" ]];then
    tar -zcf /backups/etc-$(date +%Y%m%d).tar.gz /etc
elif [[ "$1" == "bzip2" || "$1" == "BZIP2" ]];then
    tar -jcf /backups/etc-$(date +%Y%m%d).tar.bz2 /etc
elif [[ "$1" == "xz" || "$1" == "XZ" ]];then
    tar -Jcf /backups/etc-$(date +%Y%m%d).tar.xz /etc
else
    echo "Error"
    exit 0
fi

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

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

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

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

(4) 其它为无法判断;

#!/bin/bash
#
if [ $# -eq 0 ];then
    echo "At least one parameter"
    exit 1
fi
for i in $*;do
    if [ -f $i ];then
        echo "the file is normal"
    elif [ -d $i ];then
        echo "you can use cd enter this directory"
    elif [ -L $i ];then
        echo "the link is normal"
    else
        echo "unkown error"
    fi
done

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

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

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

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

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

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

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

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

#!/bin/bash
#
if [ $# -eq 0 ];then
    echo "At least one parameter"
    exit 1
fi
for i in $*;do
    uid=$(grep -E "^$i" /etc/passwd | cut -d: -f3)
    if [ $uid -eq 0 ];then
        echo "$i is root"
    elif [ $uid -ne 0 && $uid -lt 500 ];then
        echo "$i is a system user"
    else
        echo "$i is a common user"
    fi
done

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

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

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

#!/bin/bash
#
if [ $# -eq 0 ];then
    echo "At least one parameter"
    exit 1
fi
for i in $*;do
    uid=$(grep -E "^$i" /etc/passwd | cut -d: -f3)
    shell=$(grep -E "^$i" /etc/passwd | cut -d: -f7)
    if [[ $uid -ge 500 && "$shell" =~ .*sh ]];then
        echo "$i can login"
    else
        echo "$i can't login"
    fi
done

11、写一个脚本,完成如下任务 :

(1) 按顺序分别复制/var/log目录下的每个直接文件或子目录至/tmp/test1-testn目录中;

(2) 复制目录时,才使用cp -r命令;

(3) 复制文件时使用cp命令;

(4) 复制链接文件时使用cp -d命令;

(5) 余下的所有类型,使用cp -a命令;

#!/bin/bash
#
mkdir -p /tmp/test1-testn
for i in $(ls /var/log);do
    if [ -f $i ];then
        cp /var/log/$i /tmp/test1-testn
    elif [ -d $i ];then
        cp -r /var/log/$i /tmp/test1-testn
    elif [ -L $i ];then
        cp -d /var/log/$i /tmp/test1-testn
    else
        cp -a /var/log/$i /tmp/test1-testn
    fi
done

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

(0)
N24_涩味N24_涩味
上一篇 2016-12-21
下一篇 2016-12-21

相关推荐

  • corosync+pacemaker+pcs 使用ansible配置高可用LAMP构架

    前言: 这篇博客的实验主要是配置两个节点基于corosync + pacemaker的高考用lamp, 是我搞得最痛苦的一次,并且结果还不稳定。主要问题是corosync 1.x + pacemaker 时,如果把pacemaker当成插件使用,尝试很多次都不成功,后来把pacemaker当成半独立的服务进行配置。 但是如此一来crm就没办法进行资源配置,只…

    Linux干货 2016-01-27
  • rsyslog, mysql, loganalyzer联合实现

    一. rsyslog简介 rsyslog是一个自由软件, 是GPL的lincesed增强的syslogd. 它提供了Mysql和完全可配置的输出格式的支持. 1. 日志信息格式:      <优先级>时间戳 主机名 模块名/级别/信息摘要:内容      <priority>…

    Linux干货 2016-10-24
  • N25第四周 chmod chown以及 grep命令的常用示例

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

    Linux干货 2016-12-22
  • 马哥教育网络班22期第3周课程作业

    1、列出当前系统上所有已经登录的用户的用户名,注意:同一个用户登录多次,则只显示一次即可。 [root@MyCloudServer ~]# who | cut -d " " -f1 |sort -u root 2、取出最后登录到当前系统的用…

    Linux干货 2016-09-19
  • HAproxy实战

    HAproxy实验一 1、实验要求: (1) 动静分离discuzx,动静都要基于负载均衡实现; (2) 进一步测试在haproxy和后端主机之间添加varnish缓存(见实验二步骤); (3) 给出拓扑设计; (4) haproxy的设定要求: (a) 启动stats; (b) 自定义403、502和503的错误页; (c) 各组后端主机选择合适的调度方法…

    Linux干货 2016-11-15
  • Linux文件管理类命令相关

    Linux文件管理类命令相关 1、Linux上的文件管理类命令都有哪些,其常用的使用方法及其相关示例演示。 1)、查看文件命令: (1)ls命令: list,列出目录下的内容 语法: ls [OPTION]… [FILE]… 常用选项: -a: 显示所有文件,包括隐藏文件; -A:显示除.和..之外的所有文件; -l: –…

    Linux干货 2016-09-24