bash小脚本

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

[root@centos6 scripts]# cat systeminfo.sh
#!/bin/bash
HostName=`uname -n`
Ipv4=`ifconfig |sed -nr '2s#.*addr:(.*)  Bca.*$#\1#gp'`
Cpu=`lscpu|sed -n '13p'|tr -s ' '`
Mem=`free -hm |grep "Mem"|tr -s ' ' ':'|cut -d: -f2`
Disk=`fdisk -l |grep '/dev/sda:'|sed -r 's#.*: (.*),.*$#\1#g'`
 
 
 
echo the hostname is: $HostName
echo the server_ip is: $Ipv4
echo the opeartion system is: $(cat /etc/redhat-release)
echo the kernel verison is: $(uname -r)
echo the cpuinfo is: $Cpu
echo the memery size is: $Mem
echo the Hardisk size is: $Disk
[root@centos6 scripts]# sh systeminfo.sh
the hostname is: centos6.localdomain
the server_ip is: 10.1.249.94
the opeartion system is: CentOS release 6.8 (Final)
the kernel verison is: 2.6.32-642.el6.x86_64
the cpuinfo is: Model name: AMD A8-4500M APU with Radeon(tm) HD Graphics
the memery size is: 980M
the Hardisk size is: 128.8 GB
[root@centos6 scripts]#

 

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

[root@centos6 scripts]# cat backup.sh
#!/bin/bash
backup_dir="/tmp/etc-$(date +%F)"
cp -aR /etc/ $backup_dir && echo "the $backup_dir is backup successfull"
[root@centos6 scripts]# sh backup.sh
the /tmp/etc-2016-08-11 is backup successfull
[root@centos6 scripts]# ll /tmp/
总用量 40
drwxr-xr-x. 122 root root 12288 8月  11 19:03 etc-2016-08-11
 [root@centos6 scripts]#

 

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

[root@centos6 scripts]# cat disk.sh
#!/bin/bash
MaxUse=`df |grep "/dev/sda"|sed -r 's#.* ([0-9]+%).*#\1#g'|sort -nr|head -1`
echo "当前硬盘分区中空间利用率最大的值为:$MaxUse"
[root@centos6 scripts]# sh disk.sh
当前硬盘分区中空间利用率最大的值为:22%
[root@centos6 scripts]#

 

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

[root@centos6 scripts]# cat links.sh
#!/bin/bash
Links=`netstat -tn |grep tcp |tr -s ' ' ':'|cut -d: -f6|sort -nr|uniq -c`
echo -e "主机的每个远程主机的IPv4连接数和地址为:$Links"
[root@centos6 scripts]# sh links.sh
主机的每个远程主机的IPv4连接数和地址为:      2 10.1.250.79
[root@centos6 scripts]#

 

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

[root@centos6 scripts]# cat sumid.sh
#!/bin/bash
uuid1=`cat /etc/passwd|sed -n '10p'|cut -d: -f3`
uuid2=`cat /etc/passwd|sed -n '20p'|cut -d: -f3`
sum=$(($uuid1+$uuid2))
echo "第10个用户和第20用户的ID之和为:$sum"
[root@centos6 scripts]# sh sumid.sh
第10个用户和第20用户的ID之和为:180
[root@centos6 scripts]#

 

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

[root@centos6 scripts]# cat sumspace.sh
#!/bin/bash
[ $# -lt 2 ] && echo "please input two path:" && exit 1
 
Args1=`grep "^$" $1 |wc -l`
Args2=`grep "^$" $2 |wc -l`
 
let sumspace=$Args1+$Args2
 
echo "这两个文件中所有空白行之和为:$sumspace"
[root@centos6 scripts]# sh sumspace.sh  /etc/issue /etc/issue
这两个文件中所有空白行之和为:2
[root@centos6 scripts]# sh sumspace.sh
please input two path:
[root@centos6 scripts]#

 

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

[root@centos6 scripts]# sh sumfile.sh
please input at least three dir:
[root@centos6 scripts]# sh sumfile.sh /etc /var /usr
/etc,/var,/usr共有一级子目录和文件292个
[root@centos6 scripts]# cat  sumfile.sh
#!/bin/bash
[ $# -lt 3 ] && echo "please input at least three dir:" && exit 1
 
total1=`ls -A $1 |wc -l`
total2=`ls -A $2 |wc -l`
total3=`ls -A $3 |wc -l`
 
sumfile=$(($total1+$total2+$total3))
echo "$1,$2,$3共有一级子目录和文件$sumfile个"
[root@centos6 scripts]#

 

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

[root@centos6 scripts]# sh argsum.sh
at least input one args:
[root@centos6 scripts]# sh argsum.sh /etc/issue
the args you input has 1  lines space
[root@centos6 scripts]# cat argsum.sh
#!/bin/bash
 
[ $# -lt 1 ] && echo "at least input one args:" && exit 1 || echo "the args you input has `grep "^$" $1|wc -l`  lines space"
[root@centos6 scripts]#

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

[root@centos6 scripts]# sh hostping.sh
please input one ip address:
[root@centos6 scripts]# sh hostping.sh  10.1.249.94
you can access the website!
[root@centos6 scripts]# sh hostping.sh  10.1.249.93
the ip is not unreachable
[root@centos6 scripts]# cat hostping.sh
#!/bin/bash
[ $# -lt 1 ] && echo "please input one ip address:" && exit 1
ping -c1 -W1 $1 &>/dev/null  && echo "you can access the website!" || echo "the ip is not unreachable"
 
[root@centos6 scripts]#

本章总结blog地址:http://purify.blog.51cto.com/10572011/1836818

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

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

相关推荐

  • Linux脚本基础练习

    马哥教育网络班+ 第7周课堂练习 Linux脚本基础练习 练习: 1、创建一个10G分区,并格式为ext4文件系统; (1)要求其block大小为2048,预留空间百分比为2,卷标为MYDATA,默认挂载属性包含acl (2)挂载至/data/mydata目录 要求挂载时禁止程序自动运行,且不更新文件的访问时间戳 第一步,在虚拟机中挂载一块20G的新硬盘 &…

    Linux干货 2016-11-09
  • 集中练习3

    用户管理、文本处理、文件管理相关

    2017-09-20
  • 网络N22期-第五周作业

    1、显示当前系统上root、fedora或user1用户的默认shell; [root@localhost ~]#egrep '^(root|fedora|user1)\>' /etc/passwd | cut -d: -f7 /bin/bash 2、找出/etc…

    Linux干货 2016-09-15
  • linux学习第一天

    了解Linux和计算机的基础

    2018-03-26
  • openssl关于CA证书的创建

    1、用openssl实现证书申请 先在/etc/pki/CA/目录下创建一个index.txt的文件,作为ca证书的数据库 在相同目录下创建一个serial的序列号文件,并写入01 生成ca的签名证书用到的私钥文件 注意:私钥的权限时600,文件名必须是cakey.pem 生成自签证书 这样私有CA建立完成 申请认证: 在申请的机器上生成私钥 生成申请文件 …

    Linux干货 2016-09-23
  • Http实践

    练习:搭建虚拟主机     (1)基于主机名实现三个虚拟主机     (2) 每虚拟主机使用独立的访问日志和错误日志     (3) 第三个虚拟主机的/admin要进行用户访问认证     (4) 在…

    Linux干货 2016-09-30