馬哥教育網絡班21期+第6周課程練習

VIM基礎知識

常用模式:

編輯模式-->命令模式
輸入模式
末行模式:內置的命令行接口

模式轉換:

編輯模式-->輸入模式
i:在光標所在處前轉換為輸入模式;
a:在光標所在后面轉入輸入模式;
o:在當前光標所在行的下方打開一個新行,并轉為輸入模式;
I:在當前光標所在行的行首輸入;
A:在當前光標所在行的行尾輸入;
O:在當前光標所在行的上方打開一個新行,并轉為輸入模式;

模式之間的互相轉換:

輸入模式-->編輯模式==>ESC
編輯模式-->末行模式==>:
末行模式-->編輯模式==>:ESC

關閉與退出

:q 退出
:q!強制退出
:wq保存退出
:x 保存退出

單詞間跳轉

w:跳至下個單詞的詞首
e:跳轉至下一個單詞的詞尾
b:跳至當前詞的詞首

編輯模式:

字符編輯:
x: 剪切光標處單個字符:
#x:剪切光標所在處起始的#個字符;
xp:先剪切(x),然后光標后移,最后是粘貼(p),最終效果就是兩個字母交換;

刪除命令:
d:刪除命令,可結合光標跳轉字符,實現范圍刪除;
例如:d$,d^,d0
dd:刪除光標所在的行;
    #dd:多行刪除;

復制命令:
y:復制,工作行為相似于d命令;
yy:復制行
    #yy:復制多行;


撤銷此前的編輯:
    u:撤銷此前的操作;
    #u:撤銷指定次數的操作;

撤銷此前的撤銷:
    Crtl+r

翻屏操作:
    Crtl+f:向文件尾部翻一屏;
    Ctrl+b:向文件首部翻一屏;
    Crtl+d:向文件尾部翻半屏;
    Crtl+u:向文件首部翻半屏;

末行模式:

內置命令行接口
(1)地址定界-->:start_pos,end_pos
#:具體第#行,例如2,100;
#,#:從左側#表示行起始,到右側#表示行結尾:
#,+#:1,+3:從左側#表示的行起始,加上右側#表示的行數:
.:當前行:
$:最后一行:
%:全文,相當于1,$

/pat1/,/pat2/:
從第一次被pat1模式匹配到的行開始,一直到第一次pat2匹配到的行結束:
使用方式:

后跟一個編輯命令:
    d:在指定輸出后進行刪除;
    w /PATH/TO/SOMEWHERE:將范圍內的行另存至指定文件中;
    r /PATH/FROM/SOMEFILE: 在指定位置插入指定文件中的所有內容;

(2)查找:
    /PATTERN:從當前光標所在處向文件尾部查找
    ?PATTERN:從當前光標所在處向文件首部查找:
        n:與命令同方向:
        N:與命名反方向:

(3)查找并替換:
    s:在末行模式下完成查找替換操作
    s/要查找的內容/替換為的內容/修飾符
        要查找的內容:可使用模式
        替換為的內容:不能使用模式,但可以使用\1,\2...等后向引用符號,還可以使用“&”引用前面查找時查找到的整個內容:
        修飾符:
            i:忽略大小寫
            g:全局替換:默認情況下,每一行只替換第一次出現:
            查找替換中的分隔符/可替換為其他字符,例如:
            s@@@
            s###

獲取幫助:

    :help 
    :help subject

操作練習

1、復制/etc/rc.d/rc.sysinit文件至/tmp目錄,將/tmp/rc.sysinit文件中的以至少一個空白字符開頭的行的行首加#;

[root@itop ~]# cp /etc/rc.d/rc.sysinit /tmp/rc.sysinit 
[root@itop tmp]# vim rc.sysinit
:%s/^[[:space:]]\+/#&/g

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

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

3、刪除/tmp/rc.sysinit文件中的以#開頭,且后面跟了至少一個空白字符的行行的#和空白字符

[root@itop ~]# cp /etc/rc.d/rc.sysinit /tmp/rc.sysinit 
[root@itop tmp]# vim rc.sysinit
:%s/^#[[:space:]]\+//g

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

[root@itop ~]# cp /boot/grub/grub.conf /tmp/grub.conf
[root@itop tmp]# vim grub.conf
:1,3s/^/#&/

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

[root@itop ~]# vim /etc/yum.repos.d/CentOS-Media.repo 
:%s/enabled=0/enabled=1
:%s/gpgcheck=0/gpcheck=1

6、每4小時執行一次對/etc目錄的備份,備份至/backup目錄中,保存的目錄名為形如etc-201504020202

[root@itop ~]# crontab -e 
* */4 * * * cp -rf /etc /backup/etc-`date +\%Y\%m\%d\%H\%M`

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

[root@itop ~]# crontab -e
 1 * * * 2,4,6 cp /var/log/messages /backup/messages_logs/messages-`date +\%Y\%m\%d`

8、每天每兩小時取當前系統/proc/meminfo文件中的所有以S開頭的信息至/stats/memory.txt文件中

[root@itop ~]# crontab -e 
* */2 * * * grep "^s" /proc/meminfo >> /stats/memory.txt

9、工作日的工作時間內,每兩小時執行一次echo "howdy"

[root@itop ~]# crontab -e
 * 8-18/2 * * 1,2,3,4,5 echo "howdy"

腳本編程練習

10、創建目錄/tmp/testdir-當前日期時間;

#/bin/bash 
#mkdir -p /tmp/testdir-`date +\%Y\%m\%d\%H\%M`

11、在此目錄創建100個空文件:file1-file100

#/bin/bash 
for i in  {1..100};
do
touch file$i
done

12、顯示/etc/passwd文件中位于第偶數行的用戶的用戶名;

#!/bin/bash
sed -n 'n;p' /etc/passwd | cut -d: -f1

13、創建10用戶user10-user19;密碼同用戶名;

for i in {10..19}; 
do
if id user$i  
then
echo "user$i exists."
else
useradd user$i
echo "user$i added."
fi
done

14、在/tmp/創建10個空文件file10-file19;

for i in {10..19};
do
if [ -f file$i ];
then
echo "file$i existed!"
else
touch  /tmp/file$i
echo "file$i added."
fi
done

15、把file10的屬主和屬組改為user10,依次類推。

#!/bin/bash
for i in {10..19}do
chown user$i:user$i file$i
done

原創文章,作者:N21_郁藍,如若轉載,請注明出處:http://www.www58058.com/35818

(0)
N21_郁藍N21_郁藍
上一篇 2016-08-15 12:07
下一篇 2016-08-15 12:10

相關推薦

  • 從Linux小白到大?!c狼共舞的日子11

    馬哥教育網絡班21期+第10周課程練習 1、詳細描述一次加密通訊的過程,結合圖示最佳。 加密過程 1.使用單向加密算法,提取A的文件的特征碼。 2.使用A的私鑰對提取出來的特征碼進行加密,把加密后的特征碼附加在A的文件的后面。 3.使用對稱加密對剛剛的A的文件和加密后的特征碼進行加密,生成對稱加密密鑰 4.使用B的公鑰對第3步驟的對稱加密的密鑰進行加密,加密…

    Linux干貨 2016-12-05
  • 創建一個簡易的Linux

      目標:   為CentOS 6添加一塊新硬件,提供兩個主分區;    (1) 為硬盤新建兩個主分區;并為其安裝grub;    (2) 為硬盤的第一個主分區提供內核和ramdisk文件; 為第二個 分區提供rootfs;    (3) 為rootfs提供bash、ls、cat程序及所依賴的庫文件;    (4) 為grub提供配置文件;    …

    Linux干貨 2016-12-30
  • 課堂練習及課后作業(0805文本處理工具)

    課堂練習: 1、找出ifconfig命令結果中本機的所有IPv4地址 2、查出分區空間使用率的最大百分比值 3、查出用戶UID最大值的用戶名、UID及shell類型 4、查出/tmp的權限,以數字方式顯示 5、統計當前連接本機的每個遠程主機IP的連接數,并按從大到小排序 grep 1、顯示/proc/meminfo文件中以大小s開頭的行;(要求:使用兩種方式…

    Linux干貨 2016-08-07
  • 基于keepalived的VRRP協議實現DR模型下的高可用集群

    基于keepalived的VRRP協議實現DR模型下的高可用集群 環境及配置前提說明 4臺虛擬服務器都為centos6.8. 主機1,ip:192.168.25.140 做后端RS1,80端口向外部提供web服務 主機2,ip:192.168.25.141 做后端RS2,80端口向外部提供web服務 ip:192.168.25.142為lo:0接口的VIP地…

    Linux干貨 2016-11-07
  • PXE批量部署linux操作系統

       前言    在實際生產環境中,有時候我們會碰到為幾十上百甚至上千臺服務器安裝Linux操作系統的需求,如果我們還是常規的去使用移動介質逐臺安裝,顯然是一件低效又令人抓狂的事情,那要安裝到何年何月啊?這對于我們追求高逼格形象的技術人員來講當然是不可以接受的,為此,pxe模式批量部署系統應運而生。   &n…

    Linux干貨 2015-05-23
  • 馬哥教育網絡班20期+第四周課程練習

    1、復制/etc/skel目錄為/home/tuser1,要求/home/tuser1及其內部文件的屬組和其它用戶均沒有任何訪問權限。 cp -r /etc/skel/ /home/tuser1 chmod o-rwx /home/tuser1/.* 2、編輯/etc/group文件,添加組hadoop。 e…

    Linux干貨 2016-06-26

評論列表(2條)

  • 馬哥教育
    馬哥教育 2016-08-17 15:16

    寫的很好,排版也很棒,加油,crontab的都不對

    • N21_郁藍
      N21_郁藍 2016-08-18 05:09

      @馬哥教育6、每4小時執行一次對/etc目錄的備份,備份至/backup目錄中,保存的目錄名為形如etc-201504020202
      0 */4 * * * /bin/cp -a /etc /backup/etc-‘date \%Y\%m\%d\%h\%M’
      7、每周2,4,6備份/var/log/messages文件至/backup/messages_logs/目錄中,保存的文件名形如messages-20150402
      0 0 * * 2,4,6 /bin/cp -a /var/log/messages /backup/message_logs-‘date \%Y\%m\%d\%h\%M’
      8、每天每兩小時取當前系統/proc/meminfo文件中的所有以S開頭的信息至/stats/memory.txt文件中
      0 */2 * * * /bin/grep ‘^S’ /proc/meminfo >> /stats/memory.txt
      9、工作日的工作時間內,每兩小時執行一次echo “howdy”
      0 8-18/2 * * 1-5 /bin/echo “howdy”

      主要問題出在命令的路徑沒有加上,另外,改善了下匹配條件,非常感謝老師指正!

欧美性久久久久