1、复制/etc/rc.d/rc.sysinit文件至/tmp目录,将/tmp/rc.sysinit文件中的以至少一个空白字符开头的行的行首加#;

cp /etc/rc.d/rc.sysinit /tmpvi /tmp/rc.sysinit    :%s/^[[:space:]]\+/#&/g

s替换、&引用前面查找到的整个内容、g全文操作

sed -i 's/^[[:space]]\+/#&/g' /tmp/rc.sysinit

2、复制/boot/grub/grub.conf至/tmp目录中,删除/tmp/grub.conf文件中的行首的空白字符;

cp /boot/grub/grub.conf /tmpvi /tmp/grub.conf    :%s/^[[:space:]]\+//
sed -i 's/^[[:space:]]\+//g' /tmp/grub.conf

3、删除/tmp/rc.sysinit文件中的以#开头,且后面跟了至少一个空白字符的行行的#和空白字符

vi /tmp/rc.sysinit    :%s/^#[[:space:]]\+//
sed -i 's/^[[:space:]]\+//g' /tmp/rc.sysinit

4、为/tmp/grub.conf文件中前三行的行首加#号;

vi /tmp/grub.conf:1,3s/^/&#/g
sed -i '1,3s/^/&#/g' /tmp/grub.conf

5、将/etc/yum.repos.d/CentOS-Media.repo文件中所有的enabled=0或gpgcheck=0的最后的0修改为1;

vi /etc/yum.repos.d/CentOS-Media.repos    :%s/enabled=0/enabled=1    :%s/gpgcheck=0/gpgcheck=1
sed 's/enabled=0/enabled=1/g;s/gpgcheck=0/gpgcheck=1/g' /etc/yum.repos.d/CentOS-Media.repos

6、每4小时执行一次对/etc目录的备份,备份至/backup目录中,保存的目录名为形如etc-201608300202

mkdir /backupmkdir /myshellvi /myshell/etcbackup4.shcd /tar zcf /backup/etc-`date +/%Y/%m/%n/%H/%M` ./etc
crontab -e0 */4 * * * /myshell/etcbackup4.sh > /dev/null 2> &1

7、每周2,4,6备份/var/log/messages文件至/backup/messages_logs/目录中,保存的文件名形如messages-20160830

crontab -e* * * * * 2,4,6 /bin/cp /var/log/messages /backup/messages_logs/messages-`date +%Y%m%d`

8、每天每两小时取当前系统/proc/meminfo文件中的所有以S开头的信息至/stats/memory.txt文件中

mkdir /statstouch memory.txtcrontab -e * */2 * * *  grep "^S" /proc/meminfo >> /stats/memory.txt

9、工作日的工作时间内,每两小时执行一次echo "howdy"

crontab -e* 9-17/2 * * 1-5  echo "howdy"

脚本编程练习

10、创建目录/tmp/testdir-当前日期时间; 

11、在此目录创建100个空文件:file1-file100

#!/bin/bashtestdir1=testdir-`date +%Y%m%d`mkdir -p /tmp/$testdir1#for i in `seq 1 100`; do# for i in {1..100}; do	touch /tmp/$testdir1/file$i;		if [ $? -eq 0 ]; then			echo "Creat file$i success."		fidone#		sed -n 'n;p' /etc/passwd | cut -d: -f1

12、显示/etc/passwd文件中位于第偶数行的用户的用户名;

sed -n 'n;p' /etc/passwd | cut -d: -f1sed -n '2-2p' /etc/passwd

    偶数行-n,仅显示脚本处理后的结果

# sed -n 'p;n' /etc/passwd | cut -d: -f1#sed -n '1-2p' /etc/passwd

奇数行

            n:读取下一行,用下一个命令执行;p:打印

13、创建10用户user10-user19;密码同用户名;

14、在/tmp/创建10个空文件file10-file19; 

15、把file10的属主和属组改为user10,依次类推。

#!/bin/bashfor i in {10..19}; do    if id user$i &> /dev/null; then        echo "user$i exists."    else        useradd user$i            if [ $? -eq 0 ]; then                echo "user$i" | passwd --stdin user$i &> /dev/null                echo "Add user$i success."            fi    fi               touch /tmp/file$i          chown user$i:user$i /tmp/file$i#创建文件不需要进行判断done