0811:脚本练习

系统信息获取脚本

1、编写脚本/root/bin/systeminfo.sh,显示当前主机系统信息,包括主机名,IPv4地址,操作系统版本,内核版本,CPU型号,内存大小,硬盘大小。
[root@centos7 scripts]#cat systeminfo.sh 
#!/usr/bin/bash 
server_ip=`ifconfig | grep 'inet\b'  | grep -v '127.0.0.1' | tr -s ' '  | cut -d' '  -f3`
CPUmod=`lscpu | grep -i "model name:"`
Meninfo=`free -h | sed -n '2p' | tr -s ' ' | cut -d' ' -f2`
DISKinfo=`fdisk -l | sed -n '2p' | sed -r 's/.*[[:space:]]([0-9].*GB).*/\1/g'` 
echo 'hostname :'$(hostname)
echo 'hostIP:'${server_ip}
echo 'OS version:'$(cat /etc/redhat-release)
echo 'Kernel version:'$(uname -r)
echo 'CPU '$CPUmodecho 'Memory :'$Meninf
oecho 'Harddisk:'$DISKinfo
2、编写脚本/root/bin/backup.sh,可实现每日将/etc/目录备份到/root/etcYYYY-mm-dd中
[root@centos7 scripts]#cat backup.sh 
#!/usr/bin/env bash 
backdir="/root/etc$(date +%F)"
cp -a /etc/. $backdir && echo " backup $backdir  finished."
3、编写脚本/root/bin/disk.sh,显示当前硬盘分区中空间利用率最大的值
[root@centos7 scripts]#cat disk.sh  
#!/usr/bin/env bash 
maxdisk=`df | grep '/dev/sd' | tr -s ' ' | sort -nr -t' ' -k5 | head -1 | cut -d' ' -f1`
maxused=`df | grep '/dev/sd' | tr -s ' ' | sort -nr -t' ' -k5 | head -1 | cut -d' ' -f5` 
echo '分区利用率最大值为:'$maxused
4、编写脚本/root/bin/links.sh,显示正连接本主机的每个远程主机的IPv4地址和连接数,并按连接数从大到小排
[root@centos7 scripts]#cat links.sh 
#!/usr/bin/env bash 
echo -e "远程主机连接统计为:\n\t连接数\t远程主机IP"
netstat -nt | tr -s ' ' | cut -d' ' -f5 | tr -cs '0-9.' '\n' | egrep '([0-9]+.){3}[0-9]+' | sort | uniq -c | sort -nr | tr -s ' ' '\t'

计算脚本

5、写一个脚本/root/bin/sumid.sh,计算/etc/passwd文件中的第10个用户和第20用户的ID之和
[root@centos7 scripts]#cat sumid.sh 
#!/usr/bin/env bash

UID1=`sed -n '10p' /etc/passwd | cut -d: -f3`
UID2=`sed -n '20p' /etc/passwd | cut -d: -f3`
let Sumid=$UID1+$UID2 
echo -e "The 10 user ID is $UID1 ;\nthe 20 user ID is $UID2 ;\n\tthe sum of two users ID is $Sumid ."
6、写一个脚本/root/bin/sumspace.sh,传递两个文件路径作为参数给脚本,计算这两个文件中所有空白行之和
[root@centos7 scripts]#cat sumspace.sh 
#!/usr/bin/env bash
File1=`grep '^$' $1 | wc -l`
File2=`grep '^$' $2 | wc -l`
let Sumspace=$File1+$File2 
echo "the sum of $1 and $2 spacelines is $Sumspace" 
unset File1
unset File2 
unset Sumspace
7、写一个脚本/root/bin/sumfile.sh,统计/etc, /var,/usr目录中共有多少个一级子目录和文件
[root@centos7 scripts]#cat sumfile.sh 
#!/usr/bin/env bash
File1=`ls -A /etc | wc -l`
File2=`ls -A /var | wc -l`
File3=`ls -A /usr | wc -l` 
let Sumfile=$File1+$File2+$File3 
echo "the sum is $Sumfile " 
unset File1
unset File2
unset File3
unset Sumfile

测试大小练习:

8、写一个脚本/root/bin/argsnum.sh,接受一个文件路径作为参数;如果参数个数小于1,则提示用户“至少应该给一个参数”,并立即退出;如果参数个数不小于1,则显示第一个参数所指向的文件中的空白行数
[root@centos7 bin]#cat argsnum.sh 
#!/bin/bash
linespace=$([[ $# -lt 1 ]] && echo "至少应该给一个参数" && exit || cat $1 | grep "^$" | wc -l)
echo "$1文件中,空白行数为$linespace。" 
unset $linespace
9、写一个脚本/root/bin/hostping.sh,接受一个主机的IPv4地址做为参数,测试是否可连通。如果能ping通,则提示用户“该IP地址可访问”;如果不可ping通,则提示用户“该IP地址不可访问”
[root@centos7 bin]#cat hostping.sh 
#!/bin/bash
ping -c1 -W1 $1 && echo "该IP地址可访问" || echo "该IP地址不可访问"
# ping命令的参数中,-c表示发送多少个包,-W表示等待多久(单位s)。

文件存在性练习:

10、chmod-rw /tmp/file1,编写脚本/root/bin/per.sh判断当前用户对/tmp/fiile1文件是否不可读且不可写
[root@centos7 bin]#cat per.sh
#!/bin/bash
fileName=/tmp/file1
[ -r $fileName ] || [ -w $fileName ] && echo "file can be read or can be written " || echo "file can not be read or the file can not be written"
11、编写脚本/root/bin/nologin.sh和login.sh,实现禁止和充许普通用户登录系统。
#!/bin/bash
read -p " if you want regular users login press y, or press n " relog
case $relog in
[Yy]|[Yy][Ee][Ss]):
        [[ -f /etc/nologin ]] && rm -f /etc/nologin &> /dev/null && echo "regular users can login now" || echo "regular users can login, no change occure"
                ;;
[Nn]|[Nn][Oo]):
        [[ ! -f /etc/nologin ]] && echo > /etc/nologin || echo "file already exist"
        ;;
*)
        echo "please input right."esac

【易错点】

  • case的格式:

case $var in
     case1)
            COMD
            ;;
     case2)
            COMD
            ;;
     *)
            OTHERS
esac
  • case1)后面,可以有冒号,也可以没有冒号。也就是case1):也是正确的

  • [Yy] | [Yy][Ee][Ss]的表示

    [Yy]表示Y或者y 
    [Yy][Ee][Ss]很出彩

课后作业

12、写一个脚本/root/bin/hostping.1.sh,接受一个主机的IPv4地址作为参数,先判断是否合格IP,否,提示IP错误。
#!/bin/bash
red='\e[31;1m'
end='\e[0m'
green='\e[32;1m'
[[ -z $@ ]] && echo -e "$red 请输入一个IPv4地址作为参数 $end" && exit 
[[ $# -gt 1 ]] && echo -e "$red 只能输入一个参数作为IPv4地址 $end" && exit 
echo "$1"|grep -E '^([1-9]|[1-9][0-9]|1[0-9]{2}|2[0-4][0-9]|25[0-5])\.(([0-9]|[1-9][0-9]|1[0-9]{2}|2[0-4][0-9]|25[0-5])\.){2}([0-9]|[1-9][0-9]|1[0-9]{2}|2[0-4][0-9]|25[0-5])$' &> /dev/null
var=$(echo $?)
[[ $var -ne 1 ]] || echo -e "$red 请输入一个正确的IPv4地址 $end" 
[[ $var -eq 1 ]] && exit 
echo -e "$red 正在 ping "$1",请等待...$end"
ping -c2 -W2 "$1" &> /dev/null && echo -e "$green 主机"$1"可访问 $end" || echo -e "$red 主机"$1"不可访问 $end"

0811:脚本练习
【难点】

  • 判断后的“echo输出”和退出,不能够连续,如果多次判断,需要进行多次判断ip,所以赋值变量,耗费cpu时钟少一些

  • 注意IP判断的正则表达式:^( [1-9] | [1-9][0-9] | 1[0-9]{2} | 2[0-4][0-9]] | 25[0-5]) . (([0-9] | [1-9][0-9] | 1[0-9]{2} | 2[0-4][0-9] | 25[0-5]) . ) {2} ( [0-9] | [1-9][0-9] | 1[0-9]{2} | 2[0-4][0-9] | 25[0-5] ) $

  • IP地址判断这里,可以替换为:^([1-255].([0-255].){2}[0-255]$,这样更简单好记一些

13、计算1+2+3……+100的值
#!/bin/bash
i=1sum=0
while [ $i -le 100 ] ;do
    sum=$(expr $sum + $i )
    let i++
done
echo $sum

0811:脚本练习
【易错】

  • expr使用时,每个字符和变量之间需要有空格!

14、计算从A开始,到B的所有数字的总和,判断B是否大于A,否提示错误并退出,是则计算之。
#!/bin/bash#[[ $# -lt 2 ]] && echo "至少需要两个不同的整数作为参数,第一个参数需要小于第二个参数" && exit[[ $1 =~ ^[[:digit:]]+$ ]][ $? -ne 0 ] && echo "第一个参数必须为整数" && exit[[ $2 =~ ^[[:digit:]]+$ ]][ $? -ne 0 ] && echo "第二个参数必须为整数" && exit[[ $1 -eq $2 ]] && echo "两个整数不能相同" && exit[[ $1 -ge $2 ]] && echo "第一个参数需要小于第二个参数" && exitecho -n "$1到$2之间所有整数的和为"seq -s+ $1 $2 | bc

0811:脚本练习
【重点】

  • 使用[ [ ] ] 进行数字的匹配。[ [ 2= [[:digit:]]+2= [[:digit:]]+ ] ],这里如果使用[ [ 2= \b[[:digit:]]+\b]][[2= \b[[:digit:]]+\b]]是不能得到正确结果的,[[2 =~ \<[ [ : digit : ] ] + > ] ]也是不能有正确的结果

原创文章,作者:m20-吴清玲,如若转载,请注明出处:http://www.178linux.com/37752

(0)
m20-吴清玲m20-吴清玲
上一篇 2016-08-22
下一篇 2016-08-22

相关推荐

  • Sed及Vim作业

      Sed及Vim作业题:     1、删除/etc/grub2.conf文件中所有以空白开头的行行首的空白字符    [root@localhost 7 ~]# sed -r  's/^[[:space:]]…

    Linux干货 2016-08-09
  • 22期第十三周课堂练习

    1、建立samba共享,共享目录为/data,要求:(描述完整的过程)   1)共享名为shared,工作组为magedu;   2)添加组develop,添加用户gentoo,centos和ubuntu,其中gentoo和centos以develop为附加组,ubuntu不属于develop组;密码均为用户名;   3)添加s…

    Linux干货 2017-01-09
  • 编译安装http

    下载源码并解包   2 准备编译环境yum groupinstall “Development Tools” 3 编译安装   ./configure –prefix=/app/httpd24 –sysconfdir=/etc/httpd24/ –enable-ssl &#821…

    2017-12-02
  • M20-1 8月3号 ACL访问控制列表

    一、acl简介:   access control list,用于实现灵活的权限管理,除了文件的所有者,所属组和其他人,可以对更多的用户设置权限,而acl生效的顺序是所有者,自定义用户组,自定义组,其他人。 二、ACL的设置技巧:   getfacl:取得某个文件/目录的ACL设置项目   setfacl:设置某个目录/文件的A…

    Linux干货 2016-08-08
  • Linux的哲学思想和文件系统

    Linux的哲学思想 Linux是一个自由的操作系统,其内部也有着自己独特的一些特定的规则,就是我们所说的关于Linux的哲学思想。 Linux系统的哲学思想 1.一切皆文件:Linux系统把几乎所有的系统资源全部都抽象为文件形式,包括硬件设备,甚至通信的接口都是以文件形式存在的。 2.Linux系统是由许许多多的小程序组成的,这些小程序的功能性单一,组合这…

    Linux干货 2016-11-01
  • 如何在微软Azure云机上添加新磁盘

    大家好: 最近在项目实践中,分享下如何在微软Azure云机上添加新磁盘。 首先需要查看下是否有未用上的磁盘,先fdisk -l查(看下图)并和Azure技术确认该磁盘是否可永久保存数据: 然后找到未分区的磁盘号,如上图中的/dev/sdc,再 fdisk /dev/sdc后开始在该新磁盘上进行分区创建: 为方便管理,我们一般就创建一个分区,然后进行格式化: …

    Linux干货 2016-11-27