8.10作业

1、编写脚本/root/bin/systeminfo.sh,显示当前主机系统信息,包括主机名,IPv4地址,操作系统版本,内核版本,CPU型号,内存大小,硬盘大小。

echo  "your host is `hostname` "

echo  "ip address is `ifconfig | sed -n -r "2s@inet(.*)netmask(.*)@\1@p"`"  

echo  "`uname -r`"

echo  "`uname -m`"        

echo  "`lscpu`"

echo  "`free  -m -h`"

echo  "您的硬盘大小为 `df -h |  sed -n  '/sda/p' | tr -s " " | cut -d" " -f2  `"

2、编写脚本/root/bin/backup.sh,可实现每日将/etc/目录备份到/root/etcYYYY-mm-dd中

read -p "please input backup directory: " backdir

read -p "please input destination directory: " desdir

[ -d $desdir ] && \cp  -r  $backdir $desdir/backup`date +%F ` || mkdir  -p   $/root/etc/

echo "backup successful!"

3、编写脚本/root/bin/disk.sh,显示当前硬盘分区中空间利用率最大的值

disk_use=`df |grep sd|tr -s " "|cut -d " " -f5|sed -n 's/%//p'|sort -rn|head -n 1`

echo $disk_use

unset disk_use

4、编写脚本/root/bin/links.sh,显示正连接本主机的每个远程主机的IPv4地址和连接数,并按连接数从大到小排序

netstat -nt |tr -s ' '|cut -d ' ' -f5 |cut -d: -f1 |grep [0-9]|sort |uniq -c|sort -nr

5、写一个脚本/root/bin/sumid.sh,计算/etc/passwd文件中的第10个用户和第20用户的ID之和

numbera=`sed -n '10p' /etc/passwd |cut -d: -f3`

numberb=`sed -n '20p' /etc/passwd |cut -d: -f3`

let suma_b=numbera+numberb

echo "user1 uig is $numbera"

echo "user2 uid is $numberb"

echo "two users id sum is $suma_b"

unset numberb  suma_b numbera


6、写一个脚本/root/bin/sumspace.sh,传递两个文件路径作为参数给脚本,计算这两个文件中所有空白行之和

read -p "Input first path of files: " first_path

read -p "Input second path of files:" second_path

a=`cat $first_path |grep -e "^$" -e "[[:space:]]\+$" |wc -l`

b=`cat $second_path |grep -e "^$" -e "[[:space:]]\+$" |wc -l`

let sum=a+b

echo "The total blank lines is: $sum"

unset a b sum


7、写一个脚本/root/bin/sumfile.sh,统计/etc, /var, /usr目录中共有多少个一级子目录和文件

a=`ls -A /etc/|wc -l`
b=`ls -A 
8.10作业ar/|wc -l`
c=`ls -A /usr/|wc -l`
let sumfile=a+b+c
echo "three directory have $sumfile files and directorys"
unset a b c sumfile


8、写一个脚本/root/bin/argsnum.sh,接受一个文件路径作为参数;如果参数个数小于1,则提示用户“至少应该给一个参数”,并立即退出;如果参数个数不小于1,则显示第一个参数所指向的文件中的空白行数

[ $# -lt 1  ] && echo "At least one file" || echo "文件的空行数为 `grep  "^$" $1 |wc -l` "

  

9、写一个脚本/root/bin/hostping.sh,接受一个主机的IPv4地址做为参数,测试是否可连通。如果能ping通,则提示用户“该IP地址可访问”;如果不可ping通,则提示用户“该IP地址不可访问”

[ ping $1 ] && echo "该IP地址可访问" || echo “该IP地址不可访问”


10、判断硬盘的每个分区空间和inode的利用率是否大于80,如果是,发邮件通知root磁盘满

 [`df | grep  "sda" | tr -s " "| cut -d " " -f5 | sed -n "s@%@@p" |head -n1` -gt 80  ] &&  echo "满了"|mail -s "磁盘已满" root

 [`df -i | grep  "sda" | tr -s " "| cut -d " " -f5 | sed -n "s@%@@p" |head -n1` -gt 80  ] &&  echo "满了"|mail -s "磁盘已满" root

11、指定文件做为参数,判断文件是否为.sh后缀,如果是,添加x权限

  read -p "请输入文件file"

 grep " .*\.sh"  $file && chmod +x $file || exit 1



判断输入的ip是否为合法ip

两种方法:

1.

read -p "请输入您的ip" ip

echo '$ip' | grep -E -o '{((\<([1-9][0-9]|1[0-9][0-9]|2[0-4][0-9]|25[0-5])\>\.){3}\.\<([0-9][0-9]|1[0-9][0-9]|2[0-4][0-9]|25[0-5])\>) -o (0.0.0.0)}' &&  echo "该地址合格。" ||  echo "该地址不合格。"

2.

read -p "请输入ip" ip

  a=`echo "$ip" |sed -n -r "s@^([0-9]+)\.([0-9]+)\.([0-9]+)\.([0-9]+)@\1@p" `

  b=`echo "$ip" |sed -n -r "s@^([0-9]+)\.([0-9]+)\.([0-9]+)\.([0-9]+)@\2@p" `

  c=`echo "$ip" |sed -n -r "s@^([0-9]+)\.([0-9]+)\.([0-9]+)\.([0-9]+)@\3@p" `

  d=`echo "$ip" |sed -n -r "s@^([0-9]+)\.([0-9]+)\.([0-9]+)\.([0-9]+)@\4@p" `

 if  [ $a -le 255 ] && [  $b -le 255  ] && [  $c -le 255  ] && [  $d -le 255  ] ; then

    echo "该地址合格。" 

    else

    echo "该地址不合格。"

      

 fi


计算 1~100的值

本脚本计算1~A的值。

read -p 'what is A ' A

  let a=($A+1)*$A/2

  echo "$a"

输入A B的值计算 A+ (A+1)       …(B-1) +B 的总和判断

read -p '请输入数字A和B' A B

  if [ $A -lt $B ] ; then

  let  a=($B+1)*$B/2

  let  b=($A-1)*$A/2

  echo "和为"$(($a-$b))"."  

  else

  if [ $A -gt $B ] ;then

  let  c=($A+1)*$A/2

  let  d=($B-1)*$B/2

    echo  "和为"$(($c-$d))"."

    else

    echo  "和为$(($A*2))." 

    fi

  fi

方法2:

 read -p “请输入数字A和B” A B

  sum-=`seq   -s "+" A B|bc` 

 echo "和为$sum"


简单的计算器

echo $(($1$2$3))注意无提示,比较没有技术含量。


三个简单的课后作业,已完成,日后会上传更多自己觉得有意义的脚本。

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

(0)
sjfbjssjfbjs
上一篇 2016-08-15 09:25
下一篇 2016-08-15 09:25

相关推荐

  • 设计模式(三)建造者模式Builder(创建型)

    1. 概述        在软件开发的过程中,当遇到一个“复杂的对象”的创建工作,该对象由一定各个部分的子对象用一定的算法构成,由于需求的变化,复杂对象的各个部分经常面临剧烈的变化,但将它们组合在一起的算法相对稳定。        例子1:买肯德基     &…

    Linux干货 2015-06-25
  • openssl基本应用

    导言: 我们知道在互联网上进行文件传输、电子邮件商务往来存在许多不安全因素,特别是对于一些大公司和一些机密文件在网络上传输,所以为了保证安全,我们必须给文件加密。今天,我们就来谈谈加密、解密、openssl的使用以及CA的实现过程。 数据的3大加密方式 对称加密 含义 指加密解密使用同一组密钥,是按数据分块以后进行加密的,前后数据块彼此之间有关联关系。 特性…

    Linux干货 2016-12-05
  • DNS简单配置

    正向解析,反向解析,主从, 主:主配置文件:options {        listen-on port 53 { 127.0.0.1; 172.16.252.194; };  //监听的端口,即哪些主机可以进行访问        directory   &…

    Linux干货 2017-05-24
  • 文本编辑三剑客之gawk

     awk 本章内容: awk介绍 awk基本用法 awk变量 awk格式化 awk操作符 awk条件判断 awk循环 awk数组 awk函数 调用系统命令 1.awk介绍 ★ Linux 文本处理工具三剑客:grep、sed、awk。其中grep是一种文本过滤工具;sed是文本行编辑器,而awk是一种报表生成器,就是对文件进行格式化处理的…

    Linux干货 2016-09-24
  • 马哥教育网络班20期+第五周博客作业

    1、显示/boot/grub/grub.conf中以至少一个空白字符开头的行; ]# grep  "^[[:space:]]\+" /boot/grub/grub.conf 2、显示/etc/rc.d/rc.sysinit文件中以#开头,后面跟至少一个空白字符,而后又有至少一个非空白字符的行; ]#…

    Linux干货 2016-07-12
  • N22-第九周作业

    1、写一个脚本,判断当前系统上所有用户的shell是否为可登录shell(即用户的shell不是/sbin/nologin);分别这两类用户的个数;通过字符串比较来实现; #!/bin/bash # declare -i count1=0 declare -i count2=0 for i in $(awk -F : '{print $7}&#03…

    Linux干货 2016-10-17