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

相关推荐

  • N25-第七周

    1、创建一个10G分区,并格式为ext4文件系统; (1) 要求其block大小为2048, 预留空间百分比为2, 卷标为MYDATA, 默认挂载属性包含acl;     [root@localhost ~]# fdisk -l Disk /dev/sda: 42.9 GB, 42949672960 bytes 255…

    Linux干货 2017-05-21
  • 4th work

    1、复制/etc/skel目录为/home/tuser1,要求/home/tuser1及其内部文件的属组和其他用户均没有任何访问权限。 [root@localhost etc]# cp -r /etc/skel/ /home/tuser1 [root@localhost etc]# chmod go-rwx /home/tuser1/ 2、编辑/etc/gr…

    Linux干货 2017-10-09
  • nfs

    NFS 服务 : Network File system 网络文件系统效果: 好像在本机硬盘一样原理: 当用户去访问 映射成本地系统 // 原理 挂载属性: vsftpd 是应用程序,(内核支持) nfs 是一个文件系统应用: 局域网(最多用于) — 依赖网络 应用层 app httpd 80 vsftpd 传输层 tcp/ipinternet层…

    Linux干货 2018-02-05
  • N21-北京-泥人-马哥教育网络班21期+第一周课程练习

    马哥教育网络班21期  第一周课程练习 一、计算机的组成 1、计算机主要由以下几部分组成:运算器 控制器 存储器(编址存储单元)、 输入、输出设备   2、运算器负责运算:只能做二进制的数学、逻辑运算, 控制器:控制由哪得到数据,放到哪去,协调运算器、存储器、输入、输出等设备 运算器、控制器整合到一起就是常说的中央处理器,也就是CPU。 …

    Linux干货 2016-07-12
  • 了解sed

    本博客分为四个部分:sed介绍、sed用法、sed高级用法(简略带过)、相关例题。通过本文可以大致了解sed命令。深度可以当成是课前预习吧。 1、sed介绍Stream EDitor, 行编辑器 sed是一种流编辑器,它一次处理一行内容。处理时,把 当前处理的行存储在临时缓冲区中,称为“模式空间”( pattern space),接着用sed命令处理缓冲区中…

    Linux干货 2017-04-25
  • vim、crontab、bash for循环练习

    1、复制/etc/rc.d/init.d/functions文件至/tmp目录,将/tmp/functions文件中的以至少一个空白字符开头的行的行首加#。 vim中支持全文查找替换功能且在查找时支持正则表达式,在替换时进行引用。先使用vim /tmp/functions,然后在vim编辑模式中输入:%s/\(^[[:space:]]\+\)/#\1/g再回…

    系统运维 2016-12-03