shell 脚本基础作业

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

#!/bin/bash

:<<EOF

显示当前主机系统信息,包括主机名,IPv4地址,操作系统版本,内核版本,CPU型号,内存大小,硬盘大小

EOF

Host_name=`hostname`

Ip_address=`ifconfig | grep -o '\([[:digit:]]\+\.\)\{3\}[[:digit:]]\+'|sed -n '1p'`

Systeminfo=`cat /etc/redhat-release`

Coreinfo=`uname -r`

Cpuinfo=`lscpu|sed -n '13p' | tr -s ' ' | cut -d: -f2`

Meminfo=`lscpu|sed -n '13p' | tr -s ' ' | cut -d: -f2`

Hdisk=`fdisk -l /dev/sda |sed -n '2p'|tr -d ' '|cut -d , -f1`

echo "主机名:$Host_name"

echo -e "\n操作系统信息: $Systeminfo"

echo -e "\ncpu信息: $Cpuinfo"

echo -e "\n内核信息: $Coreinfo"

echo -e "\n内存信息: $Meminfo"

echo -e "\n本机IP地址: $Ip_address"

echo -e "\n硬盘信息: $Hdisk"

1.jpg

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

cp -a  /etc/.  /root/etc`date/ +%F` && ( echo"backup finished" ; ls -l | grep 'etc[[:digit:]]\+' )

||  echo "backup error"

2.jpg

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

#!/bin/bash

:<<EOF

显示当前硬盘分区中空间利用率最大的值

EOF

echo "please input the device you want to check:"

read Chk_device

echo -e "\n`df | grep "$Chk_device" | tr -s ' ' | cut -d' ' -f1,5`\n"

3.jpg

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

#!/bin/bash

:<<EOF

显示正连接本主机的每个远程主机的IPv4地址和连接数,并按连接数从大到小排序

EOF

netstat -nt | tr -s ' ' | cut -d' ' -f5 | tr -cs '0-9.' '\n' |  grep '\([0-9]\+\.\)\{3\}[0-9]\+' | sort | uniq -c | sort -nr | tr -s ' ' '\t'

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

#!/bin/bash

#计算第N行的用户的ID的总和

declare -i id=0

for line in {10,20};do

id2=`sed -n "${line}p" /etc/passwd | cut -d: -f3`

id=$[$id+$id2]

done

echo "the sum is $id"

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

#!/bin/bash

#统计目录中共有多少个一级子目录和文件

sum1=`ls -a $1 |wc -l`

echo "the sum1 of $1 is $sum1"

sum2=`ls -a $2 |wc -l`

echo "the sum2 of $2 is $sum2"

sum3=`ls -a $3 |wc -l`

echo "the sum3 of $3 is $sum3"

6.jpg

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

#!/bin/bash

:<<\EOF

写一个脚本/root/bin/argsnum.sh,接受一个文件路径作

为参数;如果参数个数小于1,则提示用户“至少应该给一个

参数”,并立即退出;如果参数个数不小于1,则显示第一个

参数所指向的文件中的空白行数

EOF

[ $# -eq 0 ]&& (echo "至少应该给一个参数"; exit 2)

linenum1=`grep '^$' $1 | wc -l`

echo "the linenum of the first parameter is $linenum1"

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

#!/bin/bash

:<<\EOF

写一个脚本/root/bin/hostping.sh,接受一个主机的

IPv4地址做为参数,测试是否可连通。如果能ping通,则提

示用户“该IP地址可访问”;如果不可ping通,则提示用户“

该IP地址不可访问

EOF

ping -c1 -w1 $1 &> /dev/null && (echo"该IP地址可以访问";exit 0) || echo " 该IP地址不可以访问"

9、chmod -rw /tmp/file1,编写脚本/root/bin/per.sh,判断当前用户对/tmp/fiile1文件是否不可读且不可写

#!/bin/bash

:<<\EOF

chmod -rw /tmp/file1,编写脚本/root/bin/per.sh,判

断当前用户对/tmp/fiile1文件 是否不可读且不可写

EOF

[ ! -r /tmp/test/file1 -a !-w /tmp/test/file1 ] &&  echo" no -r no -w" || echo "has -r or -w"

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

#!/bin/bash

#禁止和充许普通用户登录系统。

echo "please input "nologin" or "login" to limit the users to login "

read Login_model

[ "$Login_model" == "nologin" ] && (touch /etc/nologin &>/dev/null ;echo "limit users

to login")

[ "$Login_model" == "login" ] && ( rm -rf /etc/nologin &>/dev/null ;echo "allow users to

login")

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

#!/bin/bash

:<<\EOF

写一个脚本/root/bin/hostping.sh,接受一个主机的

IPv4地址做为参数,测试是否可连通。如果能ping通,则提

示用户“该IP地址可访问”;如果不可ping通,则提示用户“

该IP地址不可访问

EOF

echo "please input IP address you want to ping:"

read Ping_address

[[ "$ipaddress" =~ "[[:digit:]]\+\.[[:digit:]]\+\.[[:digit:]]\+\.[[:digit:]]\+" ]]

ping -c1 -w1 $1 &> /dev/null && (echo"该IP地址可以访问";exit 0) || echo " 该IP地址不可以访问"

  

12、计算1+2+3+…+100的值

declare -i sum=0

for i in {1,100};do

sum=$[$i+$sum]

echo "sum=$sum"

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

#!/bin/bash

#

declare -i sum=0

[ $1 -lt $2 ] && (sum=$[$1+$2];echo "sum=$sum") || echo "error";exit

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

(1)
ldt195175108ldt195175108
上一篇 2016-08-15
下一篇 2016-08-15

相关推荐

  • Linux进程查看及管理(2)

    Linux进程查看及管理(2) CentOS5和6的启动流程: Liunx中的启动:kernel和rootfs(根文件系统) kernel:进程管理,内存管理,网络管理功能,驱动程序,文件系统,安全功能(权限模型), rootfs:glibc(lib,lib64) 库:函数集合,function(功能模块)有其调用接口(头文件是对函数功能或调用参数的功能进行…

    Linux干货 2016-08-08
  • Linux下硬连接和软连接的区别

    Linux下硬链接与软链接的区别   链接,是指在计算机文件之间传递参数和控制命令,并把它们组成一个可执行的整体的过程。例如我们常见的windows系统下的“快捷方式”,它是一种链接,人们可以通过它来直接访问计算机上的某个文件,不必逐级在硬盘目录下寻找;互联网上的“超文本链接”,它用文字链接的形式来指向一个页面,人们可以通过此链接快速访问网站的页面…

    Linux干货 2016-10-21
  • vim编辑器

    一、vim编辑器简介     文本:ASCII,Unicode     文本编辑种类:     行编辑器:sed     全屏编辑器:nano,vi     v…

    Linux干货 2016-08-10
  • Linux三剑客之sed

    sed 简介 sed 工作原理 命令格式 常用选项: 地址定界: 编辑命令: 替换标记: sed元字符集(正则表达式) 高级编辑命令: sed用法实例 作业: 选定行的范围:,(逗号) 删除操作:d命令 显示模式空间内容 追加(行下):a\命令 插入(行上):i\命令 退出:q命令 多点编辑:e命令 从文件读入:r命令 写入文件:w命令 替换操作:s命令 替…

    Linux干货 2016-08-11
  • 配置LAMP (php-fpm模式)部署步骤

    配置LAMP (php-fpm模式)部署步骤 1.安装mariadb yum install maridb-server -y 1).配置server.cnf cp /etc/my.cnf.d/server.cnf{,.back} vim /etc/my.cnf.d/server.cnf ##mariadb服务器端配置文件 [mysqld] ##以下项是优化…

    Linux干货 2017-06-02