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