首页 > 代码库 > 第六周作业
第六周作业
1、复制/etc/rc.d/rc.sysinit文件至/tmp目录,将/tmp/rc.sysinit文件中的以至少一个空白字符开头的行的行首加#;
答: # cp/etc/rc.d/rc.sysinit /tmp 方法一:用sed # sed -i ‘s/\(^[[:space:]]\)/#\1/g‘/tmp/rc.sysinit 方法二: # vim/tmp/rc.sysinit 1):%s@^ \+@#&@g 2):%s@^[[:space:]]\+@#&@g 3):%s@^\( \+\)@#\1@g 4):%s@\(^ \+\)@#\1@g 说明: sed-i:直接修改读取的文件内容,而不是输出到终端; [[:space:]]:表格空白字符; ^:行首锚定;此题中^放在括号里和括号外匹配的效果是一样的; s :在末行模式下完成查找替换操作; s/要查找的内容/替换为的内容/修饰符 要查找的内容:可使用模式; 替换为的内容:不能使用模式,但可以使用\1,\2, . . .等后向引用符号,还可以使用“&” 引用起码查找时查找到的整个内容; 修饰符: i:忽略大小写; g:全局替换,默认情况下,每一行只替换第一次出现; 查找替换中的分隔符/可替换为@,#;例如:s///,s@@@,s###;
2、复制/boot/grub/grub.conf至/tmp目录中,删除/tmp/grub.conf文件中的行首的空白字符;
答: # cp/boot/grub/grub.conf /tmp 方法一: # sed -i ‘s/^[[:space:]]\+//g‘/tmp/grub.conf 方法二: # vim/tmp/grub.conf :%s#^[[:space:]]\+##g
3、删除/tmp/rc.sysinit文件中的以#开头,且后面跟了至少一个空白字符的行的#和空白字符;
答: #vim /tmp/rc.sysinit 方法一: :%s@^#[[:space:]]\+@@g 方法二: # sed -i ‘s@^#[[:space:]]\+@@g’/tmp/rc.sysinit
4、为/tmp/grub.conf文件中前三行的行首加#号;
答: 方法一: # sed -i ‘1,3s@\(^.\)@#\1@g‘ /tmp/grub.conf 方法二: # vim /tmp/grub.conf :1,3s@^.@#&@g
5、将/etc/yum.repos.d/CentOS-Media.repo文件中所有的enabled=0或gpgcheck=0的最后的0修改为1;
答: 方法一: # sed -i ‘s/enabled=0/enabled=1/g;s/gpgcheck=0/gpgcheck=1/g‘ /etc/yum.repos.d/CentOS-Media.repo 方法二: # vim/etc/yum.repos.d/CentOS-Media.repo :%s/enabled=0/enabled=1/g :%s/gpgcheck=0/gpgcheck=1/g
6、每4小时执行一次对/etc目录的备份,备份至/backup目录中,保存的目录名为形如etc-201608300202
答: # 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-20160830
答: # crontab -e * * * * 2,4,6 /bin/cp -a /var/log/messages /backup/messages_logs/messages-$(date+%Y%m%d)
8、每天每两小时取当前系统/proc/meminfo文件中的所有以S开头的信息至/stats/memory.txt文件中;
答: # crontab -e 0 */2 * * * /bin/egrep ‘^S’ /proc/meminfo>> /stats/memory.txt
9、工作日的工作时间内,每两小时执行一次echo "howdy";
答: # crontab -e 0 8-18/2 * * 1-5 /bin/echo “howdy”
脚本编程练习
10、创建目录/tmp/testdir-当前日期时间;
答: [root@ilinux tmp]# vim testdir.sh #!/bin/bash mkdir/tmp/testdir-$(date +%Y%m%d) [root@ilinux tmp]# chmod +x testdir.sh [root@ilinux tmp]# . testdir.sh [root@ilinux tmp]# ll drwxr-xr-x. 2 root root 4096 Sep 12 20:02 testdir-20160912
11、在此目录创建100个空文件:file1-file100;
答: [root@ilinux tmp]# vim file100.sh #!/bin/bash # for f in {1..100};do touch file$f done [root@ilinux tmp]# chmod +x file100.sh [root@ilinux file1-file100]# ./file100.sh
12、显示/etc/passwd文件中位于第偶数行的用户的用户名;
答: 方法一: # sed -n ‘n;p‘ /etc/passwd | cut -d: -f1 方法二: # sed -n ‘2~2p’ /etc/passwd | cut -d: -f1
13、创建10用户user10-user19;密码同用户名;
答: # vim adduser.sh #!/bin/bash # for i in {10..19};do if id user$i &> /dev/null;then echo "user$i isexists." else useradd user$i echo "user$i | passwd--stdin user$i" fi done # ./adduser.sh
14、在/tmp/创建10个空文件file10-file19;
答: 方法一: for i in {10..19};do touch /tmp/file$i done 方法二: for i in `seq 10 19`;do touch /tmp/file$i done
15、把file10的属主和属组改为user10,依次类推。
答: 方法一: for i in {10.19};do chown user$i:user$i /tmp/file$i done 方法二: for i in `seq 10 19`;do chown user$i:user$i /tmp/file$i done
本文出自 “ilinux” 博客,请务必保留此出处http://shenzhijin.blog.51cto.com/1741240/1853663
第六周作业