運維常用shell指令碼
阿新 • • 發佈:2019-01-22
1、用shell指令碼批量建立Linux使用者
實現要求:建立使用者student1到student50,指定組為student組!而且每個使用者需要設定一個不同的密碼!
指令碼實現如下:
#!/bin/bash
for i in `seq 1 50`
do
useradd -G student student$i ;
echo student$i | passwd student$i --stdin;
done
【說明:Linux下 Passwd有引數
--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 使用者名稱
】
-------------------設定相同的密碼------------------------
#!/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,就這麼一個簡單的指令碼,就可以再系統裡批量生成賬號了。而且密碼跟賬號的名字一樣。
這就是for do done語句用法。
2、 編寫shell指令碼,將/usr/local/test目錄下大於100k的檔案轉移到/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 統計IP和每個地址訪問的次數,按訪問量列出前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 引數說明:– c 顯示輸出中,在每行行首加上本行在檔案中連續出現的次數。
sort引數說明:sort預設的排序方式是升序,-r 引數就會改變成倒敘;你有沒有遇到過10比2小的情況。我反正遇到過。
出現這種情況是由於排序程式將這些數字按字元來排序了,排序程式會先比較1和2,顯然1小,所以就將
10放在2前面嘍。這也是sort的一貫作風。)
4、一臺監控主機,一臺被監控主機。被監控主機分割槽使用率大於80%,就發告警郵件。放到crontab裡面,每10分鐘執行一次。
a、 首先兩臺機器要建立伺服器間的信任關係。
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、監控主機的磁碟空間,當使用空間超過90%就通過發mail來發警告
#!/bin/bash
#monitor available disk space
#提取本伺服器的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 伺服器 磁碟空間 使用率已經超過90%,請及時處理。"|mail -s "$IP 伺服器硬碟告警" [email protected]
fi
6、自動ftp上傳
#! /bin/bash
ftp -n << END_FTP
open 192.168.1.22
user test testing //使用者名稱test 密碼:testing
binary
prompt off //關閉提示
mput files //上傳files檔案
close
bye
END_FTP
6、編寫shell指令碼,獲取本機的網路地址。比如:本機的ip地址是:
192.168.100.5/255.255.255.0,
那麼他的網路地址是:
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 " "
子網掩碼:NETMASK= `ifconfig eth0 | grep "inet addr"|cut -f 4 -d ":"
7、某系統管理員需要每天做一定的重複工作,編制一個解決方案:
(1).從下午4:50 刪除/abc 目錄下的全部子目錄和全部檔案;
(2).從早上8:00~下午6:00 每小時讀取/xyz 目錄下x1 檔案中每行第一個域的全部數
據加入到/backup 目錄下的back01.txt 檔案內;
(3).每逢週一下午5:50 將/data 目錄下的所有目錄和檔案歸檔並壓縮為檔案
backup.tar.gz;
(4).在下午5:55 將IDE 介面的CD-ROM 缷載(假設CD-ROM 的裝置名為hdc);
(5).在早上8:00 前開機後啟動。
(a)用vi建立編輯一個名為prgx的crontab檔案;
(b)prgx檔案的內容:
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執行 prgx檔案中的內容:
[email protected]:#crontab prgx;在每日早晨8:00之前開機後即可自動啟動crontab
8.設計一個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
9.編寫shell程式,實現自動刪除50個賬號的功能。賬號名為stud1至stud50。
參考程式:
#!/bin/sh
i=1
while [ $i -le 50 ]
do
userdel -r stud${i}
i=$(($i+1 ))
done
10.設計一個shell程式,在每月第一天備份並壓縮/etc目錄的所有內容,存放在/root/bak目錄裡,且檔名為如下形式yymmdd_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)編寫任務定時器:
echo "0 0 1 * * /bin/sh /usr/bin/fileback" >; /root/etcbakcron
crontab /root/etcbakcron
或使用crontab -e 命令新增定時任務:
0 1 * * * /bin/sh /usr/bin/fileback
11.有一普通使用者想在每週日凌晨零點零分定期備份/user/backup到/tmp目錄下,該使用者應如何做?
參考答案:(1)第一種方法:
使用者應使用crontab –e 命令建立crontab檔案。格式如下:
0 0 * * sun cp –r /user/backup /tmp
(2)第二種方法:
使用者先在自己目錄下新建檔案file,檔案內容如下:
0 * * sun cp –r /user/backup /tmp
然後執行 crontab file 使生效。
12.設計一個Shell程式,在/userdata目錄下建立50個目錄,即user1~user50,並設定每個目錄的許可權,其中其他使用者的許可權為:讀;檔案所有者的許可權為:讀、寫、執行;檔案所有者所在組的許可權為:讀、執行。
參考答案: 建立程式 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
實現要求:建立使用者student1到student50,指定組為student組!而且每個使用者需要設定一個不同的密碼!
指令碼實現如下:
#!/bin/bash
for i in `seq 1 50`
do
useradd -G student student$i ;
echo student$i | passwd student$i --stdin;
done
【說明:Linux下 Passwd有引數
--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 使用者名稱
】
-------------------設定相同的密碼------------------------
#!/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,就這麼一個簡單的指令碼,就可以再系統裡批量生成賬號了。而且密碼跟賬號的名字一樣。
這就是for do done語句用法。
2、 編寫shell指令碼,將/usr/local/test目錄下大於100k的檔案轉移到/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 統計IP和每個地址訪問的次數,按訪問量列出前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 引數說明:– c 顯示輸出中,在每行行首加上本行在檔案中連續出現的次數。
sort引數說明:sort預設的排序方式是升序,-r 引數就會改變成倒敘;你有沒有遇到過10比2小的情況。我反正遇到過。
出現這種情況是由於排序程式將這些數字按字元來排序了,排序程式會先比較1和2,顯然1小,所以就將
10放在2前面嘍。這也是sort的一貫作風。)
4、一臺監控主機,一臺被監控主機。被監控主機分割槽使用率大於80%,就發告警郵件。放到crontab裡面,每10分鐘執行一次。
a、 首先兩臺機器要建立伺服器間的信任關係。
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、監控主機的磁碟空間,當使用空間超過90%就通過發mail來發警告
#!/bin/bash
#monitor available disk space
#提取本伺服器的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 伺服器 磁碟空間 使用率已經超過90%,請及時處理。"|mail -s "$IP 伺服器硬碟告警"
fi
6、自動ftp上傳
#! /bin/bash
ftp -n << END_FTP
open 192.168.1.22
user test testing //使用者名稱test 密碼:testing
binary
prompt off //關閉提示
mput files //上傳files檔案
close
bye
END_FTP
6、編寫shell指令碼,獲取本機的網路地址。比如:本機的ip地址是:
192.168.100.5/255.255.255.0,
那麼他的網路地址是:
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 " "
子網掩碼:NETMASK= `ifconfig eth0 | grep "inet addr"|cut -f 4 -d ":"
7、某系統管理員需要每天做一定的重複工作,編制一個解決方案:
(1).從下午4:50 刪除/abc 目錄下的全部子目錄和全部檔案;
(2).從早上8:00~下午6:00 每小時讀取/xyz 目錄下x1 檔案中每行第一個域的全部數
據加入到/backup 目錄下的back01.txt 檔案內;
(3).每逢週一下午5:50 將/data 目錄下的所有目錄和檔案歸檔並壓縮為檔案
backup.tar.gz;
(4).在下午5:55 將IDE 介面的CD-ROM 缷載(假設CD-ROM 的裝置名為hdc);
(5).在早上8:00 前開機後啟動。
(a)用vi建立編輯一個名為prgx的crontab檔案;
(b)prgx檔案的內容:
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執行 prgx檔案中的內容:
8.設計一個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
9.編寫shell程式,實現自動刪除50個賬號的功能。賬號名為stud1至stud50。
參考程式:
#!/bin/sh
i=1
while [ $i -le 50 ]
do
userdel -r stud${i}
i=$(($i+1 ))
done
10.設計一個shell程式,在每月第一天備份並壓縮/etc目錄的所有內容,存放在/root/bak目錄裡,且檔名為如下形式yymmdd_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)編寫任務定時器:
echo "0 0 1 * * /bin/sh /usr/bin/fileback" >; /root/etcbakcron
crontab /root/etcbakcron
或使用crontab -e 命令新增定時任務:
0 1 * * * /bin/sh /usr/bin/fileback
11.有一普通使用者想在每週日凌晨零點零分定期備份/user/backup到/tmp目錄下,該使用者應如何做?
參考答案:(1)第一種方法:
使用者應使用crontab –e 命令建立crontab檔案。格式如下:
0 0 * * sun cp –r /user/backup /tmp
(2)第二種方法:
使用者先在自己目錄下新建檔案file,檔案內容如下:
0 * * sun cp –r /user/backup /tmp
然後執行 crontab file 使生效。
12.設計一個Shell程式,在/userdata目錄下建立50個目錄,即user1~user50,並設定每個目錄的許可權,其中其他使用者的許可權為:讀;檔案所有者的許可權為:讀、寫、執行;檔案所有者所在組的許可權為:讀、執行。
參考答案: 建立程式 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