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
下一篇 2016-08-15

相关推荐

  • Linux终端类型

    目录 1. 终端概述 2. 串行端口终端(/dev/ttySn) 3. 伪终端(/dev/pty/) 4. 控制终端(/dev/tty) 5. 控制台终端(/dev/ttyn, /dev/console) 6. 虚拟终端(/dev/pts/n) 7. 其它类型   终端概述 终端…

    Linux干货 2016-10-18
  • 基于Corosync + Pacemaker+DRBD实现MySQL高可用集群

    前言 在众多的高可用集群解决方案中,除了Heartbeat之外,Corosync也能提供类似于Heartbeat一样的功能,而且目前RedHat官方提供的高可用集群解决方案的程序包都以Corosync为主,所以今后Corosync会逐渐取代Heartbeat。本文带来的是基于Corosync + Pacemaker+DRBD的MySQL高可用集群解决方案。 …

    Linux干货 2015-06-12
  • 马哥教育网络班21期+第8周课程练习

    1、请描述网桥、集线器、二层交换机、三层交换机、路由器的功能、使用场景与区别。 集线器:工作在物理层,对信号作放大处理,转发比特流,所有端口都是共享带宽都是一个冲突域,使用在小型局域网内。 网桥:早期的二层数据链路层设备,可以建立和维护MAC地址表,独享带宽,每个端口是一个冲突域,使用在小型局域网内。 交换机:工作在数据链路层,可以学习和维护MAC地址,之后…

    Linux干货 2016-08-05
  • Nginx+Keepalived实现站点高可用

    Nginx+Keepalived实现站点高可用 vrrp 虚拟路由冗余协议(Virtual Router Redundancy Protocol,简称VRRP)是由IETF提出的解决局域网中配置静态网关出现单点失效现象的路由协议,1998年已推出正式的RFC2338协议标准。VRRP广泛应用在边缘网络中,它的设计目标是支持特定情况下IP数据流量失败转移不会引…

    Linux干货 2016-11-07
  • 文件挂载

    (1)创建目录 /mnt/file,利用dd命令创建一个大文件; (2)将文件格式化,这个文件有文件系统,相当于一个分区; (3)直接用blkid 看不到文件,可以用mount -o loop 挂载文件,挂载上后,文件就可以当作分区来用了; (4)挂载文件的优势在于,方便移动。分区不能随便移动而文件可以; centos6是要加-o loop的 centos7…

    2017-05-03
  • 马哥教育网络第21期-第八周课程练习

    1、请描述网桥、集线器、二层交换机、三层交换机、路由器的功能、使用场景与区别。   网桥从一个局域网接收MAC帧,拆封、校对、校验之后,按另一个局域网的格式重新组装,发往它的物理层。由于网桥是链路层设备,因此不处理数据链路层以上层次协议所加的报头。   集线器的主要功能是对接收到的信号进行再生整形放大,以扩大网络的传输距离,同时把所有节点…

    Linux干货 2016-10-24