N22-第六周作業

請詳細總結vim編輯器的使用并完成以下練習題

     vim是模式化的文本編輯器。在不同模式下,每一次按鍵的效果都不一樣。vim有三種工作模式,分別是編輯模式,插入模式和末行模式。編輯模式是打開vim后的默認模式,用于查看文本或進行復制,粘貼,刪除等編輯命令。插入模式是為了向文本中輸入信息。末行模式是vim自帶的命令行接口,能向vim發起命令,例如,全局替換某字符串或保存退出等。在編輯模式下按下i,o,O可轉入插入模式,輸入完成后按下Esc返回編輯模式。編輯模式下按下:可進入末行模式。

編輯模式:

     編輯模式的主要目的是為了查看文檔的。hlkj能讓光標分別向左右上下移動??墒褂肅trl+f或Ctrl+b向后翻屏或向前翻屏快速查看內容?;蚴褂脀讓光標在單詞間跳轉。也能使用#G直接讓光標跳轉到第#行。編輯模式的另一個重要功能是執行文本編輯命令??梢杂脁刪除光標處字符,用rCHAR直接替代光標處的字符??梢杂脃y復制一行內容,然后用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.www58058.com/49057

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

相關推薦

  • Homework Week-2 Linux文件管理

    1、Linux上的文件管理命令都有哪些,其常用的使用方法及其相關示例演示。 文件管理工具:cp, mv, rm         cp命令:copy  源文件  目標文件                單源復制:cp [O…

    Linux干貨 2016-08-22
  • 用戶和組的管理

    前言 服務器最主要的工作是提供可靠的服務,提供服務就必須對外開放自己的網絡,可靠就需要一定的機制來保證了。Linux中有一個3A的機制,首先是認證,就是我們經常聽到的一句話,怎么證明你就是你;其次是授權,管理一個服務器,每個管理員都有自己的職責,那么我們就只分配對應的權限給特定的人,這樣就可以明確事故的責任,從源頭甩鍋;最后是審計,總有一些黑客可以通過各種手…

    Linux干貨 2016-10-22
  • Linux啟動之grub詳解,故障排除,自建linux

    概述     上篇我們以CentOS6為例介紹了一下系統啟動流程,本篇將承接上篇,詳細的介紹一下系統啟動流程中的grub,以及系統啟動過程中的各種故障的排除,以及利用現有內核自己構建一個能夠正常啟動的簡單Linux系統。具體分為一下幾個部分:     1、grub相關概念詳解 &…

    Linux干貨 2016-09-13
  • 簡單的shell腳本結合awk實現防止對web服務的dos攻擊

    一 實驗環境         鄙人使用的是centos 6.8操作系統   需要安裝iptables(常見的linux系統貌似都會自動安裝iptables)這條可以忽略   awk也需要安裝沒有的話就用yum裝下吧       &…

    2017-04-24
  • 磁盤管理詳解

    linux系統如何識別硬盤 硬盤類型:        按接口可劃分為        并行             &nb…

    Linux干貨 2016-08-29
  • 進程管理

    一、進程概述 1、進程的概念        用戶通過執行命令,將程序提起到內存中運行,運行中的程序即稱為進程。內核為了方便管理,根據內核發起者的權限、屬性等參數,為每個進程設置一個獨立的PID號,通過PID號來判斷進程的權限。 2、進程的分類:    &nbs…

    Linux干貨 2016-09-07

評論列表(1條)

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

    寫的很好,怎么還有沒做的?。?/p>

欧美性久久久久