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

相关推荐

  • 第三周作业

    1.列出当前系统上所有已经登录的用户的用户名,注意:同一个用户登录多次,则只显示一次即可。 [root@localhost ~]# who | cut -d' ' -f1 | sort -u 2.取出最后登录到当前系统的用户的相关信息。 […

    Linux干货 2017-01-04
  • N26-博客作业-week9

    1、写一个脚本,判断当前系统上所有用户的shell是否为可登录shell(即用户的shell不是/sbin/nologin);分别这两类用户的个数;通过字符串比较来实现; #!/bin/bash # declare -i nologin_num=0,login_num=0 for i in $(cut -d: -f7 /etc/passwd); do if …

    Linux干货 2017-04-01
  • 马哥教育Net20第二十二天:在Centos7上实现lmnp

    要求: vhost1: pma.stuX.com, phpMyAdmin, 同时提供https服务; vhost2: wp.stuX.com, wordpress vhost3: dz.stuX.com, Discuz  环境说明: DNS是:192.168.100.7 vhos…

    Linux干货 2016-07-02
  • 马哥教育网络班19期第一周课程练习

    1、描述计算机的组成及其功能。 从大体上计算机是由cpu、内存、主板、I/O设备、存储设备组成 cpu的功能就好像人的大脑,控制身体的。严格意义上是用来解释计算机指令以及处理软件中的数据的。 内存的功能就好像人的大脑记忆区、来存放眼睛看到的世界。严格意义上是用于暂时存放cpu中的运算数据,以及与硬盘等外部存储器交换的数据 主板的功能就好像人的身体,来链接身体…

    Linux干货 2016-06-18
  • 配置基于mysql的虚拟用户认证vsftp服务器

    1.安装vsftp、mysql、epel_release(epel源,后面要安装的pam_mysql认证模块需要这个源)、pam_mysql 2.刚装的mysql运行一下/usr/bin/mysql_secure_installation 3.建立数据库vsftpd,建表user,     create database vsftpd; …

    Linux干货 2016-06-22
  • Linux基础知识点(一)

    此篇博客只是记录第一周未掌握或不熟悉的知识点,用来加深印象。

    2018-03-13