您好,登錄后才能下訂單哦!
這篇文章將為大家詳細講解有關提高效率的Linux技巧有哪些,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。
如果要對一個已輸入的命令進行修改,可以使用 ^a
(ctrl + a
)或 ^e
(ctrl + e
)將光標快速移動到命令的開頭或命令的末尾。
還可以使用 ^
字符實現對上一個命令的文本替換并重新執行命令,例如 ^before^after^
相當于把上一個命令中的 before
替換為 after
然后重新執行一次。
$ eho hello world <== 錯誤的命令 Command 'eho' not found, did you mean: command 'echo' from deb coreutils command 'who' from deb coreutils Try: sudo apt install <deb name> $ ^e^ec^ <== 替換echo hello worldhello world
如果使用命令行登錄其它機器上,可以考慮添加別名。在別名中,可以填入需要登錄的用戶名(與本地系統上的用戶名可能相同,也可能不同)以及遠程機器的登錄信息。例如使用 server_name ='ssh -v -l username IP-address'
這樣的別名命令:
$ alias butterfly=”ssh -v -l jdoe 192.168.0.11”
也可以通過在 /etc/hosts
文件中添加記錄或者在 DNS 服務器中加入解析記錄來把 IP 地址替換成易記的機器名稱。
執行 alias
命令可以列出機器上已有的別名。
$ aliasalias butterfly='ssh -v -l jdoe 192.168.0.11'alias c='clear'alias egrep='egrep --color=auto'alias fgrep='fgrep --color=auto'alias grep='grep --color=auto'alias l='ls -CF'alias la='ls -A'alias list_repos='grep ^[^#] /etc/apt/sources.list /etc/apt/sources.list.d/*'alias ll='ls -alF'alias ls='ls --color=auto'alias show_dimensions='xdpyinfo | grep '\''dimensions:'\'''
只要將新的別名添加到 ~/.bashrc
或類似的文件中,就可以讓別名在每次登錄后都能立即生效。
^s
(ctrl + s
)將通過執行流量控制命令 XOFF 來停止終端輸出內容,這會對 PuTTY 會話和桌面終端窗口產生影響。如果誤輸入了這個命令,可以使用 ^q
(ctrl + q
)讓終端重新響應。所以只需要記住 ^q
這個組合鍵就可以了,畢竟這種情況并不多見。
Linux 提供了很多讓用戶復用命令的方法,其核心是通過歷史緩沖區收集執行過的命令。復用命令的最簡單方法是輸入 !
然后接最近使用過的命令的開頭字母;當然也可以按鍵盤上的向上箭頭,直到看到要復用的命令,然后按回車鍵。還可以先使用 history
顯示命令歷史,然后輸入 !
后面再接命令歷史記錄中需要復用的命令旁邊的數字。
!! <== 復用上一條命令!ec <== 復用上一條以 “ec” 開頭的命令!76 <== 復用命令歷史中的 76 號命令
使用形如 tail -f /var/log/syslog
的命令可以查看指定的日志文件,并動態顯示文件中增加的內容,需要監控向日志文件中追加內容的的事件時相當有用。這個命令會輸出文件內容的末尾部分,并逐漸顯示新增的內容。
$ tail -f /var/log/auth.logSep 17 09:41:01 fly CRON[8071]: pam_unix(cron:session): session closed for user smmspSep 17 09:45:01 fly CRON[8115]: pam_unix(cron:session): session opened for user rootSep 17 09:45:01 fly CRON[8115]: pam_unix(cron:session): session closed for user rootSep 17 09:47:00 fly sshd[8124]: Accepted password for shs from 192.168.0.22 port 47792Sep 17 09:47:00 fly sshd[8124]: pam_unix(sshd:session): session opened for user shs bySep 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 rootSep 17 09:55:01 fly CRON[8208]: pam_unix(cron:session): session closed for user root <== 等待顯示追加的內容
對于大多數 Linux 命令,都可以通過在輸入命令后加上選項 --help
來獲得這個命令的作用、用法以及它的一些相關信息。除了 man
命令之外, --help
選項可以讓你在不使用所有擴展選項的情況下獲取到所需要的內容。
$ mkdir --helpUsage: 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 '(coreutils) mkdir invocation'
如果要謹慎使用 rm
命令,可以為它設置一個別名,在刪除文件之前需要進行確認才能刪除。有些系統管理員會默認使用這個別名,對于這種情況,你可能需要看看下一個技巧。
$ rm -i <== 請求確認
你可以使用 unalias
命令以交互方式禁用別名。它不會更改別名的配置,而僅僅是暫時禁用,直到下次登錄或重新設置了這一個別名才會重新生效。
$ unalias rm
如果已經將 rm -i
默認設置為 rm
的別名,但你希望在刪除文件之前不必進行確認,則可以將 unalias
命令放在一個啟動文件(例如 ~/.bashrc
)中。
如果你經常在只有 root 用戶才能執行的命令前忘記使用 sudo
,這里有兩個方法可以解決。一是利用命令歷史記錄,可以使用 sudo !!
(使用 !!
來運行最近的命令,并在前面添加 sudo
)來重復執行,二是設置一些附加了所需 sudo
的命令別名。
$ alias update=’sudo apt update’
有時命令行技巧并不僅僅是一個別名。畢竟,別名能幫你做的只有替換命令以及增加一些命令參數,節省了輸入的時間。但如果需要比別名更復雜功能,可以通過編寫腳本、向 .bashrc
或其他啟動文件添加函數來實現。例如,下面這個函數會在創建一個目錄后進入到這個目錄下。在設置完畢后,執行 source .bashrc
,就可以使用 md temp
這樣的命令來創建目錄立即進入這個目錄下。
md () { mkdir -p "$@" && cd "$1"; }
關于“提高效率的Linux技巧有哪些”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,使各位可以學到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。