Linux 第九天: 练习和作业

Linux 第九天: 练习和作业

 

 

 

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

server_ip=`ifconfig|grep'inet\b'|grep -v '127.0.0.1'|tr-s ' '|cut -d' ' -f3`
CPUmod=`lscpu|grep -i "model name:"`
Meminfo=`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:' $CPUmod
echo 'Memory:' $Meminfo
echo 'Harddisk:' $DISKinfo

 

 

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

backupdir="/root/etc$(date +%F)"
cp -a /etc $backdir
echo "backup $backdir finished."

 

 

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

maxused=`df -h|grep '/dev/sd' |tr -s ' '|sort -nr -t' ' -k5 |head -l |cut -d' ' -f5`
echo'硬盘分区利用率最大值为:'$maxused

 

 

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

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'

 

 

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

dir=/etc/passwd
n=10
m=20
id_10=`cat $dir|head -$n|tail -1|cut -d: -f3`
id_20=`cat $dir|head -$m|tail -1|cut -d: -f3`
num=$[id_10+id_20]

UID1=`sed -n '10p'/etc/passwd |cut -f: -f3`
UID2=`sed -n '20p'/etc/passwd |cut -d: -f3`
let Sumid=$UID1+$UID2

 

 

写一个脚本/root/bin/sumspace.sh 传递两个文件路径作为参数给脚本 计算这两个文件中所有空白行之和
File1=`grep'^$' $1|wc -l`
File2=`grep'^$' $2|wc -l`
let Sumspace=$File1+$File2
echo "the sum of $1 + $2 spacelines is $Sumspace"
unset File1
unset File2
unset Sumspace

 

 

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

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

 

 

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

[[$# -lt 1]] && echo "input a file at least" ||(grep '^$'$1 |wc -l)

 

 

 

写一个脚本/root/bin/argsnum.sh 接受一个文件IPv4作为参数 测试是否可以连通 如果ping通 则提示用户"该ip地址可以访问" 如果不可ping通 则提示用户"该IP地址不可访问"

ping -w1 -c1 $1 &>/dev/null
[[$? -eq 0]] && echo "该IP地址可以访问"||echo "该IP地址不可以访问"

 

 

chmod -rw /tmp/file1 编写脚本/root/bin/per.sh 判断当前用户对/tmp/file1是否不可读不可写

[! -r $1 -a ! -w $1 ] && echo "can't r & w" || echo " can r or w"

 

 

编写脚本/root/bin/nologin.sh和login.sh 实现禁止和允许普通用户登录系统

[-e $1] && echo "you can login" || (rm -rf /home/`whoami`; echo "you can login")
[-e $1] && (rm -rf /home/`whoami`; echo "you can not login")||echo "you can login"

 

 

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

echo $1 | egrep -o '([0-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]))\.

([0-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]))\>'&>/dev/null
[ $? -ne  0 ] && echo "这是个不合格的IP" && exit 213
ping -w1 -c1 "$1" &>/dev/null &&  (echo "该IP地址可访问") || (echo "该IP无法访问")

 

 

计算1+2+3+…+100的值
[root@qzx ~]# seq 1 100 |tr '\n' '+' | egrep -o '.*[^+]' |bc

 

 

计算从脚本第一参数A开始,到第二个参数B的所有数字的总和,判断B是否大于A,否提示错误并退出,是则计算之

[ $2 -gt $1 ] && (seq $1 $2 |tr '\n' '+' | egrep -o '.*[^+]' |bc) || (echo "输入的数字不正确")

 

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

(0)
dengjiandengjian
上一篇 2016-08-15
下一篇 2016-08-15

相关推荐

  • N26 第八周作业

    1、请描述网桥、集线器、二层交换机、三层交换机、路由器的功能、使用场景与区别。 网桥(network bridge) 网桥工作于物理层与数据链路层,在终端设备较多的局域网中可以用网桥设备将局域网分离为不同的冲突域(collision domain),减少网络冲突,提升网络传输效率 集线器(network hub) 集线器具有多个I/O端口,一个端口的输入信号…

    2017-02-25
  • FHS文件系统各目录功能

    前言:     文件系统是一种存储和组织计算机数据的方法,它使得对其访问和查找变得容易。linux的哲学是一切皆文件,linux系统中的一切包括设备文件,我们都能在linux的倒置树状文件系统中找到相对应的文件。所以清楚的明白根目录下的每个子目录包含什么样的文件是很有必要的。我们将以Filesystem Hierarchy Standar…

    Linux干货 2016-10-17
  • Linux keepalived高可用集群

                       Linux keepalived高可用集群 keepalived简介:    keepalived是为了高可用ipvs集群而设计的,主要用作realserver的健康状态检测,如果有一台web…

    系统运维 2016-11-18
  • 马哥教育网络班21期第4周课程练习

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

    Linux干货 2016-07-27
  • crond实现邮件告警

    实验环境:centos 6.8 所需软件:mailx或msmtp或smtpEmail等 smtp客户端程序 所需帐号:我这使用的是163邮箱。 本方案优点:安装软件少,无须启动postfix等邮件服务。无须配置postfix邮件服务。由于调用的是注册邮箱,所以也不会给移入到垃圾邮件中。  建议:生产中,不管是什么服务发送邮件的建议使用外部smtp帐…

    Linux干货 2016-07-10
  • M20-1权限作业

    1、当用户xiaoming对/testdir 目录无执行权限时,意味着无法做哪些操作? [root@centos7 testdir]# ls -ld /testdir/ drwxr-xrw-. 3 root root 27 Aug  5 0…

    Linux干货 2016-08-05