一、linux目錄結構linux
Linux的應用領域shell
企業服務器:企業的後臺(好比說是qq,微信的後臺都是linux在跑)數據庫
桌面:我的電腦編程
嵌入式:手機,我的數字助理(PDA),消費性店子產品,以及航空航天等領域ubuntu
Linux的一個各類版本的分支圖vim
1、 Ubuntu簡介windows
Ubuntu(烏班圖)是一個基於Debian的以桌面應用爲主的Linux操做系統,聽說其名稱來自非洲南部祖魯語或科薩語的「ubuntu」一詞,意思是「人性」、「個人存在是由於你們的存在」,是非洲傳統的一種價值觀。緩存
Ubuntu的目標在於爲通常用戶提供一個最新同時又至關穩定,主要以自由軟件建構而成的操做系統。Ubuntu目前具備龐大的社區力量支持,用戶能夠方便地從社區得到幫助。安全
2、 安裝過程當中的知識點: bash
虛擬機的認識:
虛擬機(virtual machine)是指經過該軟件模擬的具備完整硬件系統功能的,運行在一個徹底隔離環境的完整計算機系統(不少的linux用戶都是運行在虛擬機上,比較熱門的虛擬機:vmwork station)
虛擬機的網絡類型的簡單理解:
虛擬機是在咱們的操做系統裏使用軟件模擬出來的,至關於虛擬機是寄宿在咱們的真實的物理機的操做系統裏的,虛擬機和物理機之間的關係是 寄宿與被寄宿的關係, 真實的物理機被稱爲宿主機。
1. bridged(橋接模式) : 咱們的電腦在上網的時候都須要有一個網絡地址(IP地址),經過這個地址能夠肯定咱們的電腦在網絡上的位置,橋接模式就是將咱們虛擬機中的網卡的網絡地址 放在咱們真實的物理機的網卡上。 這樣的話,咱們的虛擬機就好像跟咱們的宿主機所在的局域網中的一臺機器同樣。 橋接模式適合有路由器的狀況,和真實的物理環境同樣。(通俗: 至關於手機(虛擬機)和你的電腦同時鏈接同一臺路由器)
2. NAT(網絡地址轉換模式) : 在宿主機上製做一個虛擬網卡,經過這個網卡,給虛擬機分配IP。宿主機在這裏的角色至關於局域網中的路由器。NAT模式適合於沒有路由器的狀況,虛擬機經過宿主機去上網。(通俗:把你的電腦連上網了之後,虛擬機上的系統經過風向你的電腦的上的網絡,進行上網)
3.Host-Only(模式): 和NAT模式很像,惟一的區別是,沒有地址轉換服務,因此該模式下虛擬機只能訪問到主機。沒法訪問外網。
分區:
文件系統類型: 默認爲 ext4, 文件系統分不少種,ext二、ext三、ext四、fat、ntfs等等(windows : NTFS)
什麼是文件系統: 文件系統是操做系統用於明確磁盤或分區上的文件的方法和數據結構; 即在磁盤上組織文件的方法。
兩種文件系統的對比:
/ : 全部目錄都在
/boot : boot 配置文件、內核和其它啓動 時所需的文件
/etc : 存放系統配置有關的文件
/home : 存放普通用戶目錄
/mnt : 硬盤上手動 掛載的文件系統
/media : 自動掛載(加載)的硬盤分區以及相似CD、數碼相機等可移動介質。
/cdrom : 掛載光盤?
/opt : 存放一些可選程序,如某個程序測試版本,安裝到該目錄的程序的全部數據,庫文件都存在同個目錄下
/root : 系統管理員的目錄,對於系統來講,系統管理員比如上帝,他能夠對系統作任何操做,好比刪除你的文件,通常狀況下不要使用root用戶。
/bin : 存放經常使用的程序文件(命令文件)。
/sbin : 系統管理命令,這裏存放的是系統管理員使用的管理程序
/tmp : 臨時目錄,存放臨時文件,系統會按期清理該目錄下的文件。
/usr : 在這個目錄下,你能夠找到那些不適合放在/bin或/etc目錄下的額外的工具。好比遊戲、打印工具等。/usr目錄包含了許多子目錄: /usr/bin目錄用於存放程序;/usr/share用於存放一些共享的數據,好比音樂文件或者圖標等等;/usr/lib目錄用於存放那些不能直接 運行的,但倒是許多程序運行所必需的一些函數庫文件。/usr/local : 這個目錄通常是用來存放用戶自編譯安裝軟件的存放目錄;通常是經過源碼包安裝的軟件,若是沒有特別指定安裝目錄的話,通常是安裝在這個目錄中。
/usr/bin/ 非必要可執行文件 (在單用戶模式中不須要);面向全部用戶。
/usr/include/ 標準包含文件。
/usr/lib/ /usr/bin/和/usr/sbin/中二進制文件的庫。
/usr/sbin/ 非必要的系統二進制文件,例如:大量網絡服務的守護進程。
/usr/share/ 體系結構無關(共享)數據。
/usr/src/ 源代碼,例如:內核源代碼及其頭文件。
/usr/X11R6/ X Window系統 版本 11, Release 6.
/usr/local/ 本地數據的第三層次, 具體到本臺主機。一般而言有進一步的子目錄, 例如:bin/、lib/、share/.
/var : 該目錄存放那些常常被修改的文件,包括各類日誌、數據文件;
/var/cache/ 應用程序緩存數據。這些數據是在本地生成的一個耗時的I/O或計算結果。應用程序必須可以再生或恢復數據。緩存的文件能夠被刪除而不致使數據丟失。
/var/lib/ 狀態信息。 由程序在運行時維護的持久性數據。 例如:數據庫、包裝的系統元數據等。
/var/lock/ 鎖文件,一類跟蹤當前使用中資源的文件。
/var/log/ 日誌文件,包含大量日誌文件。
/var/mail/ 用戶的電子郵箱。
/var/run/ 自最後一次啓動以來運行中的系統的信息,例如:當前登陸的用戶和運行中的守護進程。現已經被/run代替[13]。
/var/spool/ 等待處理的任務的脫機文件,例如:打印隊列和未讀的郵件。
/var/spool/mail/ 用戶的郵箱(不鼓勵的存儲位置)
/var/tmp/ 在系統重啓過程當中能夠保留的臨時文件。
/lib : 目錄是根文件系統上的程序所需的共享庫,存放了根文件系統程序運行所需的共享文件。這些文件包含了可被許多程序共享的代碼,以免每一個程序都包含有相同的子程序的副本,故可使得可執行文件變得更小,節省空間。
/lib32 : 同上
/lib64 : 同上
/lost+found : 該目錄在大多數狀況下都是空的。但當忽然停電、或者非正常關機後,有些文件就臨時存放在;
/dev : 存放設備文件
/run : 代替/var/run目錄,
/proc : 虛擬文件系統,能夠在該目錄下獲取系統信息,這些信息是在內存中由系統本身產生的,該目錄的內容不在硬盤上而在內存裏;
/sys : 和proc同樣,虛擬文件系統,能夠在該目錄下獲取系統信息,這些信息是在內存中由系統本身產生的,該目錄的內容不在硬盤上而在內存裏;
swap分區(交換空間)
其實當你的內存足夠大的時候,能夠不用swap分區,其實swap分區就是至關於一個監空而且保護內存的機制,他會觀察着你的內存中的數據,存在swap中,保證系統的正常運行,是一個輔助內存,當你的內存在不夠用的時候,暫時會將硬盤中的一部分空間拿出來做爲內存,來暫時的使用
ubuntu 在不知道密碼的狀況下,修改密碼:
開機時長按shift鍵--------》 按‘e’進入相似於BIOS的界面--------》 找到開頭linux ,結尾有ro 的一行內容 ---------》 將ro及之後的內容改成rw init=/bin/bash/ ------》按F10(保存修改)---------》 而後輸入passwd + username ---------------》 輸入新密碼 ---------》出現提示 password update successfully 則爲修改密碼成功 ------------》 重啓新密碼生效 軟件管理
apt ( Advanced Packaging Tool ) , 他能夠自動下載、配置、安裝軟件包;簡化了Linux系統上的。Debian及衍生版中都包含了apt , RedHat系列的linux的則使用yum來進行管理,其中Fedora22中Centos7中開始使用dnf 來替代yum。
apt-cache search package 搜索包 apt-cache show package 獲取包的相關信息,如說明、大小、版本等 sudo apt-get install package 安裝包(這裏的安裝包不是。deb格式的) sudo apt-get install package –reinstall 從新安裝包 sudo apt-get -f install 強制安裝 sudo apt-get remove package 刪除包(只能用於對包的刪除,不能刪除文件) sudo apt-get remove package –purge 刪除包,包括刪除配置文件等 sudo apt-get autoremove 自動刪除不須要的包 sudo apt-get update 更新源(當你有時候apt-get install 安裝不成功的時候,可使用 updadte 來更新一下,再嘗試安裝) sudo apt-get upgrade 更新已安裝的包 sudo apt-get dist-upgrade 升級系統 sudo apt-get dselect-upgrade 使用 dselect 升級 apt-cache depends package 瞭解使用依賴 apt-cache rdepends package 瞭解某個具體的依賴 sudo apt-get build-dep package 安裝相關的編譯環境 apt-get source package 下載該包的源代碼 sudo apt-get clean && sudo apt-get autoclean 清理下載文件的存檔 sudo apt-get check 檢查是否有損壞的依賴
apt的安裝源文件放在 :/etc/apt/source.list 中,(能夠在軟件更新器中添加新的安裝源,格式:
deb http://security.ubuntu.com/ubuntu xenial-security main restricted # deb-src http://security.ubuntu.com/ubuntu xenial-security main restricted
)
安裝包的類型:deb 包 和 deb.src 包的區別
deb 包是你從網上手動的下載下來的一個安裝包,他是一個二進制的文件,能夠直接實現安裝
deb.src 包也是從網上下載下來的,不過他不是一個二進制的文件,他是一個軟件的源文件,因此必須經過進一步的編譯,纔可以進行安裝
dpkg
dpkg(缺點):若是安裝一個軟件有不少的依賴包,那麼你就須要手動的去安裝全部的依賴包,可是apt能夠在安裝源上所有都直接下載下來
是Debian軟件包管理器的基礎,被用於安裝、卸載和供給和.deb軟件包相關的信息。dpkg自己是一個底層的工具,自己並不能從遠程包倉庫下載包以及處理包的依賴的關係,須要將包從遠程下載後再安裝。DPKG經常使用命令:
當你有deb包的時候,能夠直接使用dpkg來安裝,dpkg不支持從安裝源在線安裝
dpkg -i package.deb 安裝包 dpkg -r package 刪除包 dpkg -P package 刪除包(包括配置文件) dpkg -L package 列出與該包關聯的文件 dpkg -l package 顯示該包的版本 dpkg –unpack package.deb 解開 deb 包的內容 dpkg -S keyword 搜索所屬的包內容 dpkg -l 列出當前已安裝的包 dpkg -c package.deb 列出 deb 包的內容 dpkg –configure package 配置包
Ubuntu 軟件倉庫被分爲四個部分:main(主要的), restricted(受限的), universe(普遍的) , multiverse(多元的),這主要根據咱們對軟件的支持能力,以及軟件的目的是否符合咱們的 自由軟件哲學。
先看了一下配置文件的一段內容:
第一個deb表示軟件包的格式,能夠是 deb 或 deb-src,前者表示所指向的存放 binary 格式(已編譯),後者爲 sources 格式(原代碼)。
第二個URI,即 Universal Resource Identifier,通用資源標識符,能夠是以:file(系統) 、 cdrom(光驅) 、 http 、 ftp、copy 、rsh 、ssh 等幾個參數開頭的軟件包所在位置。
第三個Distribution 指發行版本號,能夠是:stable,testing,unstable,sarge,etch,sid 等,具體可參考Debian文檔。
後面的幾個component表示具體的軟件包分類:
main:徹底遵循 Debian 自由軟件準則 即DFSG的軟件包;
contrib:軟件包均遵循DFSG自由使用原則,可是其使用了某些不符合DFSG的第三方庫;
non-free:不符合DFSG的軟件包。
刪除:
rm : 刪除命令
rm -f file1 # 強制刪除文件 rm -r a/b/file1 # 刪除指定目錄及其下的全部文件和目錄 rm -rf a/b/file1 # 強制刪除指定目錄及其下的全部文件和目錄 # rm 命令太危險,不建議使用
mv : 移動或重命令文件或目錄
mv SOURCE DEST # mv test.log test.txt # 文件更名 mv test1.txt dir1/ #移動文件 mv test1.txt test2.tx test3.tx dir1/ #移動多個文件
cp : 複製
cp SOURCE DEST # 複製文件 cp -i SOURCE DEST # 若是遇到須要覆蓋的狀況,則提示 cp -r dir1 dir2 # 若給出的源文件是一目錄文件,此時cp將遞歸複製該目錄下全部的子目錄和文件。此時目標文件必須爲一個目錄名 cp -p file1 file2 # 此時cp除複製源文件的內容外,還將把其修改時間和訪問權限也複製到新文件中。
cp -rp dir1 dir2
stat : 查看文件相信信息
stat filename # Access time(atime):是指取用文件的時間,所謂取用,常見的操做有:使用編輯器查看文件內容,使用cat命令顯示文件內容,使用cp命令把該文件(即來源文件)複製成其餘文件,或者在這個文件上運用grep sed more less tail head 等命令,凡是讀取而不修改文件的操做,均衡改變文件的Access time. # Modify time(mtime):是指修改文件內容的時間,只要文件內容有改動(如使用轉向輸出或轉向附加的方式)或存盤的操做,就會改變文件的Modify time,日常咱們使用ls –l查看文件時,顯示的時間就是Modify time # Change time(ctime):是指文件屬性或文件位置改動的時間,如使用chmod,chown,mv指令集使用ln作文件的硬是鏈接,就會改變文件的Change time.
cat : 連接文件後輸出文件內容到屏幕上,其實就是查看文件內容
tac : 反轉行的輸出
cat file1 #顯示 file1的文件內容 cat file1 file2 # 顯示file1和file2的文件內容 cat -n file1 # 由1開始對全部輸出的行數編號 cat -s file # 當遇到連續2行以上的空白行,只保留一行空白行
wc :統計指定文件中的字節數、字數、行數,並將統計結果顯示輸出
-c 統計字節數。 -l 統計行數。 -m 統計字符數。這個標誌不能與 -c 標誌一塊兒使用。 -w 統計字數。一個字被定義爲由空白、跳格或換行字符分隔的字符串
sort : 排序
sort [-fbMnrtuk] [file or stdin] 選項與參數: -f :忽略大小寫的差別,例如 A 與 a 視爲編碼相同; -b :忽略最前面的空格符部分; -n :使用『純數字』進行排序(默認是以文字型態來排序的); -r :反向排序; -u :就是 uniq ,相同的數據中,僅出現一行表明; -t :分隔符,默認是用 [tab] 鍵來分隔; -k :以那個區間 (field) 來進行排序的意思
uniq : 忽略或報告重複行
uniq [-icu] 選項與參數: -i :忽略大小寫字符的不一樣; -c :進行計數 -u :只顯示惟一的行
cut命令能夠從一個文本文件或者文本流中提取文本列。
選項與參數: -d :後面接分隔字符。與 -f 一塊兒使用; -f :依據 -d 的分隔字符將一段信息分割成爲數段,用 -f 取出第幾段的意思; -c :以字符 (characters) 的單位取出固定字符區間;
tee : 讀取標準輸入的數據,並將其內容輸出成文件。
cat sec.log | tee file1 # 讀取sec.log ,並生成file1文件 cat sec.log | tee - a file1 # 讀取sec.log ,並追加, cat sec.log |tee file1 file2
history : 查看執行過的命令。
history # 顯示最近1000條歷史命令 history 5 # 顯示最後5條命令 !number# number爲history以後命令前的序號:執行該條命令 !cat # 執行最後一條以cat開頭的命令
more : 查看文件內容
less : 查看文件內容
head : 輸出文件的開始的部分, 能夠指定行數 , 默認顯示10行
head -n 5 file
tail : 查看文件尾部的內容。默認顯示最後10行
tail file1 tail -n 5 file1 tail -f file1 # 動態監控文件 (與tailf 具備相同的做用)
which # 查找其餘命令的位置
which ls
ls : 列出目標目錄中全部的子目錄和文件
格式:ls [選項] [目錄名]
-a 用於顯示全部文件和子目錄(保羅點文件)。
-l 除了文件名以外,還將文件的權限、全部者、文件大小等信息詳細列出來。
-r 將目錄的內容清單以英文字母順序的逆序顯示。
-t 按文件修改時間進行排序,而不是按文件名進行排序。
-A 同-a,但不列出「.」(表示當前目錄)和「..」(表示當前目錄的父目錄)。
-F 在列出的文件名和目錄名後添加標誌。例如,在可執行文件後添加「*」,在目錄名後添加「/」以區分不一樣的類型。
-R 若是目標目錄及其子目錄中有文件,就列出全部的文件。
. 和..
. 表示當前目錄
.. 表示父目錄
ls # 列出當前目錄下的文件和目錄 ls . # 列出當前目錄下的文件和目錄 ls .. # 列出當前目錄的父目錄下的文件和目錄 ls /etc # 列出/etc目錄下的文件和目錄 ls -l # 以長格式顯示文件信息 總用量 76 -rwxrwxrwx 1 will will 78 5月 13 18:11 ss_start.sh
文件類型
- 普通文件
d 目錄文件
b 塊設備文件
c 字符設備文件
l 連接文件
p 管道文件
s socket文件
ls -l /dev # 能夠查看字符設備文件和塊設備文件 ls -l /run # 能夠找到socket文件 ls -l /run/systemd/inhibit/ # 能夠查看到管道文件
文件權限
rwxrwxr-- : 三組rwx 分別表示 全部者、全部組、其餘人 的權限。
r : 表示可讀, 能夠用數字 4 來表示
w : 標識可寫 ,能夠用數字 2 來表示
x : 表示可執行 , 能夠用數字 1 來表示
- :表示沒有相應權限 能夠用數字 0 來表示
修改權限的方法:
chmod o+w file1 chmod g-w file1 chmod go-w file1 chmod u=rwx file1 chmod 755 file1 # -rwxr-xr-x (755) 只有全部者纔有讀,寫,執行的權限,組羣和其餘人只有讀和執行的權限 chmod 644 # -rw-r--r-- (644) 只有全部者纔有讀和寫的權限,組羣和其餘人只有讀的權限 # 其中: # u 表明全部者(user) # g 表明全部者所在的組羣(group) # o 表明其餘人,但不是u和g (other) # a 表明所有的人,也就是包括u,g和o
目錄上的權限:
r : 表示是否能夠讀取目錄下的文件名
w : 表示是否能夠在目錄下建立修改文件
x : 表示目錄是否能夠被搜索
有x權限後,就可使用 ./a.py 的方式執行文件。
chown : 更改文件的全部者和全部組
chown root:root file chown root file chown :root file
特殊權限
SUID: 讓通常用戶在執行某些程序的時候,可以暫時具備該程序擁有者的權限,SUID對目錄是無效的
SGID : 文件:若是SGID設置在二進制文件上,則不論用戶是誰,在執行該程序的時候,它的有效用戶組(effective group)將會變成該程序的用戶組全部者(group id); 目錄:若是SGID是設置在某目錄上,則在該目錄內所創建的文件或目錄的用戶組,將會是該目錄的用戶組。 SGID多用在特定的多人團隊的項目開發上,在系統中用得較少
STICKY : 只針對目錄有效,在具備SBit的目錄下,用戶若在該目錄下具備w及x權限,則當用戶在該目錄下創建文件或目錄時,只有文件擁有者與root纔有權力刪除。
rwsrw-r-- 代表有suid標識,
用戶和用戶組
linux使用文件保存用戶信息 :
文件
# /etc/passwd 用戶帳戶信息。
# /etc/shadow 安全用戶帳戶信息。
# /etc/group 組帳戶信息。
# /etc/gshadow 安全組帳戶信息。
# /etc/default/useradd 帳戶建立的默認值。
# /etc/skel/ 包含默認文件的目錄。
# /etc/login.defs Shadow 密碼套件配置。
useradd: 添加用戶
# -c 備註 加上備註。並會將此備註文字加在/etc/passwd中的第5項字段中 # -d 用戶主文件夾。指定用戶登陸所進入的目錄,並賦予用戶對該目錄的的徹底控制權 # -e 有效期限。指定賬號的有效期限。格式爲YYYY-MM-DD,將存儲在/etc/shadow # -f 緩衝天數。限定密碼過時後多少天,將該用戶賬號停用 # -g 主要組。設置用戶所屬的主要組 www.cit.cn # -G 次要組。設置用戶所屬的次要組,可設置多組 # -M 強制不建立用戶主文件夾 # -m 強制創建用戶主文件夾,並將/etc/skel/當中的文件複製到用戶的根目錄下 # -p 密碼。輸入該賬號的密碼 # -s shell。用戶登陸所使用的shell # -u uid。指定賬號的標誌符user id,簡稱uid useradd user1 # 添加用戶 user1 useradd -d /home/userTT user2
userdel : 刪除用戶
userdel user1 # userdel -r user1 # -r, --remove 用戶主目錄中的文件將隨用戶主目錄和用戶郵箱一塊兒刪除。在其它文件系統中的文件必須手動搜索並刪除。 # -f, --force 此選項強制刪除用戶帳戶,甚至用戶仍然在登陸狀態。它也強制刪除用戶的主目錄和郵箱,即便其它用戶也使用同一個主目錄或郵箱不屬於指定的用戶
usermod : 修改用戶信息
# -c<備註> 修改用戶賬號的備註文字。 # -d登入目錄> 修改用戶登入時的目錄。 # -e<有效期限> 修改賬號的有效期限。 # -f<緩衝天數> 修改在密碼過時後多少天即關閉該賬號。 # -g<羣組> 修改用戶所屬的羣組。 # -G<羣組> 修改用戶所屬的附加羣組。 # -l<賬號名稱> 修改用戶賬號名稱。 # -L 鎖定用戶密碼,使密碼無效。 # -s<shell> 修改用戶登入後所使用的shell。 # -u<uid> 修改用戶ID。
# -U 解除密碼鎖定。 usermod -G staff user2 # 將 newuser2 添加到組 staff 中 usermod -l newuser1 newuser # 修改 newuser 的用戶名爲 newuser1 usermod -L newuser1 # 鎖定帳號 newuser1 usermod -U newuser1 # 解除對 newuser1 的鎖定
groupadd : 添加組
groupadd group1 groupadd -g 1000 group1 # 指定gid
groupdel : 刪除組
groupdel group1 # 刪除組
su與 sudo
su : 切換用戶,沒有參數時,默認切換爲root用戶;
su # 切換爲root ## 推薦 su - # 切換爲root 並加載user1的環境配置 su - user1 # 切換爲user1 並加載user1的環境配置
sudo : 讓當前用戶暫時以管理員的身份root來執行命令。
Ubuntu 默認沒有啓用root用戶, 普通用戶執行一些特殊的操做時,使用sudo就可讓普通用戶以root用戶的身份執行命令
sudo有一個配置文件: /etc/sudoers ; 經過修改配置文件可讓指定用戶使用sudo命令
alias : 給命令起別名(超級爽歪歪的一個命令,alias cd="rm -rf /")
alias ll='ls -alF' alias la='ls -A' alias l='ls -CF'
注意: 若是須要別名永久生效,須要保存到 .bashrc 文件
NB 的 vim
vim 是升級版的 vi (vim厲害到能夠不用廢棄鼠標)
vi/vim : 強大的編輯器
進入vi的命令
vi filename :打開或新建文件,並將光標置於第一行首
vi +n filename :打開文件,並將光標置於第n行首
vi + filename :打開文件,並將光標置於最後一行首
vi +/pattern filename:打開文件,並將光標置於第一個與pattern匹配的串處
vi -r filename :在上次正用vi編輯時發生系統崩潰,恢復filename
vi filename....filename :打開多個文件,依次進行編輯
移動光標類命令
h :光標左移一個字符
l :光標右移一個字符
space:光標右移一個字符
Backspace:光標左移一個字符
k或Ctrl+p:光標上移一行
j或Ctrl+n :光標下移一行
Enter :光標下移一行
w或W :光標右移一個字至字首
b或B :光標左移一個字至字首
e或E :光標右移一個字至字尾
) :光標移至句尾
( :光標移至句首
}:光標移至段落開頭
{:光標移至段落結尾
nG:光標移至第n行首
n+:光標下移n行
n-:光標上移n行
n:光標移至第n行尾H:光標移至屏幕頂行M:光標移至屏幕中間行L:光標移至屏幕最後行0:(注意是數字零)光標移至當前行首:光標移至第n行尾H:光標移至屏幕頂行M:光標移至屏幕中間行L:光標移至屏幕最後行0:(注意是數字零)光標移至當前行首:光標移至當前行尾
屏幕翻滾類命令
Ctrl+u:向文件首翻半屏
Ctrl+d:向文件尾翻半屏
Ctrl+f:向文件尾翻一屏
Ctrl+b;向文件首翻一屏
nz:將第n行滾至屏幕頂部,不指定n時將當前行滾至屏幕頂部。
插入文本類命令
i :在光標前
I :在當前行首
a:光標後
A:在當前行尾
o:在當前行之下新開一行
O:在當前行之上新開一行
r:替換當前字符
R:替換當前字符及其後的字符,直至按ESC鍵
s:從當前光標位置處開始,以輸入的文本替代指定數目的字符
S:刪除指定數目的行,並以所輸入文本代替之
ncw或nCW:修改指定數目的字
nCC:修改指定數目的行
刪除命令
ndw或ndW:刪除光標處開始及其後的n-1個字
do:刪至行首
d:刪至行尾ndd:刪除當前行及其後n−1行x或X:刪除一個字符,x刪除光標後的,而X刪除光標前的Ctrl+u:刪除輸入方式下所輸入的文本搜索及替換命令/pattern:從光標開始處向文件尾搜索pa