Menu
1、用shell腳本批量建立Linux用戶
2炎咖、 編寫shell腳本,將/usr/local/test目錄下大于100k的文件轉(zhuǎn)移到/tmp目錄下:
3寒波、通過apache訪問日志access.log 統(tǒng)計IP和每個地址訪問的次數(shù)塘装,按訪問量列出前10名。
4影所、一臺監(jiān)控主機蹦肴,一臺被監(jiān)控主機。被監(jiān)控主機分區(qū)使用率大于80%猴娩,就發(fā)告警郵件阴幌。放到crontab里面勺阐,每10分鐘執(zhí)行一次。
5矛双、監(jiān)控主機的磁盤空間,當使用空間超過90%就通過發(fā)mail來發(fā)警告
6渊抽、自動ftp上傳
7、編寫shell腳本议忽,獲取本機的網(wǎng)絡(luò)地址懒闷。
8、某系統(tǒng)管理員需要每天做一定的重復工作栈幸,編制一個解決方案:
(1)從下午4:50 刪除/abc 目錄下的全部子目錄和全部文件愤估;
(2)從早上8:00~下午6:00 每小時讀取/xyz 目錄下x1 文件中每行第一個域的全部數(shù)
據(jù)加入到/backup 目錄下的back01.txt 文件內(nèi);
(3)每逢周一下午5:50 將/data 目錄下的所有目錄和文件歸檔并壓縮為文件
backup.tar.gz;
(4)在下午5:55 將IDE 接口的CD-ROM 缷載(假設(shè)CD-ROM 的設(shè)備名為hdc);
(5)在早上8:00 前開機后啟動速址。
9.設(shè)計一個shell程序玩焰,添加一個新組為class1,然后添加屬于這個組的30個用戶芍锚,用戶名的形式為stdxx昔园,其中xx從01到30
10.編寫shell程序,實現(xiàn)自動刪除50個賬號的功能并炮。賬號名為stud1至stud50默刚。
Answer:
1、用shell腳本批量建立Linux用戶
實現(xiàn)要求:創(chuàng)建用戶student1到student50,指定組為student組逃魄!而且每個用戶需要設(shè)定一個不同的密碼羡棵!
腳本實現(xiàn)如下:
not this is a test
#!/bin/bash
for i in `seq 1 50`
do
useradd -G student student$i ;
echo student$i | passwd student$i --stdin;
done
【說明:Linux下 Passwd有參數(shù)
--stdin
This option is used to indicate that passwd should read the new password from standard input, which can be a pipe.
所以linux下自動改變用戶密碼的辦法就是:
Echo 密碼 |passwd –stdin 用戶名
】
設(shè)置相同的密碼
#!/bin/bash
password="123456"
for USER in user1 user2 user3
do
useradd -m $USER
echo -e "${password}\n${password}" | passwd $USER
done
【說明:
echo -n 不換行輸出:
$echo -n "123"
$echo "456"
最終輸出
123456
而不是
123
456
echo -e 處理特殊字符:
\n 換行且光標移至行首 】
ok,就這么一個簡單的腳本,就可以再系統(tǒng)里批量生成賬號了嗅钻。而且密碼跟賬號的名字一樣皂冰。
這就是for do done語句用法。
2养篓、 編寫shell腳本秃流,將/usr/local/test目錄下大于100k的文件轉(zhuǎn)移到/tmp目錄下:
!/bin/bash
for FILE in `ls /usr/local/test`
do
if [ -f $FILE ] ; then
if [ `ls -l $FILE | awk `{print $5}` -gt 100000 ] ; then
mv $FILE /tmp/
fi
fi
done
================
#!/bin/bash
for FileName in `ls -l /usr/local/test | awk '$5>102400' {print $9}`
do
mv $FileName /tmp/
done
ls -al /tmp/
echo "done!"
3、通過apache訪問日志access.log 統(tǒng)計IP和每個地址訪問的次數(shù)柳弄,按訪問量列出前10名舶胀。
日志格式樣例如下:
192.168.1.247 ---【02/jul/2010:23:44:59 + 8080 】 "GET /HTTP/1/1" 200 19
答案:
cat access.log | awk '{print $1}' |sort| uniq -c |sort -rn |head -10
(uniq 參數(shù)說明:– c 顯示輸出中,在每行行首加上本行在文件中連續(xù)出現(xiàn)的次數(shù)碧注。
sort參數(shù)說明:sort默認的排序方式是升序嚣伐,-r 參數(shù)就會改變成倒敘;你有沒有遇到過10比2小的情況萍丐。我反正遇到過轩端。
出現(xiàn)這種情況是由于排序程序?qū)⑦@些數(shù)字按字符來排序了,排序程序會先比較1和2逝变,顯然1小基茵,所以就將
10放在2前面嘍奋构。這也是sort的一貫作風。)
4拱层、一臺監(jiān)控主機弥臼,一臺被監(jiān)控主機。被監(jiān)控主機分區(qū)使用率大于80%根灯,就發(fā)告警郵件径缅。放到crontab里面,每10分鐘執(zhí)行一次烙肺。
a纳猪、 首先兩臺機器要建立服務(wù)器間的信任關(guān)系。
b茬高、腳本:
#!/bin/bash
FSMAX="80"
remote_user='root'
remote_ip=(IP地址列表)
ip_num='0'
while [ "$ip_num" -le "$(expr ${#remote_ip[@]} -l)"]
do
read_num='1'
ssh "$remote_user"@"${remote_ip[$ip_num]}" df -h > /tmp/diskcheck_tmp
grep '^/dev/*' /tmp/diskcheck_tmp | awk '{print $5}'|sed 's/\%//g' > /tmp/diskcheck_num_tmp
while [ "$read_num" -le $(wc -l < /tmp/diskcheck_num_tmp) ]
do
size=$(sed -n "$read_num" 'p' /tmp/diskcheck_num_tmp)
if [ "size" -gt "$FSMAX" ]
then
$(grep '^/dev/*' /tmp/diskcheck_tmp |sed -n $read_num'p' > /tmp/disk_check_mail)
$(echo ${remote_ip[$ip_num]}) >> /tmp/disk_check_mail)
$(mail -s "diskcheck_alert" admin < /tmp/disk_check_mail)
fi
read_num=$(expr $read_num + 1)
done
ip_num=$(expr $ip_num + 1)
done
===================寫入crontab=====================
0/10 * * * * /home/diskcheck.sh 2&>1
5假抄、監(jiān)控主機的磁盤空間,當使用空間超過90%就通過發(fā)mail來發(fā)警告
#!/bin/bash
#monitor available disk space
#提取本服務(wù)器的IP地址信息
IP=`ifconfig eth0 | grep "inet addr" | cut -f 2 -d ":" | cut -f 1 -d " "`
SPACE=` df -hP | awk '{print int($5)}'`
if [ $SPACE -ge 90 ]
then
echo "$IP 服務(wù)器 磁盤空間 使用率已經(jīng)超過90%怎栽,請及時處理。"|mail -s "$IP 服務(wù)器硬盤告警" fty89@163.com
fi
6宿饱、自動ftp上傳
#! /bin/bash
ftp -n << END_FTP
open 192.168.1.22
user test testing //用戶名test 密碼:testing
binary
prompt off //關(guān)閉提示
mput files //上傳files文件
close
bye
END_FTP
7熏瞄、編寫shell腳本,獲取本機的網(wǎng)絡(luò)地址谬以。比如:本機的ip地址是:
192.168.100.5/255.255.255.0,
那么他的網(wǎng)絡(luò)地址是:
192.168.100.1/255.255.255.0
方法一:
#强饮!/bin/bash
IP=ifconfig eth0|grep 'inet addr'|sed 's/^.*addr://g'|awk '{print $1}'
NETMASK=ifconfig eth0 |grep "inet addr"|sed 's/^.*Mask://g'
echo "$IP/&NETMASK"
exit
方法二:
#!/bin/bash
#This script print ip and network
file="/etc/sysconfig/network-scripts/ifcfg-eth0"
if [ -f $file ] ;then
IP=`grep "IPADDR" $file|awk -F"=" '{ print $2 }'`
MASK=`grep "NETMASK" $file|awk -F"=" '{ print $2 }'`
echo "$IP/$MASK"
exit 1
fi
IP地址也可這樣獲取:
IP=`ifconfig eth0 | grep "inet addr" | cut -f 2 -d ":" | cut -f 1 -d " "
子網(wǎng)掩碼:
NETMASK= `ifconfig eth0 | grep "inet addr"|cut -f 4 -d ":"
8为黎、某系統(tǒng)管理員需要每天做一定的重復工作邮丰,編制一個解決方案:
(1)從下午4:50 刪除/abc 目錄下的全部子目錄和全部文件;
(2)從早上8:00~下午6:00 每小時讀取/xyz 目錄下x1 文件中每行第一個域的全部數(shù)
據(jù)加入到/backup 目錄下的back01.txt 文件內(nèi)铭乾;
(3)每逢周一下午5:50 將/data 目錄下的所有目錄和文件歸檔并壓縮為文件
backup.tar.gz;
(4)在下午5:55 將IDE 接口的CD-ROM 缷載(假設(shè)CD-ROM 的設(shè)備名為hdc);
(5)在早上8:00 前開機后啟動剪廉。
答案:
(a)用vi創(chuàng)建編輯一個名為prgx的crontab文件;
(b)prgx文件的內(nèi)容:
50 16 * * * rm -r /abc/*
0 8-18/1 * * * cut -f1 /xyz/x1 >> /backup/bak01.txt
50 17 * * * tar zcvf backup.tar.gz /data
55 17 * * * umount /dev/hdc
(c)由超級用戶登錄炕檩,用crontab執(zhí)行 prgx文件中的內(nèi)容:
root@xxx:#crontab prgx斗蒋;
在每日早晨8:00之前開機后即可自動啟動crontab
9.設(shè)計一個shell程序,添加一個新組為class1笛质,然后添加屬于這個組的30個用戶泉沾,用戶名的形式為stdxx,其中xx從01到30
參考答案:
#!/bin/sh
i=1
groupadd class1
while [ $i -le 30 ]
do
if [ $i -le 9 ] ;then
USERNAME=stu0${i}
else
USERNAME=stu${i}
fi
useradd $USERNAME
mkdir /home/$USERNAME
chown -R $USERNAME /home/$USERNAME
chgrp -R class1 /home/$USERNAME
i=$(($i+1))
done
10.編寫shell程序,實現(xiàn)自動刪除50個賬號的功能。賬號名為stud1至stud50剿吻。
參考程序:
#!/bin/sh
i=1
while [ $i -le 50 ]
do
userdel -r stud${i}
i=$(($i+1 ))
done
11.設(shè)計一個shell程序矮固,在每月第一天備份并壓縮/etc目錄的所有內(nèi)容另患,存放在/root/bak目錄里捆等,且文件名為如下形式y(tǒng)ymmdd_etc降铸,yy為年住拭,mm為月潭袱,dd為日柱嫌。Shell程序fileback存放在/usr/bin目錄下。
參考答案:
(1)編寫shell程序fileback:
#!/bin/sh
DIRNAME=`ls /root | grep bak`
if [ -z "$DIRNAME" ] ; then
mkdir /root/bak
cd /root/bak
fi
BACKETC=$(date +%Y%m%d)_etc.tar.gz
tar zcvf $BACKETC /etc
echo "fileback finished!"
(2)編寫任務(wù)定時器:
echo "0 0 1 * * /bin/sh /usr/bin/fileback" >; /root/etcbakcron
crontab /root/etcbakcron
或使用crontab -e 命令添加定時任務(wù):
0 1 * * * /bin/sh /usr/bin/fileback
12.有一普通用戶想在每周日凌晨零點零分定期備份/user/backup到/tmp目錄下屯换,該用戶應(yīng)如何做编丘?
參考答案:
(1)第一種方法:
用戶應(yīng)使用crontab –e 命令創(chuàng)建crontab文件。
格式如下:
0 0 * * sun cp –r /user/backup /tmp
(2)第二種方法:
用戶先在自己目錄下新建文件file彤悔,文件內(nèi)容如下:
0 * * sun cp –r /user/backup /tmp
然后執(zhí)行 crontab file 使生效嘉抓。
13.設(shè)計一個Shell程序,在/userdata目錄下建立50個目錄晕窑,即user1~user50抑片,并設(shè)置每個目錄的權(quán)限,其中其他用戶的權(quán)限為:讀杨赤;文件所有者的權(quán)限為:讀敞斋、寫、執(zhí)行疾牲;文件所有者所在組的權(quán)限為:讀植捎、執(zhí)行。
參考答案:
建立程序 Pro16如下:
#!/bin/sh
i=1
while [ i -le 50 ]
do
if [ -d /userdata ];then
mkdir -p -m 754 /userdata/user$i 加上-m 754 就不用寫下面那一句了 -p 是遞歸建立目錄
#chmod 754 /userdata/user$i
echo "user$i"
let "i = i + 1" (或i=$(($i+1))
else
mkdir /userdata
mkdir -p -m /userdata/user$i
#chmod 754 /userdata/user$i
echo "user$i"
let "i = i + 1" (或i=$(($i+1))
fi
done
13.1 mysql備份實例阳柔,自動備份mysql焰枢,并刪除30天前的備份文件
#!/bin/sh
#auto backup mysql
#wugk 2012-07-14
#PATH DEFINE
BAKDIR=/data/backup/mysql/`date +%Y-%m-%d`
MYSQLDB=www
MYSQLPW=backup
MYSQLUSR=backup
if[ $UID -ne 0 ];then
echo This script must use administrator or root user ,please exit!
sleep 2
exit 0
fi
if[ ! -d $BAKDIR ];then
mkdir -p $BAKDIR
else
echo This is $BAKDIR exists ,please exit ….
sleep 2
exit
fi
###mysqldump backup mysql
/usr/bin/mysqldump -u$MYSQLUSR -p$MYSQLPW -d $MYSQLDB >/data/backup/mysql/`date +%Y-%m-%d`/www_db.sql
cd $BAKDIR ; tar -czf www_mysql_db.tar.gz *.sql
cd $BAKDIR ;find . -name “*.sql” |xargs rm -rf[ $? -eq 0 ]&&echo “This `date +%Y-%m-%d` RESIN BACKUP is SUCCESS”
cd /data/backup/mysql/ ;find . -mtime +30 |xargs rm -rf
13.2 批量解壓tar腳本,批量解壓zip并且建立當前目錄
#!/bin/sh
PATH1=/tmp/images
PATH2=/usr/www/images
for i in `ls ${PATH1}/*`
do
tar xvf $i -C $PATH2
done
這個腳本是針對所有tar文件在一個目錄舌剂,但是實際情況中济锄,有可能在下級或者更深的目錄,我們可以使用find查找
#!/bin/sh
PATH1=/tmp/images
PATH2=/usr/www/images
for i in `find $PATH1 -name “*.tar” `
do
tar xvf $i -C $PATH2
done
如果是zip文件霍转,例如123189.zip 132342.zip 等等批量文件拟淮,默認unzip直接解壓不帶自身目錄,意思是解壓123189.zip完當前目錄就是圖片谴忧,不能創(chuàng)建123189目錄下并解壓很泊,可以用shell腳本實現(xiàn)
#!/bin/sh
PATH1=/tmp/images
PATH2=/usr/www/images
cd $PATH1
for i in `find . -name ”*.zip”|awk -F. {print $2} `
do
mkdir -p PATH2$i
unzip -o .$i.zip -d PATH2$i
done
13.3
14.從1疊加到100
echo $[$(echo +{1..100})]
echo $[(100+1)*(100/2)]
seq -s '+' 100 |bc
15.判斷參數(shù)是否為空-空退出并打印null
#!/bin/sh
echo $1
name=${1:?"null"}
echo $name
16.循環(huán)數(shù)組
for ((i=0;i<${#o[*]};i++))
do
echo ${o[$i]}
done
17. 判斷路徑是否存在
if [ -d /root/desktop/text/123 ];then
echo "找到了123"
if [ -d /root/desktop/text ]
then echo "找到了text"
else echo "沒找到text"
fi
else echo "沒找到123文件夾"
fi
18.找出出現(xiàn)次數(shù)最多
awk '{print $1}' file|sort |uniq -c|sort -k1r
19. 判斷腳本參數(shù)是否正確
./test.sh -p 123 -p 3306 -h 127.0.0.1 -u root
#!/bin/sh
if [ $# -ne 8 ];then
echo "usage: $0 -u user -p passwd -p port -h host"
exit 1
fi
while getopts :u:p:p:h: name
do
case $name in
u)
mysql_user=$optarg
;;
p)
mysql_passwd=$optarg
;;
p)
mysql_port=$optarg
;;
h)
mysql_host=$optarg
;;
*)
echo "usage: $0 -u user -p passwd -p port -h host"
exit 1
;;
esac
done
if [ -z $mysql_user ] || [ -z $mysql_passwd ] || [ -z $mysql_port ] || [ -z $mysql_host ]
then
echo "usage: $0 -u user -p passwd -p port -h host"
exit 1
fi
echo $mysql_user $mysql_passwd $mysql_port $mysql_host
20.打印表格
#!/bin/sh
clear
awk 'begin{
print "+--------------------+--------------------+";
printf "|%-20s|%-20s|\n","name","number";
print "+--------------------+--------------------+";
}'
a=`grep "^[a-z]" a.txt |sort +1 -n |awk '{print $1":"$2}'`
#cat a.txt |sort +1 -n |while read list
for list in $a
do
name=`echo $list |awk -f: '{print $1}'`
number=`echo $list |awk -f: '{print $2}'`
awk 'begin{printf "|%-20s|%-20s|\n","'"$name"'","'"$number"'";
print "+--------------------+--------------------+";
}'
done
awk 'begin{
print " *** the end *** "
print " "
}'
21.判斷日期是否合法
#!/bin/sh
while read a
do
if echo $a | grep -q "-" && date -d $a +%y%m%d > /dev/null 2>&1
then
if echo $a | grep -e '^[0-9]\{4\}-[01][0-9]-[0-3][0-9]$'
then
break
else
echo "您輸入的日期不合法,請從新輸入沾谓!"
fi
else
echo "您輸入的日期不合法委造,請從新輸入!"
fi
done
echo "日期為$a"
22.打印日期段所有日期
#!/bin/bash
qsrq=20010101
js rq=20010227
n=0
>tmp
while :;do
current=$(date +%y%m%d -d"$n day $qsrq")
if [[ $current == $js rq ]];then
echo $current >>tmp;break
else
echo $current >>tmp
((n++))
fi
done
rq=`awk 'nr==1{print}' tmp`
23.打印提示
cat <<eof
#內(nèi)容
eof
24. 取用戶的根目錄
#! /bin/bash
while read name pass uid gid gecos home shell
do
echo $home
done < /etc/passwd
25. 查找連續(xù)多行均驶,在不連續(xù)的行前插入
#/bin/bash
lastrow=null
i=0
cat incl|while read line
do
i=`expr $i + 1`
if echo "$lastrow" | grep "#include <[a-z].h>"
then
if echo "$line" | grep -v "#include <[a-z].h>"
then
sed -i ''$i'i\\/\/all header files are include' incl
i=`expr $i + 1`
fi
fi
lastrow="$line"
done
26.查詢其他數(shù)據(jù)庫 其它引擎
#/bin/bash
path1=/data/mysql/data/
dbpasswd=db123
#myisam或innodb
engine=innodb
if [ -d $path1 ];then
dir=`ls -p $path1 |awk '/\/$/'|awk -f'/' '{print $1}'`
for db in $dir
do
number=`mysql -uroot -p$dbpasswd -a -s "$path1"mysql.sock -e "use ${db};show table status;" |grep -c $engine`
if [ $number -ne 0 ];then
echo "${db}"
fi
done
fi
27.批量修改其他數(shù)據(jù)庫引擎
#/bin/bash
for db in test test1 test3
do
tables=`mysql -uroot -pdb123 -a -s /data/mysql/data/mysql.sock -e "use $db;show tables;" |awk 'nr != 1{print}'`
for table in $tables
do
mysql -uroot -pdb123 -a -s /data/mysql/data/mysql.sock -e "use $db;alter table $table engine=myisam;"
done
done
28.將shell取到的數(shù)據(jù)插入mysql其他數(shù)據(jù)庫
mysql -u$username -p$passwd -h$dbhost -p$dbport -a -e "
use $dbname;
insert into data values ('','$ip','$date','$time','$data')
"
29.兩日期間隔天數(shù)
d1=`date -d '20070409' +"%s"`
d2=`date -d '20070304 ' +"%s"`
d3=$(($d1 - $d2))
echo $(($d3/60/60/24))
30. ssh批量執(zhí)行命令
#版本1
#!/bin/bash
while read line
do
ip=`echo $line|awk '{print $1}'`
passwd=`echo $line|awk '{print $2}'`
ssh -n localhost "cat -"
sshpass -p "$passwd" ssh -n -t -o stricthostkeychecking=no root@$ip "id"
done<iplist.txt
#版本2
#!/bin/bash
iplist=`awk '{print $1}' iplist.txt`
for ip in $iplist
do
passwd=`awk '/'$ip'/{print $2}' iplist.txt`
sshpass -p "$passwd" ssh -n -t -o stricthostkeychecking=no root@$ip "id"
done
31.多進程后臺并發(fā)控制
#!/bin/bash
test () {
echo $a
sleep 5
}
for a in `seq 1 30`
do
test &
echo $!
((num++))
if [ $num -eq 6 ];then
echo "wait..."
wait
num=0
fi
done
wait
32.恢復rm刪除的文件
debugfs針對 ext2
ext3grep針對 ext3
extundelete針對 ext4
df -t # 首先查看磁盤分區(qū)格式
umount /data/ # 卸載掛載,數(shù)據(jù)丟失請首先卸載掛載,或重新掛載只讀
ext3grep /dev/sdb1 --ls --inode 2 # 記錄信息繼續(xù)查找目錄下文件inode信息
ext3grep /dev/sdb1 --ls --inode 131081 # 此處是inode
ext3grep /dev/sdb1 --rest ore-inode 49153 # 記錄下inode信息開始恢復目錄
this is a failure to select atom!
don't open vim mode
don't open vim-mode
instant vim not installed
it is pity that the vim-instant function can't be
installed correctly!
good night boy!
ace in beijin
參考<http://guoyueheng148.blog.163.com/blog/static/6016709120140209413480/>