Linux中國

讓你提高效率的 Linux 技巧

巧妙的 Linux 命令行技巧能讓你節省時間、避免出錯,還能讓你記住和復用各種複雜的命令,專註在需要做的事情本身,而不是你要怎麼做。以下介紹一些好用的命令行技巧。

命令編輯

如果要對一個已輸入的命令進行修改,可以使用 ^actrl + a)或 ^ectrl + e)將游標快速移動到命令的開頭或命令的末尾。

還可以使用 ^ 字元實現對上一個命令的文本替換並重新執行命令,例如 ^before^after^ 相當於把上一個命令中的 before 替換為 after 然後重新執行一次。

$ eho hello world  <== 錯誤的命令

Command &apos;eho&apos; not found, did you mean:

 command &apos;echo&apos; from deb coreutils
 command &apos;who&apos; from deb coreutils

Try: sudo apt install <deb name>

$ ^e^ec^        <== 替換
echo hello world
hello world

使用遠程機器的名稱登錄到機器上

如果使用命令行登錄其它機器上,可以考慮添加別名。在別名中,可以填入需要登錄的用戶名(與本地系統上的用戶名可能相同,也可能不同)以及遠程機器的登錄信息。例如使用 server_name =&apos;ssh -v -l username IP-address&apos; 這樣的別名命令:

$ alias butterfly=」ssh -v -l jdoe 192.168.0.11」

也可以通過在 /etc/hosts 文件中添加記錄或者在 DNS 伺服器中加入解析記錄來把 IP 地址替換成易記的機器名稱。

執行 alias 命令可以列出機器上已有的別名。

$ alias
alias butterfly=&apos;ssh -v -l jdoe 192.168.0.11&apos;
alias c=&apos;clear&apos;
alias egrep=&apos;egrep --color=auto&apos;
alias fgrep=&apos;fgrep --color=auto&apos;
alias grep=&apos;grep --color=auto&apos;
alias l=&apos;ls -CF&apos;
alias la=&apos;ls -A&apos;
alias list_repos=&apos;grep ^[^#] /etc/apt/sources.list /etc/apt/sources.list.d/*&apos;
alias ll=&apos;ls -alF&apos;
alias ls=&apos;ls --color=auto&apos;
alias show_dimensions=&apos;xdpyinfo | grep &apos;&apos;&apos;dimensions:&apos;&apos;&apos;&apos;

只要將新的別名添加到 ~/.bashrc 或類似的文件中,就可以讓別名在每次登錄後都能立即生效。

凍結、解凍終端界面

^sctrl + s)將通過執行流量控制命令 XOFF 來停止終端輸出內容,這會對 PuTTY 會話和桌面終端窗口產生影響。如果誤輸入了這個命令,可以使用 ^qctrl + q)讓終端重新響應。所以只需要記住 ^q 這個組合鍵就可以了,畢竟這種情況並不多見。

復用命令

Linux 提供了很多讓用戶復用命令的方法,其核心是通過歷史緩衝區收集執行過的命令。復用命令的最簡單方法是輸入 ! 然後接最近使用過的命令的開頭字母;當然也可以按鍵盤上的向上箭頭,直到看到要復用的命令,然後按回車鍵。還可以先使用 history 顯示命令歷史,然後輸入 ! 後面再接命令歷史記錄中需要復用的命令旁邊的數字。

!! <== 復用上一條命令
!ec <== 復用上一條以 「ec」 開頭的命令
!76 <== 復用命令歷史中的 76 號命令

查看日誌文件並動態顯示更新內容

使用形如 tail -f /var/log/syslog 的命令可以查看指定的日誌文件,並動態顯示文件中增加的內容,需要監控向日誌文件中追加內容的的事件時相當有用。這個命令會輸出文件內容的末尾部分,並逐漸顯示新增的內容。

$ tail -f /var/log/auth.log
Sep 17 09:41:01 fly CRON[8071]: pam_unix(cron:session): session closed for user smmsp
Sep 17 09:45:01 fly CRON[8115]: pam_unix(cron:session): session opened for user root
Sep 17 09:45:01 fly CRON[8115]: pam_unix(cron:session): session closed for user root
Sep 17 09:47:00 fly sshd[8124]: Accepted password for shs from 192.168.0.22 port 47792
Sep 17 09:47:00 fly sshd[8124]: pam_unix(sshd:session): session opened for user shs by
Sep 17 09:47:00 fly systemd-logind[776]: New session 215 of user shs.
Sep 17 09:55:01 fly CRON[8208]: pam_unix(cron:session): session opened for user root
Sep 17 09:55:01 fly CRON[8208]: pam_unix(cron:session): session closed for user root
        <== 等待顯示追加的內容

尋求幫助

對於大多數 Linux 命令,都可以通過在輸入命令後加上選項 --help 來獲得這個命令的作用、用法以及它的一些相關信息。除了 man 命令之外, --help 選項可以讓你在不使用所有擴展選項的情況下獲取到所需要的內容。

$ mkdir --help
Usage: mkdir [OPTION]... DIRECTORY...
Create the DIRECTORY(ies), if they do not already exist.

Mandatory arguments to long options are mandatory for short options too.
 -m, --mode=MODE set file mode (as in chmod), not a=rwx - umask
 -p, --parents no error if existing, make parent directories as needed
 -v, --verbose print a message for each created directory
 -Z set SELinux security context of each created directory
 to the default type
 --context[=CTX] like -Z, or if CTX is specified then set the SELinux
 or SMACK security context to CTX
 --help display this help and exit
 --version output version information and exit

GNU coreutils online help: <http://www.gnu.org/software/coreutils/>
Full documentation at: <http://www.gnu.org/software/coreutils/mkdir>
or available locally via: info &apos;(coreutils) mkdir invocation&apos;

謹慎刪除文件

如果要謹慎使用 rm 命令,可以為它設置一個別名,在刪除文件之前需要進行確認才能刪除。有些系統管理員會默認使用這個別名,對於這種情況,你可能需要看看下一個技巧。

$ rm -i    <== 請求確認

關閉別名

你可以使用 unalias 命令以交互方式禁用別名。它不會更改別名的配置,而僅僅是暫時禁用,直到下次登錄或重新設置了這一個別名才會重新生效。

$ unalias rm

如果已經將 rm -i 默認設置為 rm 的別名,但你希望在刪除文件之前不必進行確認,則可以將 unalias 命令放在一個啟動文件(例如 ~/.bashrc)中。

使用 sudo

如果你經常在只有 root 用戶才能執行的命令前忘記使用 sudo,這裡有兩個方法可以解決。一是利用命令歷史記錄,可以使用 sudo !!(使用 !! 來運行最近的命令,並在前面添加 sudo)來重複執行,二是設置一些附加了所需 sudo 的命令別名。

$ alias update=』sudo apt update』

更複雜的技巧

有時命令行技巧並不僅僅是一個別名。畢竟,別名能幫你做的只有替換命令以及增加一些命令參數,節省了輸入的時間。但如果需要比別名更複雜功能,可以通過編寫腳本、向 .bashrc 或其他啟動文件添加函數來實現。例如,下面這個函數會在創建一個目錄後進入到這個目錄下。在設置完畢後,執行 source .bashrc,就可以使用 md temp 這樣的命令來創建目錄立即進入這個目錄下。

md () { mkdir -p "$@" && cd "$1"; }

總結

使用 Linux 命令行是在 Linux 系統上工作最有效也最有趣的方法,但配合命令行技巧和巧妙的別名可以讓你獲得更好的體驗。

via: https://www.networkworld.com/article/3305811/linux/linux-tricks-that-even-you-can-love.html

作者:Sandra Henry-Stocker 選題:lujun9972 譯者:HankChow 校對:wxy

本文由 LCTT 原創編譯,Linux中國 榮譽推出


本文轉載來自 Linux 中國: https://github.com/Linux-CN/archive

對這篇文章感覺如何?

太棒了
0
不錯
0
愛死了
0
不太好
0
感覺很糟
0
雨落清風。心向陽

    You may also like

    Leave a reply

    您的郵箱地址不會被公開。 必填項已用 * 標註

    這個站點使用 Akismet 來減少垃圾評論。了解你的評論數據如何被處理

    More in:Linux中國

    Linux中國

    捐贈 Let&apos;s Encrypt,共建安全的互聯網

    隨著 Mozilla、蘋果和谷歌對沃通和 StartCom 這兩家 CA 公司處罰落定,很多使用這兩家 CA 所簽發證書的網站紛紛尋求新的證書籤發商。有一個非盈利組織可以為大家提供了免費、可靠和安全的 SSL 證書服務,這就是 Let's Encrypt 項目。現在,它需要您的幫助
    Linux中國

    關於Linux防火牆iptables的面試問答

    Nishita Agarwal是Tecmint的用戶,她將分享關於她剛剛經歷的一家公司(印度的一家私人公司Pune)的面試經驗。在面試中她被問及許多不同的問題,但她是iptables方面的專家,因此她想分享這些關於iptables的問題和相應的答案給那些以後可能會進行相關面試的人。 所有的問題和相應的答案都基於Nishita Agarwal的記憶並經過了重寫。 嗨,朋友!我叫Nishita Agarwal。我已經取得了理學學士學位,我的專業集中在UNIX和它的變種(BSD,Linux)。它們一直深深的吸引著我。我在存儲方面有1年多的經驗。我正在尋求職業上的變化,並將供職於印度的P
    Linux中國

    Lets Encrypt 已被所有主流瀏覽器所信任

    旨在讓每個網站都能使用 HTTPS 加密的非贏利組織 Lets Encrypt 已經得了 IdenTrust的交叉簽名,這意味著其證書現在已經可以被所有主流的瀏覽器所信任。從這個裡程碑事件開始,訪問者訪問使用了Lets Encrypt 證書的網站不再需要特別配置就可以得到 HTTPS 安全保護了。 Lets Encrypt 的兩個中級證書 ...