N22-第六周作业

请详细总结vim编辑器的使用并完成以下练习题

     vim是模式化的文本编辑器。在不同模式下,每一次按键的效果都不一样。vim有三种工作模式,分别是编辑模式,插入模式和末行模式。编辑模式是打开vim后的默认模式,用于查看文本或进行复制,粘贴,删除等编辑命令。插入模式是为了向文本中输入信息。末行模式是vim自带的命令行接口,能向vim发起命令,例如,全局替换某字符串或保存退出等。在编辑模式下按下i,o,O可转入插入模式,输入完成后按下Esc返回编辑模式。编辑模式下按下:可进入末行模式。

编辑模式:

     编辑模式的主要目的是为了查看文档的。hlkj能让光标分别向左右上下移动。可使用Ctrl+f或Ctrl+b向后翻屏或向前翻屏快速查看内容。或使用w让光标在单词间跳转。也能使用#G直接让光标跳转到第#行。编辑模式的另一个重要功能是执行文本编辑命令。可以用x删除光标处字符,用rCHAR直接替代光标处的字符。可以用yy复制一行内容,然后用p粘贴这一行内容。用dd可以快速删除某一行。u命令能够撤销前一次编辑操作。

末行模式:

     主要能实现多行复制,删除。查找替换功能。.,20y表示复制光标所在行到20行之间的行。1,$d表示删除全文。查找替换的一般格式为s@查找的内容@替换的内容@g。其中查找内容可用标准正则表达式。

  

1、复制/etc/rc.d/rc.sysinit文件至/tmp目录,将/tmp/rc.sysinit文件中的以至少一个空白字符开头的行的行首加#;

:%s@^[[:space:]]\+@#&@

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

:%s@^[[:space:]]\+@@

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

:%s@^#[[:space:]]\+@@

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

:1,3s/.*/#&/

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

:%s@gpgcheck=0@gpgcheck=1@g

:%s@enable=0@enable=1@g

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

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

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

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

~]# crontab -l

SHELL=/bin/bash

PATH=/sbin:/bin:/usr/sbin:/usr/bin

MAILTO=root

0 */4 * * * cp /etc /backup/etc-$(date +%Y%m%d%H%M%S)

0 8 * * 2,4,6 cp /var/log/messages /backup/messages_logs/messages-$(date +%Y%m%d)

0 */2 * * * grep "^S" /proc/meminfo > /stats/memory.txt

0 9,11,13,15,17 * * 1,2,3,4,5 echo "howdy"

脚本编程练习

10、创建目录/tmp/testdir-当前日期时间;

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

~]# cat t1

#!/bin/bash

#

mkdir /tmp/testdir-$(date +%Y%m%d%H%M%S)

cd  /tmp/testdir-$(date +%Y%m%d%H%M%S)

for i in {1..100};do

touch file$i

done

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

~]# cat t2

#!/bin/bash

#

count_line=$(cat /etc/passwd | wc -l)

for i in `seq $count_line`;do

if [ $[$i%2] -eq 0 ];then

head -n $i /etc/passwd | tail -n 1 | cut -d: -f1

fi

done

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

~]# cat t3

#!/bin/bash

#

for i in `seq 10 19`;do

useradd user$i

echo "user$i" | passwd –stdin user$i

done

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

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

~]# cat t4

#!/bin/bash

#

cd /tmp

for i in `seq 10 19`;do

touch file$i

chown user$i.user$i file$i

done

原创文章,作者:上海-brown,如若转载,请注明出处:http://www.178linux.com/49057

(0)
上海-brown上海-brown
上一篇 2016-09-26 07:43
下一篇 2016-09-26 07:43

相关推荐

  • Mariadb数据库复制系列(五):基于SSL的复制

       实验五:基于SSL的主从复制功能的实现 在mysql服务器之间复制数据,默认情况下都是基于明文的,在有些场景中,明文传输会造成严重的数据安全隐患,因此,需要对mysql服务器之间的复制时的传输进行加密,传输加密方式可以基于SSL的会话进行 1、实验环境 2、私有CA的搭建 3、在主节点node72上生成证书签署请求、发送到私有CA服务器 4、在从节点n…

    Linux干货 2016-11-24
  • N25-第六周作业

      复制/etc/rc.d/rc.sysinit文件至/tmp目录,将/tmp/rc.sysinit文件中的以至少一个空白字符开头的行的行首加#;               s/要查找的内容/替换为的内容/修饰符 %:全文,相当…

    Linux干货 2017-02-13
  • ip子网划分

    ip子网划分 人们为了通信方便,给每台计算机分配了一个类似我们电话号码一样的标识地址。IP就好比一个人的指纹一样,在INTERNET中是独一无二的(公网中)。我们可以通过ip查询到使用该ip的主机。 现在的IP分为ipv4和ipv6。前者是32位二进制组成,为了防止IP不够用由此研发出后者ipv6,ipv6是由128位二进制组成。ipv6中包含ip的数量相当…

    Linux干货 2017-07-01
  • 游戏运维工程师

    爱乐盟互动为深圳市政府评定的深圳市重点文化企业,同时为广东省高科技产业商会常务理事单位,注册资金人民币1000万元。公司的原创大型MMORPG网游《王者传说2》为深圳市政府重点支持的网游项目,《王者传说2》将全面领先于国内的同类产品,成为业界新标准的重要网游产品!! 《王者传说2》已进入产品研发的重要阶段。除《王者传说2》,爱乐盟也已经启动了数款全新大型网游…

    Linux干货 2016-10-19
  • 基于ssl协议和openssl工具建立私有CA

    前言     要自建CA需先了解openssl工具和ssl协议还有各加密类型     ssl(Secure Socket Layer)安全套接字层当前版本为3.0,浏览器与Web服务器之间的身份认证和加密数据传输,它工作在传输层和各应用层之间,用户可以选择是否使用ssl进行传输,选择ssl协议将调用…

    Linux干货 2015-05-07
  • 马哥教育网络19期+第十八周课程练习

    1、为LNMP架构添加memcached支持,并完成对缓存效果的测试报告; LNMP的安装过程不再赘述. # yum install -y memcached # cat /etc/sysconfig/memcached  PORT="11211" &nbsp…

    Linux干货 2016-09-19

评论列表(1条)

  • 马哥教育
    马哥教育 2016-09-27 09:47

    写的很好,怎么还有没做的啊?