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

相关推荐

  • N27_第六周作业

    请详细总结vim编辑器的使用并完成以下练习题 基本模式:编辑模式(命令模式),输入模式,末行模式 模式转换: 编辑模式–输入模式: i:insert,在光标所在处前方输入 a:append,在光标所在处后方输入 o:在光标所在处的下方新建一行 I:在光标所在行行首输入 A:在光标所在处行尾输入 O:在光标所在处的上方打开一个新行 输入模式&#82…

    Linux干货 2017-10-26
  • ACL权限实例详解

    CentOS7当中,无论是操作系统安装时还是之后手工创建的文件系统(xfs、ext4)均会开启ACL功能。 CentOS6及之前的版本,仅操作系统安装时创建的文件系统才会默认开启ACL,手工创建的文件系统,需要手工开启ACL 功能。 Acl如何设置 创建分区 mount -o acl /dev/sda7  取消的方式,重新挂载时不指定即可 tune…

    2017-07-29
  • openvpn安装配置过程

    前言     之前为了方便远程办公时访问公司的内部系统,如:svn、OA、wiki、禅道等等;通通在防火墙上做了端口映射。然后有个内部系统被黑了,各种弱口令没办法。果断关闭端口映射,看来还是得搭建个VPN服务器,vpn设备感觉大材小用。马上就想到了开源的openvpn,下面就来介绍openvpn的安装配置过程。 ope…

    Linux干货 2015-05-11
  • vsdf

    Linux干货 2017-10-23
  • 使用sudo对用户进行权限管理

    使用sudo对用户进行权限管理 因为root用户权限太大,一般在实际应用的时候 ,为了避免造成错误泛滥和找不到责任人都需要对使用服务器人员进行权限分配,除了系统管理员外,其他人禁止使用root,但可以通过sudo命令,给自己提权。同时通过日志审计进行监控操作,操作如下: 1.禁止普通用户使用su命令到root # usermod -g wheel user0…

    Linux干货 2017-03-26
  • keepalived+nginx 实现 sharepoint 负载均衡

    keepalived 实现虚拟路由
    nginx 做反向代理和负载均衡

    Linux干货 2017-12-20