N22+张zhangzhang+第6周博客作业

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

  vim编辑器是vi编辑器的增强版,是全屏文本编辑器,用于完成文本的输出、删除、查找、替换、块操作等众多功能。一般分三种模式:编辑模式、输入模式、末行模式。

1474290378333400.jpg

vim各种按键的功能

编辑模式:

1474292298478334.jpg

1474292890394758.jpg

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

cp /etc/rc.d/rc.sysinit /tmp
vim /tmp/rc.sysinit
:%s@^[[:space:]]\+[^[:space:]]\+@#&@g  ##在末行模式下输入替换命令

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

cp /boot/grub/grub,conf /tmp
vim /tmp/grub.conf 
:%s@^[[:space:]]\+@@g

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

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

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

:1,3s@^[^[:space:]]\+@#&@g

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

vim /etc/yum.repos.d/CentOS-Media.repo
:%s@\(enabled\|gpgcheck\)=0@\1=1@g

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

0 */4 * * * /usr/bin/cp -R /etc /tmp/backup/etc-`date +%Y%m%d%H%M`

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

* * * * 2,4,6 /usr/bin/cp -a /var/log/messages /backup/messages-`date +%Y%m%d%H`

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

* */2 * * 1-7 /usr/bin/grep -E "^S" >> /stats/memory.tex

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

* */2 * * 1-5 /usr/bin/echo “howdy”

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

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

#!/bin/bash
#创建目录
Name=/tmp/testdir-`date +%Y%m%d`
if [ -d $Name ] ; then
   echo "$Name exits"
else
   mkdir $Name
   echo "$Name have added"
fi
#创建空文件
for i in {1..100} ; do
   touch $Name/file$i &> /dev/null
   echo "$Name/file$i have created"
done

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

#!/bin/bash
#
Line=`wc -l /etc/passwd | cut -d" " -f1`
for i in ` seq 0 2 $Line ` ; do
     Username=` head -$i /etc/passwd | tail -1 | cut -d: -f1`
     echo "$i line username $Username"
done

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

#!/bin/bash
#
for i in {10..19} ; do
   if id user$i ; then
      echo "user $i exits"
      exit 1
   else
      useradd user$i
      echo "user$i" | passwd --stdin user$i
      echo "user$i have created"
   fi
done

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

#!/bin/bash
#

for i in {10..19} ; do
    if [ -e /tmp/file$i -a -s /tmp/file$i ] ; then
         echo " /tmp/file$i not kong file"
         exit 1
    else
         touch /tmp/file$i
         echo " /tmp/file$i have created"
    fi
done

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

#!/bin/bash
#
for i in {10..19} ; do
   if ! id user$i &> /dev/null ; then
       echo " no such user"
       useradd user$i &> /dev/null
       echo "have created"
   fi
   chown user$i:user$i /tmp/file$i
   ls -l /tmp/file$i
done

原创文章,作者:N22-北京-张zhangzhang,如若转载,请注明出处:http://www.178linux.com/47876

(0)
上一篇 2016-09-20 09:09
下一篇 2016-09-20 09:25

相关推荐

  • Linux发展及简单命令

    一 计算机的组成及其功能 冯·诺依曼提出的计算机体系结构:计算机由控制器、运算器、存储器、输入设备、输出设备五部分组成。 二 Linux的发行版 Linux发行版主要有三个分支:Debian、Slackware、Redhat。 (1)Debian:(以社区的方式运作) Ubuntu:基于Debian开发的开源Linux操作系统,主要针对桌面和服务器; Lin…

    2018-03-02
  • iptables 从入门到进阶

    Linux的防火墙体系主要工作在网络层,针对TCP/IP数据包实施过滤和限制,属于典型的包过滤防火墙(或网络层防火墙)。在Linux中netfilter和iptables都是指Linux防火墙。区别在于: netfilter:指的是Linux内核中实现包过滤防火墙的内部结构,不以程序或文件的形式存在,属于“内核态”的防火墙功能体系。 iptables:指的是…

    Linux干货 2017-01-10
  • 1.计算机的组成原理与linux初识

    计算机的组成原理 抽象 具体 Linux初识 负责与硬件交互,并向外提供系统调用 Linux大家庭 suse系列: opensuse suse enterprise redhat系列: centos redhat Debian系列: ubuntu debian 命令总结 显示本机IP(需要root权限) [root@localhost dev]# ifcon…

    Linux干货 2017-07-02
  • Linux基础知识—Vim编辑器/crond周期性任务计划

    vim文本编辑 vim是vi文本编辑的增强版本,因其编辑功能强大、且支持各种语言开发环境关键字自动增亮功能,也可称为是开发工具。在Centos7/RHEL7开始,默认将vi定义成vim –color=auto,已经取代了vi的地位。下面总结下关于vim工具的使用 vim有三种模式,每个模式下有其特定的功能;我们可自由在三者之间切换使用: COMM…

    Linux干货 2016-11-01
  • Linux文件属性及如何修改文件属性

    ls -al:显示文件的文件名与相关属性并列出所有文件详细的权限与属性   dr-xr-x—.   7       root     root       4…

    2017-04-03
  • keepalived实现lvs高可用并负载均衡lamp

    一、安装lamp     1、安装httpd(172.16.23.211) [root@cs1 ~]# yum install -y httpd     2、安装php(172.16.23.211) [root@cs1 …

    Linux干货 2016-05-14

评论列表(1条)

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

    crontab的都不对,在仔细想想