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

相关推荐

  • Ansible+Corosync+Pacemaker+nfs实现http高可用

    目录: (一)实验环境 (二)准备工作 (三)为node1和node2配置基础配置 (四)使用ansible部署nfs (五)使用ansible部署corosync和pacemaker (六)使用ansible安装crmsh工具 (七)使用crmsh配置http高可用 (八)验证 (九)需要注意的地方 (一)实验环境 1.1、环境拓扑 1.2、所需系统 4台…

    Linux干货 2016-04-29
  • 十七周

    1、搭建一套LVS-DR模型的高性能集群,并实现以下功能:    (1)、wordpress程序通过nfs共享给各个realserver;    (2)、后端realserver中的nginx和php分离 Centos7系统 地址 安装程序 LVS主机 VIP:192.168.1.110 ipvsadm DIP:192…

    2017-08-17
  • 网络管理之nmcli命令的使用

    nmcli命令      地址配置工具:nmcli nmcli[ OPTIONS ] OBJECT { COMMAND | help }     device -show and manage network interfaces     …

    Linux干货 2016-09-19
  • vim及脚本

    1、复制/etc/rc.d/rc.sysinit文件至/tmp目录,将/tmp/rc.sysinit文件中的以至少一个空白字符开头的行的行首加#。     第一步:     [root@localhost ~]# cp /etc/rc.d/rc.sy…

    Linux干货 2016-12-02
  • Linux基础之用户及组管理

    grep扩展应用,用户管理,组管理,用户及组管理命令

    2018-01-31
  • 用户和组的管理

    通过命令、passwd和shadow的格式,讲述了用户和组的管理

    Linux干货 2017-12-17