从Linux小白到大牛——与狼共舞的日子6

马哥教育网络班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

(0)
N21_孤狼N21_孤狼
上一篇 2016-10-31
下一篇 2016-10-31

相关推荐

  • 马哥教育网络班21期+第11周课程练习

    1、请描述一次完整的加密通讯过程,结合图示最佳。 Bob先利用单向加密算法提取当前数据的指纹(特征码),再用自己的私钥加密数据指纹并附加于数据尾部,然后利用对称加密将整个文件加密,之后用对方的公钥加密对称加密密钥附加于尾部。 Alice收到数据后,先用自己的私钥解密,得到对称加密密钥,之后用对称加密密钥解密,然后用Bob的公钥解密得到数据指纹,并且验证了Bo…

    Linux干货 2016-09-26
  • 进程管理之进程基础及操作命令

    进程管理 今天我们开始讲进程管理的相关知识,进程是学习LInux系统的重要一节内容,不仅能更帮助我们了解LInux系统的原理组成,又能方便我们在平常运维工作中的管理工作,帮助我们故障排查.希望大家牢固的掌握进程知识. 以下是我们分享的内容: 概论 进程控制 进程管理工具 概论 程序执行: 多道程序的执行分为顺序执行和并发执行 程序顺序执行时的特征: &nbs…

    Linux干货 2016-09-07
  • 第四周作业

    1. 复制/etc/skel目录为/home/tuser1,要求/home/tuser1以及内部文件的属组和其它用户均没有任何访问权限 cp -r /etc/skel  /home/tuser1 chmod go-rwx /home/tuser1 2. 编辑/etc/group文件,添加组hadoo…

    Linux干货 2016-12-27
  • 马哥教育网络21期+第十一周练习博客(下)

    马哥教育网络21期+第十一周练习博客(下) 3、描述DNS查询过程以及DNS服务器类别。 DNS:Domain Name Service 通俗的称为地址解析,使用TCP和UDP的53端口,是属于应用层的协议; DNS查询有2种方式:     递归查询:至发送一次请求,就能找到最终的结果的查…

    Linux干货 2016-09-26
  • 文本三剑客之sed用法总结

    描述:    sed是Stream EDitor(行编辑器)的简写,是一种流编辑器,它一次处理一行内容。处理时,把当前处理的行存储在临时缓冲区中,称为“模式空间”(pattern space ),接着用sed 命令处理缓冲区中的内容,处理完成后,把缓冲区的内容送往屏幕。接着处理下一行,这样不断重复,直到文件末尾。文件内容并没有改变,除非你…

    Linux干货 2016-08-10
  • Linux用户和组的相关命令(二、组的相关命令)

    用户和组之间息息相关。创建用户时 ,Linux系统会默认生成一个与用户名相同的组,这个组是用户的私有组,也是用户的主组。对用户来说,主组有且只有一个,但是可以有零个或多个附加组。可以在组内设置组管理员来管理组内的用户列表,组管理员可以删除用户列表内的组员。组管理员不唯一,可以有零个或多个。 关于组及其属性和组密码及其属性的有关信息保存在/etc/group和…

    2017-07-22

评论列表(1条)

  • 马哥教育
    马哥教育 2016-11-02 14:18

    博客写得非常的好,32个赞,思路清晰,加油!