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)
上一篇 2016-08-15 09:24
下一篇 2016-08-15 09:25

相关推荐

  • 【N25第三周作业】用户及权限管理

    1、列出当前系统上所有已经登录的用户的用户名,注意:同一个用户登录多次,则只显示一次即可。 [root@localhost ~]# who root     pts/0        2016-12-14&nb…

    Linux干货 2016-12-14
  • 软硬链接区别及tr转换命令

    软硬链接的区别 (1)软连接可以 跨文件系统 ,硬连接不可以 (2)关于 I节点的问题 。硬连接不管有多少个,都指向的是同一个I节点,会把 结点连接数增加,只要结点的连接数不是 0,文件就一直存在 ,不管你删除的是源文件还是连接的文件。只         要有一个存在,文件就 存…

    Linux干货 2016-08-08
  • Linux虚拟网络接口-Bonding 配置

    一、bonding 的定义     bonding是通过将同一设备的多个物理网卡绑定到一个虚拟网卡上,再对外提供连接。对于外端来说,多个物理网卡共享虚拟网卡的IP和mac地址,也就表现为一个网卡设备。通过bonding技术可以实现高可用或者负载均衡。     bonding有7种工作模式:&nbsp…

    Linux干货 2017-07-02
  • N26-第四周作业-邢岩

    马哥门徒-N26-邢岩   精神练习需要深入认真的工作以及热情的劲头。当你开始练习,你是在挣扎、在反抗,你需要集中精力,然后慢慢进步。那么,我们就开始吧。   第一题,复制/etc/skel目录为/home/tuser1,要求/home/tuser1及其内部文件的属组和其它用户均没有任何访问权限。   ~]# cp -r /et…

    Linux干货 2017-02-15
  • linux高级文件系统管理

    磁盘配额:         (1)如果存放的文件空间不足,虽然分区后不能直接扩容,但是可以迁移,下面以/home目录示例: 1、新建分区,同步分区表 /dev/sda62、mkfs.ext4 /dev/sda6             &n…

    Linux干货 2017-03-14
  • 第六次上课作业

    1、三种权限rwx对文件和目录的不同意义 对文件 r:read  可读取此文件的实际内容,如读取文本文件的文字内容等 w: write  可以编辑,新增或修改该文件的内容 x:execute  该文件具有可以被系统执行的权限==>>针对二进制文件或脚本 X:针对目录会加上x权限…

    Linux干货 2016-08-04