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

请详细总结vim编辑器的使用并完成以下练习题
1、复制/etc/rc.d/rc.sysinit文件至/tmp目录,将/tmp/rc.sysinit文件中的以至少一个空白字符开头的行的行首加#;

%s/^([[:space:]]{1,}.*)/#\1/s

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

%s/^[[:space:]]{1,}/

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

%s/^(#[[:space:]]{1,})//

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

1,3s/^/#/

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

%s/(gpgcheck=\|enabled=)[[:digit:]]/\10/g

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

0 */4 * * * [ -d /backup ] || mkdir /backup ; /bin/cp -r /etc /backup/etc-$(date +\%Y\%m\%d\%H\%M)

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

0 0 * * 2,4,6 [ -d /backup/message</em>logs ] || mkdir -p /backup/message<em>logs ; /bin/cp /var/log/messages /backup/message</em>logs/messages-$(date +\%Y\%m\%d)

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

0 */2 * * * [ -d /stats ] || mkdir /stats;grep '^S' /proc/meminfo &gt;&gt; /stats/memory.txt

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

0 9-18/2 * * 1-5 echo "howdy"

脚本编程练习
10、创建目录/tmp/testdir-当前日期时间;

    #!/bin/bash
    mkdir /tmp/testdir-$(date +\%F-\%H-\%m)

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

    #!/bin/bash
    [ -e /tmp/testdir-$(date +\%F) ] &amp;&amp; rm -rf /tmp/testdir-$(date +\%F)
    mkdir /tmp/testdir-$(date +\%F)
    DIR=/tmp/testdir-$(date +\%F)
    touch $DIR/file{1..100}

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

    #!/bin/bash
    #
    HH=<code>awk '{print NR}' /etc/passwd | tail -1</code>
    for i in <code>seq 2 2 $HH</code>;do
    head -$i /etc/passwd | tail -1 | awk -F: '{print $1}'
    done

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

    #!/bin/bash
    #
    for i in {10..19};do
        id user$i &gt;&gt; /dev/null 2&gt;&amp;1
        if [ $? -eq 0 ];then
            echo "user$i is already exit"
        else
            useradd user$i
            sleep 3
            echo "user$i" | passwd --stdin user$i
        fi
    done

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

    #!/bin/bash
    #
    for i in {10..19};do
        [ -e /tmp/file$i ] &amp;&amp; echo "file$i is exit " || touch /tmp/file$i
    done

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

    #!/bin/bash
    #    for i in {10..19};do
        [ -e /tmp/file$i ] &amp;&amp; echo "file$i is exit " || touch /tmp/file$i
        chown user$i.user$i /tmp/file$i
        /bin/ls -l /tmp/file$i
    done

原创文章,作者:hhaa0352,如若转载,请注明出处:http://www.178linux.com/32171

(0)
hhaa0352hhaa0352
上一篇 2016-08-10 10:15
下一篇 2016-08-10 10:22

相关推荐

  • 基于heartbeat v2 crm实现基于nfs的mysql高可用集群

    前言 因heartbeat v1内置的资源管理器haresource功能比较简单,且不支持图形化管理,所以heartbeat v2不再支持haresource,转而使用更加强大的资源管理器crm进行集群管理。本文将讲解如何基于heartbeat v2 crm实现基于nfs的mysql高可用集群。 高可用实现 实验拓扑 实验环境 node1:172.16.10…

    Linux干货 2015-06-11
  • SED命令

    sed是一种流编辑器,它一次处理一行内容。处理时,把当前处理的行存储在临时缓冲区中,称为“模式空间”(pattern space),接着用sed命令处理缓冲区中的内容,处理完成后,把缓冲区的内容送往屏幕。接着处理下一行,这样不断重复,直到文件末尾。文件内容并没有改变,除非你使用重定向存储输出。Sed主要用来自动编辑一个或多个文件,简化对文件的反复操作,编写转…

    Linux干货 2017-05-01
  • session sticky + session cluster 实战

    前言 在做负载均衡集群的时候,如果后端是应用服务器,我们就有一个不得不考虑的一个问题:会话绑定。为了追踪会话,我们常见的有三种方式:(1)session sticky:会话粘性,常见有2种方式: source_ip:采用源地址绑定方式 nginx:ip_hash,ip地址哈希 haproxy:source lvs:sh,源地址哈希 cookie:基于cook…

    Linux干货 2017-02-13
  • python 10第二周博客作业

    1.取磁盘利用率:cut -d命令 df|tr –s  ‘ ’   ‘%’ |cut –d “%” –f5正则表达式:df -h |grep “^/dev/sd” |grep -o “[[:digit:]]\+%”|grep -o “[[:digit:]]\+”2. paste 合并两个…

    Linux干货 2018-03-17
  • N22-​Linux系统的基础命令

                                     Linux系统的基础命令 命令的语法通用格式:# COMMAND OPTIONS  ARGUMENTS COMMA…

    Linux干货 2016-08-15