1.編寫腳本/root/bin/systeminfo.sh,顯示當前主機系統信息,包括主機名,IPv4地址,操作系統版本,內核版本,CPU型號,內存大小,硬盤大小。
#!/bin/bash
echo "hostname: `hostname`"
echo "OS VERSION: `cat /etc/issue`"
echo "KERNEL VERSION: `uname -r`"
echo "CPU MODEL:`lscpu|grep 'Model name'|tr -s " "|cut -d: -f2`"
echo "MEM CAPACITY:`cat /proc/meminfo|head -1|tr -s " "|cut -d: -f2`"
echo "DISK CAPACITY: `fdisk -l|sed -n 2p|sed -r 's@.*[[:space:]]([0-9].*GB).*@\1@g'`"
echo "IPv4: `ifconfig|sed -n 2p|sed -r 's#.*inet[[:space:]](.*)[[:space:]]*net.*#\1#g'`"
2.編寫腳本/root/bin/backup.sh,可實現每日將/etc/目錄備份到/root/etcYYYY-mm-dd中
#!/bin/bash
backdir="/root/etc$(date +%F)"
cp -r /etc/. $backdir && echo "backup $backdir finished."
3.編寫腳本/root/bin/disk.sh,顯示當前硬盤分區中空間利用率最大的值
#!/bin/bash
echo "the max use of disk is `df -h|tr -s " "|cut -d " " -f5|sed -n '2,$p'|sort -n|tail -1`"
4.編寫腳本/root/bin/links.sh,顯示正連接本主機的每個遠程主機的IPv4地址和連接數,并按連接數從大到小排序
#!/bin/bash
echo -e "遠程主機連接統計為:\n\t連接數\t遠程主機IP"
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'
5.寫一個腳本/root/bin/sumid.sh,計算/etc/passwd文件中的第10個用戶和第20用戶的ID之和
#!/bin/bash
id1=`cat /etc/passwd|sed -n 10p|cut -d: -f3`
id2=`cat /etc/passwd|sed -n 20p|cut -d: -f3`
sum=$[id1+id2]
echo "the sum of two users ID is $sum"
6.寫一個腳本/root/bin/sumspace.sh,傳遞兩個文件路徑作為參數給腳本,計算這兩個文件中所有空白行之和
#!/bin/bash
File1=`grep '^$' $1|wc -l`
File2=`grep '^$' $2|wc -l`
let Sumspace=$File1+$File2
echo "the sum of $1 and $2 spacelines are $Sumspace"
unset File1
unset File2
unset Sumspace
7.寫一個腳本/root/bin/sumfile.sh,統計/etc, /var, /usr目錄中共有多少個一級子目錄和文件
#!/bin/bash
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 number of all 1level dir and file are $Sumfile"
8.寫一個腳本/root/bin/argsnum.sh,接受一個文件路徑作為參數;如果參數個數小于1,則提示用戶“至少應該給一個參數”,并立即退出;如果參數個數不小于1,則顯示第一個參數所指向的文件中的空白行數
#!/bin/bash
[[ $# -lt 1 ]] && echo "at least give a parameter" || echo "The number of blank lines in the file that the 1st arg points to is `grep '^$' $1|wc -l`"
9.寫一個腳本/root/bin/hostping.sh,接受一個主機的IPv4地址做為參數,測試是否可連通。如果能ping通,則提示用戶“該IP地址可訪問”;如果不可ping通,則提示用戶“該IP地址不可訪問”
#!/bin/bash
ping -c1 -W1 $1 &> /dev/null && echo the host is up || echo the host is down
10.chmod -rw /tmp/file1,編寫腳本per.sh,判斷當前用戶對/tmp/fiile1文件是否不可讀且不可寫
#!/bin/bash
[ -r /tmp/file1 -a -w /tmp/file1 ] && echo "可讀可寫" || echo "不可讀不可寫"
11.編寫腳本nologin.sh和login.sh,實現禁止和充許普通用戶登錄系統。
vim nologin.sh
#!/bin/bash
[ -f /etc/nologin ] && echo "ordinary user can't log on." || touch /etc/nologin;
echo "ordinary user can't log on."
vim login.sh
#!/bin/bash
[ -f /etc/nologin ] && (rm -rf /etc/nologin;echo "ordinary user can log on.") ||
echo "ordinary user can log on."
12.寫一個腳本/root/bin/hostping.sh,接受一個主機的IPv4地址做為參數,先判斷是否合格IP,否,提示IP格式不合法并退出,是,測試是否可連通。如果能ping通,則提示用戶“該IP地址可訪問”;如果不可ping通,則提示用戶“該IP地址不可訪問”
過濾ip
#!/bin/bash
echo $1 > loginip
egrep "[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\>" loginip &> /dev/null && echo "It's a qulified IP" && (ping -c1 -W1 $1 &> /dev/null && echo the host is up || echo the host is down) || (echo "It's an illegal IP";exit)
13.計算1+2+3+…+100的值
echo $((`seq -s+ 1 100`))
echo 0 +{1..100} | bc
for i in {1..100};do let "sum=$sum +$i";echo "sum=$sum";done
14.計算從腳本第一參數A開始,到第二個參數B的所有數字的總和,判斷B是否大于A,否提示錯誤并退出,是則計算之
#!/bin/bash
[ $1 -lt $2 ] && echo $((`seq -s+ $1 $2`)) || (echo " $2 !> $1 . error!" ; exit)
$# 是傳給腳本的參數個數
$0 是腳本本身的名字
$1 是傳遞給該shell腳本的第一個參數
$2 是傳遞給該shell腳本的第二個參數
$@ 是傳給腳本的所有參數的列表
$* 是以一個單字符串顯示所有向腳本傳遞的參數,與位置變量不同,參數可超過9個
$$ 是腳本運行的當前進程ID號
$? 是顯示最后命令的退出狀態,0表示沒有錯誤,其他表示有錯誤
$*
所有的位置參數,被作為一個單詞.
注意:"$*"必須被""引用.
$@
與$*同義,但是每個參數都是一個獨立的""引用字串,這就意味著參數被完整地傳遞,
并沒有被解釋和擴展.這也意味著,參數列表中的每個參數都被當成一個獨立的單詞.
注意:"$@"必須被引用.
$@ $* 只在被雙引號包起來的時候才會有差異
雙引號括起來的情況:
$*將所有的參數認為是一個字段
原創文章,作者:victorycommander,如若轉載,請注明出處:http://www.www58058.com/35700
作業完成的很出色,標題需要用點心,盡量不要帶日期,總結部分不能省略哦,好記性不如爛筆頭。