马哥教育网络班21期+第6周课程练习
请详细总结vim编辑器的使用并完成以下练习题
1、复制/etc/rc.d/rc.sysinit文件至/tmp目录,将/tmp/rc.sysinit文件中的以至少一个空白字符开头的行的行首加#;
[root@localhost ~]# cp /etc/rc.d/rc.sysinit /tmp/ [root@localhost ~]# vim /tmp/rc.sysinit :%s@^[[:space:]]@#&@g
2、复制/boot/grub/grub.conf至/tmp目录中,删除/tmp/grub.conf文件中的行首的空白字符;
[root@localhost ~]# cp /boot/grub/grub.conf /tmp/ [root@localhost ~]# vim /tmp/grub.conf :%s@^[[:space:]]\+@@g
3、删除/tmp/rc.sysinit文件中的以#开头,且后面跟了至少一个空白字符的行行的#和空白字符
[root@localhost ~]# vim /tmp/rc.sysinit :%s@^#[[:space:]]\+@@g
4、为/tmp/grub.conf文件中前三行的行首加#号;
[root@localhost ~]# vim /tmp/grub.conf :1,3s@^.@#&@g
5、将/etc/yum.repos.d/CentOS-Media.repo文件中所有的enabled=0或gpgcheck=0的最后的0修改为1;
[root@localhost ~]# vim /etc/yum.repos.d/CentOS-Media.repo :%s@\(enabled\|gpgcheck\)=0@\1=1@g
6、每4小时执行一次对/etc目录的备份,备份至/backup目录中,保存的目录名为形如etc-201504020202
[root@localhost ~]# mkdir /backup [root@localhost backup]# crontab -e 0 */4 * * * /bin/cp -a /etc /backup/etc-`date '+\%Y\%m\%d\%H\%M'`
7、每周2,4,6备份/var/log/messages文件至/backup/messages_logs/目录中,保存的文件名形如messages-20150402
[root@localhost ~]# mkdir /backup/messages_logs [root@localhost ~]# crontab -e 0 0 * * 2,4,6 /bin/cp -a /var/log/messages /backup/messages_logs/messages-`date '+\%Y\%m\%d'`
8、每天每两小时取当前系统/proc/meminfo文件中的所有以S开头的信息至/stats/memory.txt文件中
[root@localhost ~]# mkdir /stats [root@localhost ~]# crontab -e 0 */2 * * * /bin/grep ^S /proc/meminfo >> /stats/memory.txt
9、工作日的工作时间内,每两小时执行一次echo "howdy"
[root@localhost ~]# crontab -e 0 9-21/2 * * 1-5 /bin/echo "howdy"
脚本编程练习
10、创建目录/tmp/testdir-当前日期时间;
[root@localhost ~]# cat date.sh #!/bin/bash # mkdir /tmp/testdir-`date +%Y%m%d%H%M%S`
11、在此目录创建100个空文件:file1-file100
[root@localhost ~]# cat file.sh #!/bin/bash # for i in {1..100};do if [ -f file$i ];then echo "file$i exists." else touch file$i echo "file$i create." done
12、显示/etc/passwd文件中位于第偶数行的用户的用户名;
[root@localhost ~]# cat username.sh #!/bin/bash # for i in $(seq 2 2 $[`cat /etc/passwd | wc -l`]);do head -$i /etc/passwd | tail -1 | cut -d: -f1 done
13、创建10用户user10-user19;密码同用户名;
[root@localhost ~]# cat user1.sh #!/bin/bash # for i in {10..19};do if ! id user$i &>/dev/null;then useradd user$i echo user$i | passwd --stdin user$i &>/dev/null echo "user$i create." else echo "user$i exists." fi done
14、在/tmp/创建10个空文件file10-file19;
[root@localhost ~]# cat file1.sh #!/bin/bash # for i in {10..19};do if [ -f /tmp/file$i ];then echo "file$i exists." else touch /tmp/file$i echo "file$i create." fi done
15、把file10的属主和属组改为user10,依次类推。
[root@localhost ~]# cat owner.sh #!/bin/bash # for i in {10..19};do if [ -f /tmp/file$i ];then ! id user$i &>/dev/null && echo "user$i no exists." || chown $i.$i file$i [ $? -eq 0 ] && echo "owner and group is $i" else echo "file$i no exists." fi done
原创文章,作者:N21_孤狼,如若转载,请注明出处:http://www.178linux.com/55113
评论列表(1条)
博客写得非常的好,32个赞,思路清晰,加油!