第八周练习脚本部分

1、写一个脚本,使用ping命令探测172.16.250.1-172.16.250.254之间的所有主机的在线状态;在线的主机使用绿色显示;不在线的主使用红色显示;

#!/bin/bash
#
for((i=1;i<=254;i++));do
    site="172.16.250.${i}"
    ping -w1 -c1 $site &> /dev/null
    if [[ "$?" == "0" ]];then
        echo -e "\033[32m${site}\033[0m"
    else
        echo -e "\033[35m${site}\033[0m"
    fi
done

2.写一个脚本,完成以下功能

(1) 假设某目录(/etc/rc.d/rc3.d/)下分别有K开头的文件和S开头的文件若干;

(2) 显示所有以K开头的文件的文件名,并且给其附加一个stop字符串;

(3) 显示所有以S开头的文件的文件名,并且给其附加一个start字符串;

(4) 分别统计S开头和K开头的文件各有多少;

#!/bin/bash
#
for i in $(ls /etc/rc.d/rc3.d/);do
    if [[ "$i" =~ ^S  ]];then
        S=$(echo $i | wc -l)
        let Ssum+=$S
        echo ${i}start
    fi
    if [[ "$i" =~ ^K  ]];then
        K=$(echo $i | wc -l)
        let Ksum+=$K
        echo ${i}stop
    fi
done
    echo "S Begin:$Ssum"
    echo "K Begin:$Ksum"

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

(1) 脚本能接受用户名作为参数;

(2) 计算此些用户的ID之和;

#!/bin/bash
#
if [ $# -eq 0 ];then
    echo "At least one parameter,try the script again,please!"
    exit 1
fi
for i in $*;do
    id $i &> /dev/null && uid=$(grep -E "^${i}" /etc/passwd | cut -d: -f3) || echo "This user isn't existing"
    let sum+=$uid
done
    echo "ID_SUM is $sum"

4、写一个脚本

(1) 传递一些目录给此脚本;

(2) 逐个显示每个目录的所有一级文件或子目录的内容类型;

(3) 统计一共有多少个目录;且一共显示了多少个文件的内容类型;

#!/bin/bash
#
if [ $# -eq 0 ];then
    echo "At least one parameter,try the script again,please!"
    exit 1
fi
for i in $*;do
    if [ -d $i ];then
        ls $i
        dnum=$(ls $i | wc -l)
        echo "The Directory has $dnum files"
    else
        ls $i
        echo "This is a commom file:$i"
    fi
done

5、写一个脚本

通过命令行传递一个参数给脚本,参数为用户名

如果用户的id号大于等于500,则显示此用户为普通用户;

#!/bin/bash
#
if [ $# -eq 0 ];then
    echo "At least one parameter,try the script again,please!"
    exit 1
fi
for i in $*;do
    id $i &> /dev/null && uid=$(grep -E "^${i}" /etc/passwd | cut -d: -f3) || echo "This user isn't existing"
        if [[ "$uid" > "500" ]];then
            echo "$i is a common user"
        fi
done

6、写一个脚本

(1) 添加10用户user1-user10;密码同用户名;

(2) 用户不存在时才添加;存在时则跳过;

(3) 最后显示本次共添加了多少用户;

#!/bin/bash
#
x=0
for i in {1..10};do
    id user$i &> /dev/null && continue || useradd user$i && echo "user$i" | passwd --stdin user$i && let x++
done
    echo "add $x users"

7、写一脚本,用ping命令测试172.16.250.20-172.16.250.100以内有哪些主机在线,将在线的显示出来;

与第一题相似,就不写啦~

8、打印九九乘法表;

#!/bin/bash
#
for((i=1;i<=9;i++));do
    for((j=1;j<=i;j++));do
        echo -e -n "$j*$i=$[$i*$j]\t"
    done
    echo ""
done

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

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

相关推荐

  • 为什么系统可执行文件多用相对路径创建链接

    为什么系统可执行文件多用相对路径创建链接 使用链接有什么好处 作为一个linux初学者,我们首先要知道,在linux中使用链接的好处是什么。总结下来一共有几个: 使用链接可以使我们在访问文件时省去一大笔敲文件路径的时间。对于我们运维工程师来说,我们经常要查看某个文件或者访问某个目录,再进行该项工作时,往往需要敲很多路径才能找到我们想访问的文件,创建链接可以让…

    Linux干货 2017-07-23
  • 网络管理

                                                 网络基础 一.网络的基本概念 什么是网络…

    2017-09-02
  • 公钥和私钥的原理

          今天上课老师讲到公钥和秘钥,模模糊糊听了个大概,始终还是不能够详细的理解公钥怎么会事?私钥怎么会事?工作原理是怎么的?今天在网上找了半天,通过查看大家对这个密钥对的理解,总算弄清楚了,咱就把我的心得写出来给大家对密钥对有疑问的同志们看看。      公钥和私钥就是俗称…

    Linux干货 2016-11-30
  • 系统管理之程序包管理(二)yum详解

    系统管理之程序包管理(二)yum详解:     上节向大家介绍了程序包管理的理论和rpm命令的使用,本篇文章接着向大家介绍rpm的前端使用工具,方便大家更快捷的管理,使用rpm包,提高工作效率。 一 概论: Centos:yum,dnf 两个rpm前端工具 YUM :yellow dog, Yellowdog,Upda…

    Linux干货 2016-08-24
  • GRUB

    GRUB(Boot Loader):  grub: GRand Unified Bootloader grub 0.x: grub legacy grub 1.x: grub2 grub legacy: stage1: mbr stage1_5: mbr之后的扇区,让stage1中的bootloader能识别stage2所在的分区上的文件系统; s…

    Linux干货 2016-04-12
  • ☞文件服务器 – vsftpd

    文件服务器 – vsftpd 概述 FTP协议 vsftpd的配置文件 vsftpd + pam + file_db + virtual_vsftp_user vsftpd + pam + mysql + virtual_vsftp_user 登录时错误类型 总结 文件服务器是一种专供其他电脑访问文件和存储的程序。文件服务器通常比一般的个人电脑拥…

    Linux干货 2016-10-15

评论列表(1条)

  • 马哥教育
    马哥教育 2016-12-23 12:07

    赞~~从几个脚本来看,掌握的非常不错~~继续加油~