Linux第八周小结

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

在线的主机使用绿色显示

不在线的主使用红色显示

#!/bin/bash
#
for i in {1..254};do
  if ping -c 6 -w 1 192.168.1.$i &> /dev/null;then
    echo -e "\033[32m 192.168.1.$i \033[0m is up"
  else
    echo -e "\033[31m 192.168.1.$i \033[0m is down"
  fi
done

2、如何给网络接口配置多个地址,有哪些方式?

a) 使用ifconfig命令

例如 ifconfig eno16777736:0 192.168.0.100/24

b) 使用Ip addr命令

例如 ip addr add 192.168.0.101/24 dev eno16777736

c) 通过配置文件/etc/sysconfig/network-scripts/ifcfg-IFACE来识别接口并完成配置;

d) 使用nmtui命令

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

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

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

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

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

#!/bin/bash
#
declare -i n=0
declare -i m=0

for i in $(ls /etc/rc.d/rc3.d); do

   if [ $(echo $i | cut -c 1)  == "K" ]; then
      echo "$i stop"
      let n++
   elif [ $(echo $i | cut -c 1) == "S" ]; then
      echo "$i start"
      let m++
   fi

done

echo "K is $n S is $m."

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

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

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

#!/bin/bash
#
declare -i sum=0

for i in $@; do
   if ! id $i &> /dev/null; then
      echo "$i is not user"
   else
       let sum=$sum+$(id -u $i)
   fi
done

echo "uid sum = $sum"

5、写一个脚本

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

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

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

#!/bin/bash
#
declare -i m=0
declare -i n=0

for i in $@;do
   if [ -d $i ];then
     for x in $i/*;do
       echo $x
       let m++
       if [ -d $x ];then
         echo $x
         let n++
       fi
    done
   else
      echo "$i is not a dir or not file"
fi

done

echo " dir = $n   file = $m "

6、写一个脚本

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

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

#!/bin/bash
#
uname=$1
if id $uname &> /dev/null ;then
   if [ $(id -u $uname) -ge 500 ];then
      echo "this is a normal user"
   else
       echo "Not an ordinary user"
   fi
else
   echo "not a user"
fi

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

#!/bin/bash
#
for i in {20..100};do
   if ping -c 1 172.16.250.$i &> /dev/null;then
   echo "172.16.250.$i is online"
   fi
done

8、打印九九乘法表

#!/bin/bash
#
for i in 'seq 1 9';do
   for j in 'seq 1 $i';do
      echo -n -e "${j}X${i}=$[$j*$i]\t"
   done
   echo
done

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

(0)
上一篇 2017-08-19 22:30
下一篇 2017-08-20 11:02

相关推荐

  • 第一周的博客作业

    1.计算机的组成以及功能:     cpu:就是中央处理器,运算和判断计算机的数据;     储设器:存储计算机的数据;     主板:链接多的计算机的硬件;     I/O设备:输入,输出设备,,如…

    Linux干货 2017-01-05
  • 运维工程师技能需求排行

    这是我今天在拉勾网搜索运维,翻完了4四页也招聘信息之后得到的,我的目的是想要看看之后的学习,哪个更应该成为重点,有些在我意料之中,有些还真的没想到,算是努力了一个小时的收获吧,分享给大家。
    注意:其中的看法仅代表个人观点,很多都是依靠我自己的学习经验和工作经验累积的

    Linux干货 2017-12-12
  • 软件包管理–RPM YUM

    包管理器 二进制应用程序的组成部分 二进制文件,配置文件,说明文档,库文件 程序包管理器 Debian  deb文件  dpkg包管理器 Redhat  rpm文件  rpm包管理器                   &nbsp…

    Linux干货 2016-08-21
  • 第5周作业

    1、显示当前系统上root、fedora或user1用户的默认shell     ~]# egrep "^(root|fedora|user1)" /etc/passwd 2、找出/etc/rc.d/init.d/functions文件中某单词后面跟一组小括号的行,如:hello();  …

    Linux干货 2017-01-07
  • Linux网络属性配置(三)修改配置文件&& CentOS 7 网络配置

    Linux网络属性配置(三)&& CentOS 7网络配置 Linux网络属性配置(三)修改配置文件&& CentOS 7 网络配置 Linux网络属性配置(三)修改配置文件 IP、MASK、GW、DNS相关配置文件: /etc/sysconfig/network-scripts/ifcfg-IFACE 路由相关配置文件: /…

    Linux干货 2016-07-07
  • SElinux

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

    Linux干货 2016-09-21

评论列表(1条)

  • 马哥教育
    马哥教育 2017-09-02 20:44

    脚本传参和程序控制是非常基础和重要的脚本知识点,从作业中可以看出掌握的很好,再接再励。