1、複製/etc/rc.d/rc.sysinit文件至/tmp目錄,將/tmp/rc.sysinit文件中的以至少一個空白字符開頭的行的行首加#;
cp /etc/rc.d/rc.sysinit /tmp/
vi /tmp/rc.sysinit
在末行模式下輸入 :%s/^[[:space:]]/#&/ 按Enter即可
:wq 保存退出
2、複製/boot/grub/grub.conf至/tmp目錄中,刪除/tmp/grub.conf文件中的行首的空白字符;
cp /boot/grub/grub.conf /tmp
vi /tmp/grub.conf
在末行模式下輸入 :%s/^[[:space:]]\+//g 按Enter即可
:wq 保存退出
3、刪除/tmp/rc.sysinit文件中的以#開頭,且後面跟了至少一個空白字符的行行的#和空白字符
vi /tmp/rc.sysinit
在末行模式下輸入 :%s/^#[[:space:]]\+//g 按Enter即可
:wq 保存退出
4、爲/tmp/grub.conf文件中前三行的行首加#號;
vi /tmp/grub.conf
在末行模式下輸入 :1,3s/^/#/g 按Enter即可
:wq 保存退出
5、將/etc/yum.repos.d/CentOS-Media.repo文件中所有的enabled=0或gpgcheck=0的最後的0修改爲1;
vi /etc/yum.repos.d/CentOS-Media.repo
在末行模式下輸入 :%s/enabled=0/enabled=1/g
在末行模式下輸入 :%s/gpgcheck=0/gpgcheck=1/g 按Enter即可
:wq 保存退出
6、每4小時執行一次對/etc目錄的備份,備份至/backup目錄中,保存的目錄名爲形如etc-201608300202
(1)mkdir /backup
(2) vi backup_etc.sh
#!/bin/bash
DATE=`date +%Y%m%d%H%M`
cp -R /etc /backup/etc-$DATE
末行模式下 :wq
(3)chmod +x /root/backup_etc.sh
(4)crontab -e
0 */4 * * * /root/backup.sh
7、每週2,4,6備份/var/log/messages文件至/backup/messages_logs/目錄中,保存的文件名形如messages-20160830
(1) mkdir /backup/messages_logs
(2) vi backup_messages.sh
#!/bin/bash
DATE=`date +%Y%m%d`
cp -R /var/log/messages /backup/messages_logs/messages-$DATE
末行模式下 :wq
(3)chmod +x /root/backup_messages.sh
(4)crontab -e
* * * * 2,4,6 /root/backup_messages.sh
8、每天每兩小時取當前系統/proc/meminfo文件中的所有以S開頭的信息至/stats/memory.txt文件中
(1)mkdir /stats
(2)vi backup_meminfo.sh
#!/bin/bash
grep '^S' /proc/meminfo >> /stats/memory.txt
(3)chmod +x /root/backup_meminfo.sh
(4)crontab -e
0 */2 * * * /root/backup_meminfo.sh
9、工作日的工作時間內,每兩小時執行一次echo "howdy"
crontab -e
0 9-18/2 * *1-5 /bin/echo "howdy"
腳本編程練習
10、創建目錄/tmp/testdir-當前日期時間;
#!/bin/bash
DATE=`date +%Y%m%d`
mkdir /tmp/testdir-$DATE
11、在此目錄創建100個空文件:file1-file100
#!/bin/bash
DATE=`date +%Y%m%d`
mkdir /tmp/testdir-$DATE
cd /tmp/testdir-$DATE
for i in {1..100};do
touch file$i
done
12、顯示/etc/passw d文件中位於第偶數行的用戶的用戶名;
#!/bin/bash
line=`cat /etc/passwd | wc -l`
for i in $(seq 1 $line);do
if [ $[$i%2] -eq 0 ];then
head -n $i /etc/passwd | tail -n 1 | cut -d: -f1
fi
done
13、創建10用戶user10-user19;密碼同用戶名;
#!/bin/bash
declare -i i=10
declare -i users=0
while [ $i -le 19 ]; do
if ! id user$i &> /dev/null; then
useradd user$i
if [ $? -eq 0 ];then
echo user$i | passwd --stdin user$i
fi
echo "Add user: user$i."
let users++
else
echo "user$i exists"
fi
let i++
done
echo "Add $users users."
14、在/tmp/創建10個空文件file10-file19;
#!/bin/bash
for i in {10..19};do
if [ -f /tmp/file$i ] ;then
echo "file$i exists"
else
touch /tmp/file$i
if [ $? -eq 0 ];then
echo "file$i creates."
else
echo "file$i dose not create."
fi
fi
done
15、把file10的屬主和屬組改爲user10,依次類推。
#!/bin/bash
for i in {10..19};do
if [ -f /tmp/file$i ] ;then
echo "file$i exists"
else
touch /tmp/file$i
if [ $? -eq 0 ];then
echo "file$i creates."
chown -R user$i:user$i file$i
else
echo "file$i dose not create."
fi
fi
done