Linux面試題(2020最新版)

ThinkWon發表於2020-03-01

文章目錄

Java面試總結匯總,整理了包括Java基礎知識,集合容器,併發程式設計,JVM,常用開源框架Spring,MyBatis,資料庫,中介軟體等,包含了作為一個Java工程師在面試中需要用到或者可能用到的絕大部分知識。歡迎大家閱讀,本人見識有限,寫的部落格難免有錯誤或者疏忽的地方,還望各位大佬指點,在此表示感激不盡。文章持續更新中…

序號 內容 連結地址
1 Java基礎知識面試題(2020最新版) https://thinkwon.blog.csdn.net/article/details/104390612
2 Java集合容器面試題(2020最新版) https://thinkwon.blog.csdn.net/article/details/104588551
3 Java異常面試題(2020最新版) https://thinkwon.blog.csdn.net/article/details/104390689
4 併發程式設計面試題(2020最新版) https://thinkwon.blog.csdn.net/article/details/104863992
5 JVM面試題(2020最新版) https://thinkwon.blog.csdn.net/article/details/104390752
6 Spring面試題(2020最新版) https://thinkwon.blog.csdn.net/article/details/104397516
7 Spring MVC面試題(2020最新版) https://thinkwon.blog.csdn.net/article/details/104397427
8 Spring Boot面試題(2020最新版) https://thinkwon.blog.csdn.net/article/details/104397299
9 Spring Cloud面試題(2020最新版) https://thinkwon.blog.csdn.net/article/details/104397367
10 MyBatis面試題(2020最新版) https://thinkwon.blog.csdn.net/article/details/101292950
11 Redis面試題(2020最新版) https://thinkwon.blog.csdn.net/article/details/103522351
12 MySQL資料庫面試題(2020最新版) https://thinkwon.blog.csdn.net/article/details/104778621
13 訊息中介軟體MQ與RabbitMQ面試題(2020最新版) https://thinkwon.blog.csdn.net/article/details/104588612
14 Dubbo面試題(2020最新版) https://thinkwon.blog.csdn.net/article/details/104390006
15 Linux面試題(2020最新版) https://thinkwon.blog.csdn.net/article/details/104588679
16 Tomcat面試題(2020最新版) https://thinkwon.blog.csdn.net/article/details/104397665
17 ZooKeeper面試題(2020最新版) https://thinkwon.blog.csdn.net/article/details/104397719
18 Netty面試題(2020最新版) https://thinkwon.blog.csdn.net/article/details/104391081

Linux 概述

什麼是Linux

Linux是一套免費使用和自由傳播的類Unix作業系統,是一個基於POSIX和Unix的多使用者、多工、支援多執行緒和多CPU的作業系統。它能執行主要的Unix工具軟體、應用程式和網路協議。它支援32位和64位硬體。Linux繼承了Unix以網路為核心的設計思想,是一個效能穩定的多使用者網路作業系統。

Unix和Linux有什麼區別?

Linux和Unix都是功能強大的作業系統,都是應用廣泛的伺服器作業系統,有很多相似之處,甚至有一部分人錯誤地認為Unix和Linux作業系統是一樣的,然而,事實並非如此,以下是兩者的區別。

  1. 開源性
    Linux是一款開源作業系統,不需要付費,即可使用;Unix是一款對原始碼實行智慧財產權保護的傳統商業軟體,使用需要付費授權使用。

  2. 跨平臺性
    Linux作業系統具有良好的跨平臺效能,可執行在多種硬體平臺上;Unix作業系統跨平臺效能較弱,大多需與硬體配套使用。

  3. 視覺化介面
    Linux除了進行命令列操作,還有窗體管理系統;Unix只是命令列下的系統。

  4. 硬體環境
    Linux作業系統對硬體的要求較低,安裝方法更易掌握;Unix對硬體要求比較苛刻,按照難度較大。

  5. 使用者群體
    Linux的使用者群體很廣泛,個人和企業均可使用;Unix的使用者群體比較窄,多是安全性要求高的大型企業使用,如銀行、電信部門等,或者Unix硬體廠商使用,如Sun等。
    相比於Unix作業系統,Linux作業系統更受廣大計算機愛好者的喜愛,主要原因是Linux作業系統具有Unix作業系統的全部功能,並且能夠在普通PC計算機上實現全部的Unix特性,開源免費的特性,更容易普及使用!

什麼是 Linux 核心?

Linux 系統的核心是核心。核心控制著計算機系統上的所有硬體和軟體,在必要時分配硬體,並根據需要執行軟體。

  1. 系統記憶體管理
  2. 應用程式管理
  3. 硬體裝置管理
  4. 檔案系統管理

Linux的基本元件是什麼?

就像任何其他典型的作業系統一樣,Linux擁有所有這些元件:核心,shell和GUI,系統實用程式和應用程式。Linux比其他作業系統更具優勢的是每個方面都附帶其他功能,所有程式碼都可以免費下載。

Linux 的體系結構

從大的方面講,Linux 體系結構可以分為兩塊:

在這裡插入圖片描述

  • 使用者空間(User Space) :使用者空間又包括使用者的應用程式(User Applications)、C 庫(C Library) 。
  • 核心空間(Kernel Space) :核心空間又包括系統呼叫介面(System Call Interface)、核心(Kernel)、平臺架構相關的程式碼(Architecture-Dependent Kernel Code) 。

為什麼 Linux 體系結構要分為使用者空間和核心空間的原因?

  • 1、現代 CPU 實現了不同的工作模式,不同模式下 CPU 可以執行的指令和訪問的暫存器不同。
  • 2、Linux 從 CPU 的角度出發,為了保護核心的安全,把系統分成了兩部分。

使用者空間和核心空間是程式執行的兩種不同的狀態,我們可以通過兩種方式完成使用者空間到核心空間的轉移:1)系統呼叫;2)硬體中斷。

BASH和DOS之間的基本區別是什麼?

BASH和DOS控制檯之間的主要區別在於3個方面:

  • BASH命令區分大小寫,而DOS命令則不區分;
  • 在BASH下,/ character是目錄分隔符,\作為轉義字元。在DOS下,/用作命令引數分隔符,\是目錄分隔符
  • DOS遵循命名檔案中的約定,即8個字元的檔名後跟一個點,副檔名為3個字元。BASH沒有遵循這樣的慣例。

Linux 開機啟動過程?

瞭解即可。

  • 1、主機加電自檢,載入 BIOS 硬體資訊。

  • 2、讀取 MBR 的引導檔案(GRUB、LILO)。

  • 3、引導 Linux 核心。

  • 4、執行第一個程式 init (程式號永遠為 1 )。

  • 5、進入相應的執行級別。

  • 6、執行終端,輸入使用者名稱和密碼。

Linux系統預設的執行級別?

  • 關機。
  • 單機使用者模式。
  • 字元介面的多使用者模式(不支援網路)。
  • 字元介面的多使用者模式。
  • 未分配使用。
  • 圖形介面的多使用者模式。
  • 重啟。

Linux 使用的程式間通訊方式?

瞭解即可,不需要太深入。

  • 1、管道(pipe)、流管道(s_pipe)、有名管道(FIFO)。
  • 2、訊號(signal) 。
  • 3、訊息佇列。
  • 4、共享記憶體。
  • 5、訊號量。
  • 6、套接字(socket) 。

Linux 有哪些系統日誌檔案?

比較重要的是 /var/log/messages 日誌檔案。

該日誌檔案是許多程式日誌檔案的彙總,從該檔案可以看出任何入侵企圖或成功的入侵。

另外,如果胖友的系統裡有 ELK 日誌集中收集,它也會被收集進去。

Linux系統安裝多個桌面環境有幫助嗎?

通常,一個桌面環境,如KDE或Gnome,足以在沒有問題的情況下執行。儘管系統允許從一個環境切換到另一個環境,但這對使用者來說都是優先考慮的問題。有些程式在一個環境中工作而在另一個環境中無法工作,因此它也可以被視為選擇使用哪個環境的一個因素。

什麼是交換空間?

交換空間是Linux使用的一定空間,用於臨時儲存一些併發執行的程式。當RAM沒有足夠的記憶體來容納正在執行的所有程式時,就會發生這種情況。

什麼是root帳戶

root帳戶就像一個系統管理員帳戶,允許你完全控制系統。你可以在此處建立和維護使用者帳戶,為每個帳戶分配不同的許可權。每次安裝Linux時都是預設帳戶。

什麼是LILO?

LILO是Linux的引導載入程式。它主要用於將Linux作業系統載入到主記憶體中,以便它可以開始執行。

什麼是BASH?

BASH是Bourne Again SHell的縮寫。它由Steve Bourne編寫,作為原始Bourne Shell(由/ bin / sh表示)的替代品。它結合了原始版本的Bourne Shell的所有功能,以及其他功能,使其更容易使用。從那以後,它已被改編為執行Linux的大多數系統的預設shell。

什麼是CLI?

命令列介面(英語**:command-line interface**,縮寫]:CLI)是在圖形使用者介面得到普及之前使用最為廣泛的使用者介面,它通常不支援滑鼠,使用者通過鍵盤輸入指令,計算機接收到指令後,予以執行。也有人稱之為字元使用者介面(CUI)。

通常認為,命令列介面(CLI)沒有圖形使用者介面(GUI)那麼方便使用者操作。因為,命令列介面的軟體通常需要使用者記憶操作的命令,但是,由於其本身的特點,命令列介面要較圖形使用者介面節約計算機系統的資源。在熟記命令的前提下,使用命令列介面往往要較使用圖形使用者介面的操作速度要快。所以,圖形使用者介面的作業系統中,都保留著可選的命令列介面。

什麼是GUI?

圖形使用者介面(Graphical User Interface,簡稱 GUI,又稱圖形使用者介面)是指採用圖形方式顯示的計算機操作使用者介面。

圖形使用者介面是一種人與計算機通訊的介面顯示格式,允許使用者使用滑鼠等輸入裝置操縱螢幕上的圖示或選單選項,以選擇命令、呼叫檔案、啟動程式或執行其它一些日常任務。與通過鍵盤輸入文字或字元命令來完成例行任務的字元介面相比,圖形使用者介面有許多優點。

開源的優勢是什麼?

開源允許你將軟體(包括原始碼)免費分發給任何感興趣的人。然後,人們可以新增功能,甚至可以除錯和更正原始碼中的錯誤。它們甚至可以讓它執行得更好,然後再次自由地重新分配這些增強的原始碼。這最終使社群中的每個人受益。

GNU專案的重要性是什麼?

這種所謂的自由軟體運動具有多種優勢,例如可以自由地執行程式以及根據你的需要自由學習和修改程式。它還允許你將軟體副本重新分發給其他人,以及自由改進軟體並將其釋出給公眾。

磁碟、目錄、檔案

簡單 Linux 檔案系統?

在 Linux 作業系統中,所有被作業系統管理的資源,例如網路介面卡、磁碟驅動器、印表機、輸入輸出裝置、普通檔案或是目錄都被看作是一個檔案。

也就是說在 Linux 系統中有一個重要的概念**:一切都是檔案**。其實這是 Unix 哲學的一個體現,而 Linux 是重寫 Unix 而來,所以這個概念也就傳承了下來。在 Unix 系統中,把一切資源都看作是檔案,包括硬體裝置。UNIX系統把每個硬體都看成是一個檔案,通常稱為裝置檔案,這樣使用者就可以用讀寫檔案的方式實現對硬體的訪問。

Linux 支援 5 種檔案型別,如下圖所示:檔案型別

Linux 的目錄結構是怎樣的?

這個問題,一般不會問。更多是實際使用時,需要知道。

Linux 檔案系統的結構層次鮮明,就像一棵倒立的樹,最頂層是其根目錄:
Linux的目錄結構

常見目錄說明

  • /bin: 存放二進位制可執行檔案(ls,cat,mkdir等),常用命令一般都在這裡;
  • /etc: 存放系統管理和配置檔案;
  • /home: 存放所有使用者檔案的根目錄,是使用者主目錄的基點,比如使用者user的主目錄就是/home/user,可以用~user表示;
  • **/usr **: 用於存放系統應用程式;
  • /opt: 額外安裝的可選應用程式包所放置的位置。一般情況下,我們可以把tomcat等都安裝到這裡;
  • /proc: 虛擬檔案系統目錄,是系統記憶體的對映。可直接訪問這個目錄來獲取系統資訊;
  • /root: 超級使用者(系統管理員)的主目錄(特權階級o);
  • /sbin: 存放二進位制可執行檔案,只有root才能訪問。這裡存放的是系統管理員使用的系統級別的管理命令和程式。如ifconfig等;
  • /dev: 用於存放裝置檔案;
  • /mnt: 系統管理員安裝臨時檔案系統的安裝點,系統提供這個目錄是讓使用者臨時掛載其他的檔案系統;
  • /boot: 存放用於系統引導時使用的各種檔案;
  • **/lib **: 存放著和系統執行相關的庫檔案 ;
  • /tmp: 用於存放各種臨時檔案,是公用的臨時檔案儲存點;
  • /var: 用於存放執行時需要改變資料的檔案,也是某些大檔案的溢位區,比方說各種服務的日誌檔案(系統啟動日誌等。)等;
  • /lost+found: 這個目錄平時是空的,系統非正常關機而留下“無家可歸”的檔案(windows下叫什麼.chk)就在這裡。

什麼是 inode ?

一般來說,面試不會問 inode 。但是 inode 是一個重要概念,是理解 Unix/Linux 檔案系統和硬碟儲存的基礎。

理解inode,要從檔案儲存說起。

檔案儲存在硬碟上,硬碟的最小儲存單位叫做"扇區"(Sector)。每個扇區儲存512位元組(相當於0.5KB)。

作業系統讀取硬碟的時候,不會一個個扇區地讀取,這樣效率太低,而是一次性連續讀取多個扇區,即一次性讀取一個"塊"(block)。這種由多個扇區組成的"塊",是檔案存取的最小單位。"塊"的大小,最常見的是4KB,即連續八個 sector組成一個 block。

檔案資料都儲存在"塊"中,那麼很顯然,我們還必須找到一個地方儲存檔案的元資訊,比如檔案的建立者、檔案的建立日期、檔案的大小等等。這種儲存檔案元資訊的區域就叫做inode,中文譯名為"索引節點"。

每一個檔案都有對應的inode,裡面包含了與該檔案有關的一些資訊。

簡述 Linux 檔案系統通過 i 節點把檔案的邏輯結構和物理結構轉換的工作過程?

如果看的一臉懵逼,也沒關係。一般來說,面試官不太會問這個題目。

Linux 通過 inode 節點表將檔案的邏輯結構和物理結構進行轉換。

  • inode 節點是一個 64 位元組長的表,表中包含了檔案的相關資訊,其中有檔案的大小、檔案所有者、檔案的存取許可方式以及檔案的型別等重要資訊。在 inode 節點表中最重要的內容是磁碟地址表。在磁碟地址表中有 13 個塊號,檔案將以塊號在磁碟地址表中出現的順序依次讀取相應的塊。
  • Linux 檔案系統通過把 inode 節點和檔名進行連線,當需要讀取該檔案時,檔案系統在當前目錄表中查詢該檔名對應的項,由此得到該檔案相對應的 inode 節點號,通過該 inode 節點的磁碟地址表把分散存放的檔案物理塊連線成檔案的邏輯結構。

什麼是硬連結和軟連結?

1)硬連結

由於 Linux 下的檔案是通過索引節點(inode)來識別檔案,硬連結可以認為是一個指標,指向檔案索引節點的指標,系統並不為它重新分配 inode 。每新增一個一個硬連結,檔案的連結數就加 1 。

  • 不足:1)不可以在不同檔案系統的檔案間建立連結;2)只有超級使用者才可以為目錄建立硬連結。

2)軟連結

軟連結克服了硬連結的不足,沒有任何檔案系統的限制,任何使用者可以建立指向目錄的符號連結。因而現在更為廣泛使用,它具有更大的靈活性,甚至可以跨越不同機器、不同網路對檔案進行連結。

  • 不足:因為連結檔案包含有原檔案的路徑資訊,所以當原檔案從一個目錄下移到其他目錄中,再訪問連結檔案,系統就找不到了,而硬連結就沒有這個缺陷,你想怎麼移就怎麼移;還有它要系統分配額外的空間用於建立新的索引節點和儲存原檔案的路徑。

實際場景下,基本是使用軟連結。總結區別如下:

  • 硬連結不可以跨分割槽,軟體鏈可以跨分割槽。
  • 硬連結指向一個 inode 節點,而軟連結則是建立一個新的 inode 節點。
  • 刪除硬連結檔案,不會刪除原檔案,刪除軟連結檔案,會把原檔案刪除。

RAID 是什麼?

RAID 全稱為獨立磁碟冗餘陣列(Redundant Array of Independent Disks),基本思想就是把多個相對便宜的硬碟組合起來,成為一個硬碟陣列組,使效能達到甚至超過一個價格昂貴、 容量巨大的硬碟。RAID 通常被用在伺服器電腦上,使用完全相同的硬碟組成一個邏輯扇區,因此作業系統只會把它當做一個硬碟。

RAID 分為不同的等級,各個不同的等級均在資料可靠性及讀寫效能上做了不同的權衡。在實際應用中,可以依據自己的實際需求選擇不同的 RAID 方案。

當然,因為很多公司都使用雲服務,大家很難接觸到 RAID 這個概念,更多的可能是普通雲盤、SSD 雲盤醬紫的概念。

安全

一臺 Linux 系統初始化環境後需要做一些什麼安全工作?

  • 1、新增普通使用者登陸,禁止 root 使用者登陸,更改 SSH 埠號。

    修改 SSH 埠不一定絕對哈。當然,如果要暴露在外網,建議改下。l

  • 2、伺服器使用金鑰登陸,禁止密碼登陸。

  • 3、開啟防火牆,關閉 SElinux ,根據業務需求設定相應的防火牆規則。

  • 4、裝 fail2ban 這種防止 SSH 暴力破擊的軟體。

  • 5、設定只允許公司辦公網出口 IP 能登陸伺服器(看公司實際需要)

    也可以安裝 VPN 等軟體,只允許連線 VPN 到伺服器上。

  • 6、修改歷史命令記錄的條數為 10 條。

  • 7、只允許有需要的伺服器可以訪問外網,其它全部禁止。

  • 8、做好軟體層面的防護。

    • 8.1 設定 nginx_waf 模組防止 SQL 注入。
    • 8.2 把 Web 服務使用 www 使用者啟動,更改網站目錄的所有者和所屬組為 www 。

什麼叫 CC 攻擊?什麼叫 DDOS 攻擊?

  • CC 攻擊,主要是用來攻擊頁面的,模擬多個使用者不停的對你的頁面進行訪問,從而使你的系統資源消耗殆盡。

  • DDOS 攻擊,中文名叫分散式拒絕服務攻擊,指藉助伺服器技術將多個計算機聯合起來作為攻擊平臺,來對一個或多個目標發動 DDOS 攻擊。

    攻擊,即是通過大量合法的請求佔用大量網路資源,以達到癱瘓網路的目的。

怎麼預防 CC 攻擊和 DDOS 攻擊?

防 CC、DDOS 攻擊,這些只能是用硬體防火牆做流量清洗,將攻擊流量引入黑洞。

流量清洗這一塊,主要是買 ISP 服務商的防攻擊的服務就可以,機房一般有空餘流量,我們一般是買服務,畢竟攻擊不會是持續長時間。

什麼是網站資料庫注入?

  • 由於程式設計師的水平及經驗參差不齊,大部分程式設計師在編寫程式碼的時候,沒有對使用者輸入資料的合法性進行判斷。
  • 應用程式存在安全隱患。使用者可以提交一段資料庫查詢程式碼,根據程式返回的結果,獲得某些他想得知的資料,這就是所謂的 SQL 注入。
  • SQL隱碼攻擊,是從正常的 WWW 埠訪問,而且表面看起來跟一般的 Web 頁面訪問沒什麼區別,如果管理員沒檢視日誌的習慣,可能被入侵很長時間都不會發覺。

如何過濾與預防?

資料庫網頁端注入這種,可以考慮使用 nginx_waf 做過濾與預防。

Shell

本小節為選讀。我也不太會寫 Shell 指令碼,都是寫的時候,在網路上拼拼湊湊。。。

Shell 指令碼是什麼?

一個 Shell 指令碼是一個文字檔案,包含一個或多個命令。作為系統管理員,我們經常需要使用多個命令來完成一項任務,我們可以新增這些所有命令在一個文字檔案(Shell 指令碼)來完成這些日常工作任務。

什麼是預設登入 Shell ?

在 Linux 作業系統,"/bin/bash" 是預設登入 Shell,是在建立使用者時分配的。

使用 chsh 命令可以改變預設的 Shell 。示例如下所示:

## chsh <使用者名稱> -s <新shell>
## chsh ThinkWon -s /bin/sh

在 Shell 指令碼中,如何寫入註釋?

註釋可以用來描述一個指令碼可以做什麼和它是如何工作的。每一行註釋以 # 開頭。例子如下:

#!/bin/bash
## This is a command
echo “I am logged in as $USER

語法級

可以在 Shell 指令碼中使用哪些型別的變數?

在 Shell 指令碼,我們可以使用兩種型別的變數:

  • 系統定義變數

    系統變數是由系統系統自己建立的。這些變數通常由大寫字母組成,可以通過 set 命令檢視。

  • 使用者定義變數

    使用者變數由系統使用者來生成和定義,變數的值可以通過命令 "echo $<變數名>" 檢視。

Shell指令碼中 $? 標記的用途是什麼?

在寫一個 Shell 指令碼時,如果你想要檢查前一命令是否執行成功,在 if 條件中使用 $? 可以來檢查前一命令的結束狀態。

  • 如果結束狀態是 0 ,說明前一個命令執行成功。例如:

    root@localhost:~## ls /usr/bin/shar
    /usr/bin/shar
    root@localhost:~## echo $?
    0
    
  • 如果結束狀態不是0,說明命令執行失敗。例如:

    root@localhost:~## ls /usr/bin/share
    ls: cannot access /usr/bin/share: No such file or directory
    root@localhost:~## echo $?
    2
    

Bourne Shell(bash) 中有哪些特殊的變數?

下面的表列出了 Bourne Shell 為命令列設定的特殊變數。

內建變數    解釋
$0    命令列中的指令碼名字
$1    第一個命令列引數
$2    第二個命令列引數
…..    …….
$9    第九個命令列引數
$##    命令列引數的數量
$*    所有命令列引數,以空格隔開

如何取消變數或取消變數賦值?

unset 命令用於取消變數或取消變數賦值。語法如下所示:

## unset <變數名>

Shell 指令碼中 if 語法如何巢狀?

if [ 條件 ]
then
命令1
命令2
…..
else
if [ 條件 ]
then
命令1
命令2
….
else
命令1
命令2
…..
fi
fi

在 Shell 指令碼中如何比較兩個數字?

if-then 中使用測試命令( -gt 等)來比較兩個數字。例如:

#!/bin/bash
x=10
y=20
if [ $x -gt $y ]
then
echo “x is greater than y”
else
echo “y is greater than x”
fi

Shell 指令碼中 case 語句的語法?

基礎語法如下:

case 變數 in
值1)
命令1
命令2
…..
最後命令
!!
值2)
命令1
命令2
……
最後命令
;;
esac

Shell 指令碼中 for 迴圈語法?

基礎語法如下:

for 變數 in 迴圈列表
do
命令1
命令2
….
最後命令
done

Shell 指令碼中 while 迴圈語法?

如同 for 迴圈,while 迴圈只要條件成立就重複它的命令塊。
不同於 for迴圈,while 迴圈會不斷迭代,直到它的條件不為真。

基礎語法:

while [ 條件 ]
do
命令…
done

do-while 語句的基本格式?

do-while 語句類似於 while 語句,但檢查條件語句之前先執行命令(LCTT 譯註:意即至少執行一次。)。下面是用 do-while 語句的語法:

do
{
命令
} while (條件)

Shell 指令碼中 break 命令的作用?

break 命令一個簡單的用途是退出執行中的迴圈。我們可以在 whileuntil 迴圈中使用 break 命令跳出迴圈。

Shell 指令碼中 continue 命令的作用?

continue 命令不同於 break 命令,它只跳出當前迴圈的迭代,而不是整個迴圈。continue 命令很多時候是很有用的,例如錯誤發生,但我們依然希望繼續執行大迴圈的時候。

如何使指令碼可執行?

使用 chmod 命令來使指令碼可執行。例子如下:chmod a+x myscript.sh

#!/bin/bash 的作用?

#!/bin/bash 是 Shell 指令碼的第一行,稱為釋伴(shebang)行。

  • 這裡 # 符號叫做 hash ,而 ! 叫做 bang。
  • 它的意思是命令通過 /bin/bash 來執行。

如何除錯 Shell指令碼?

  • 使用 -x' 數(sh -x myscript.sh)可以除錯 Shell指令碼。
  • 另一個種方法是使用 -nv 引數(sh -nv myscript.sh)。

如何將標準輸出和錯誤輸出同時重定向到同一位置?

  • 方法一:2>&1 (如## ls /usr/share/doc > out.txt 2>&1 )
  • 方法二:&> (如## ls /usr/share/doc &> out.txt )

在 Shell 指令碼中,如何測試檔案?

test 命令可以用來測試檔案。基礎用法如下表格:

Test         用法
-d 檔名    如果檔案存在並且是目錄,返回true
-e 檔名    如果檔案存在,返回true
-f 檔名    如果檔案存在並且是普通檔案,返回true
-r 檔名    如果檔案存在並可讀,返回true
-s 檔名    如果檔案存在並且不為空,返回true
-w 檔名    如果檔案存在並可寫,返回true
-x 檔名    如果檔案存在並可執行,返回true

在 Shell 指令碼如何定義函式呢?

函式是擁有名字的程式碼塊。當我們定義程式碼塊,我們就可以在我們的指令碼呼叫函式名字,該塊就會被執行。示例如下所示:

$ diskusage () { df -h ; }
譯註:下面是我給的shell函式語法,原文沒有
[ function ] 函式名 [()]
{
命令;
[return int;]
}

如何讓 Shell 就指令碼得到來自終端的輸入?

read 命令可以讀取來自終端(使用鍵盤)的資料。read 命令得到使用者的輸入並置於你給出的變數中。例子如下:

## vi /tmp/test.sh
#!/bin/bash
echo ‘Please enter your name’
read name
echo “My Name is $name## ./test.sh
Please enter your name
ThinkWon
My Name is ThinkWon

如何執行算術運算?

有兩種方法來執行算術運算:

  • 1、使用 expr 命令:## expr 5 + 2
  • 2、用一個美元符號和方括號($[ 表示式 ]):test=$[16 + 4] ; test=$[16 + 4]

程式設計題

判斷一檔案是不是字元裝置檔案,如果是將其拷貝到 /dev 目錄下?

#!/bin/bash
read -p "Input file name: " FILENAME
if [ -c "$FILENAME" ];then
  cp $FILENAME /dev
fi

新增一個新組為 class1 ,然後新增屬於這個組的 30 個使用者,使用者名稱的形式為 stdxx ,其中 xx 從 01 到 30 ?

#!/bin/bash
groupadd class1
for((i=1;i<31;i++))
do
        if [ $i -le 10 ];then
                useradd -g class1 std0$i
        else
                useradd -g class1 std$i
        fi
done

編寫 Shell 程式,實現自動刪除 50 個賬號的功能,賬號名為stud1 至 stud50 ?

#!/bin/bash
for((i=1;i<51;i++))
do
                userdel -r stud$i
done

寫一個 sed 命令,修改 /tmp/input.txt 檔案的內容?

要求:

  • 刪除所有空行。
  • 一行中,如果包含 “11111”,則在 “11111” 前面插入 “AAA”,在 “11111” 後面插入 “BBB” 。比如:將內容為 0000111112222 的一行改為 0000AAA11111BBB2222 。
[root@~]## cat -n /tmp/input.txt
     1  000011111222
     2
     3  000011111222222
     4  11111000000222
     5
     6
     7  111111111111122222222222
     8  2211111111
     9  112222222
    10  1122
    11

## 刪除所有空行命令
[root@~]## sed '/^$/d' /tmp/input.txt
000011111222
000011111222222
11111000000222
111111111111122222222222
2211111111
112222222
1122

## 插入指定的字元
[root@~]## sed 's#\(11111\)#AAA\1BBB#g' /tmp/input.txt
0000AAA11111BBB222
0000AAA11111BBB222222
AAA11111BBB000000222
AAA11111BBBAAA11111BBB11122222222222
22AAA11111BBB111
112222222
1122

實戰

如何選擇 Linux 作業系統版本?

一般來講,桌面使用者首選 Ubuntu ;伺服器首選 RHEL 或 CentOS ,兩者中首選 CentOS 。

根據具體要求:

  • 安全性要求較高,則選擇 Debian 或者 FreeBSD 。

  • 需要使用資料庫高階服務和電子郵件網路應用的使用者可以選擇 SUSE 。

  • 想要新技術新功能可以選擇 Feddora ,Feddora 是 RHEL 和 CentOS 的一個測試版和預釋出版本。

  • 【重點】根據現有狀況,絕大多數網際網路公司選擇 CentOS 。現在比較常用的是 6 系列,現在市場佔有大概一半左右。另外的原因是 CentOS 更側重伺服器領域,並且無版權約束

    CentOS 7 系列,也慢慢使用的會比較多了。

如何規劃一臺 Linux 主機,步驟是怎樣?

  • 1、確定機器是做什麼用的,比如是做 WEB 、DB、還是遊戲伺服器。

    不同的用途,機器的配置會有所不同。

  • 2、確定好之後,就要定系統需要怎麼安裝,預設安裝哪些系統、分割槽怎麼做。

  • 3、需要優化系統的哪些引數,需要建立哪些使用者等等的。

請問當使用者反饋網站訪問慢,你會如何處理?

有哪些方面的因素會導致網站網站訪問慢?

  • 1、伺服器出口頻寬不夠用

    • 本身伺服器購買的出口頻寬比較小。一旦併發量大的話,就會造成分給每個使用者的出口頻寬就小,訪問速度自然就會慢。
    • 跨運營商網路導致頻寬縮減。例如,公司網站放在電信的網路上,那麼客戶這邊對接是長城寬頻或聯通,這也可能導致頻寬的縮減。
  • 2、伺服器負載過大,導致響應不過來

    可以從兩個方面入手分析:

    • 分析系統負載,使用 w 命令或者 uptime 命令檢視系統負載。如果負載很高,則使用 top 命令檢視 CPU ,MEM 等佔用情況,要麼是 CPU 繁忙,要麼是記憶體不夠。
    • 如果這二者都正常,再去使用 sar 命令分析網路卡流量,分析是不是遭到了攻擊。一旦分析出問題的原因,採取對應的措施解決,如決定要不要殺死一些程式,或者禁止一些訪問等。
  • 3、資料庫瓶頸

    • 如果慢查詢比較多。那麼就要開發人員或 DBA 協助進行 SQL 語句的優化。
    • 如果資料庫響應慢,考慮可以加一個資料庫快取,如 Redis 等。然後,也可以搭建 MySQL 主從,一臺 MySQL 伺服器負責寫,其他幾臺從資料庫負責讀。
  • 4、網站開發程式碼沒有優化好

    • 例如 SQL 語句沒有優化,導致資料庫讀寫相當耗時。

針對網站訪問慢,怎麼去排查?

  • 1、首先要確定是使用者端還是服務端的問題。當接到使用者反饋訪問慢,那邊自己立即訪問網站看看,如果自己這邊訪問快,基本斷定是使用者端問題,就需要耐心跟客戶解釋,協助客戶解決問題。

    不要上來就看服務端的問題。一定要從源頭開始,逐步逐步往下。

  • 2、如果訪問也慢,那麼可以利用瀏覽器的除錯功能,看看載入那一項資料消耗時間過多,是圖片載入慢,還是某些資料載入慢。

  • 3、針對伺服器負載情況。檢視伺服器硬體(網路、CPU、記憶體)的消耗情況。如果是購買的雲主機,比如阿里雲,可以登入阿里雲平臺提供各方面的監控,比如 CPU、記憶體、頻寬的使用情況。

  • 4、如果發現硬體資源消耗都不高,那麼就需要通過查日誌,比如看看 MySQL慢查詢的日誌,看看是不是某條 SQL 語句查詢慢,導致網站訪問慢。

怎麼去解決?

  • 1、如果是出口頻寬問題,那麼久申請加大出口頻寬。
  • 2、如果慢查詢比較多,那麼就要開發人員或 DBA 協助進行 SQL 語句的優化。
  • 3、如果資料庫響應慢,考慮可以加一個資料庫快取,如 Redis 等等。然後也可以搭建MySQL 主從,一臺 MySQL 伺服器負責寫,其他幾臺從資料庫負責讀。
  • 4、申請購買 CDN 服務,載入使用者的訪問。
  • 5、如果訪問還比較慢,那就需要從整體架構上進行優化咯。做到專角色專用,多臺伺服器提供同一個服務。

Linux 效能調優都有哪幾種方法?

  • 1、Disabling daemons (關閉 daemons)。
  • 2、Shutting down the GUI (關閉 GUI)。
  • 3、Changing kernel parameters (改變核心引數)。
  • 4、Kernel parameters (核心引數)。
  • 5、Tuning the processor subsystem (處理器子系統調優)。
  • 6、Tuning the memory subsystem (記憶體子系統調優)。
  • 7、Tuning the file system (檔案系統子系統調優)。
  • 8、Tuning the network subsystem(網路子系統調優)。

檔案管理命令

cat 命令

cat 命令用於連線檔案並列印到標準輸出裝置上。

cat 主要有三大功能:

1.一次顯示整個檔案:

cat filename

2.從鍵盤建立一個檔案:

cat > filename

只能建立新檔案,不能編輯已有檔案。

3.將幾個檔案合併為一個檔案:

cat file1 file2 > file
  • -b 對非空輸出行號
  • -n 輸出所有行號

例項

(1)把 log2012.log 的檔案內容加上行號後輸入 log2013.log 這個檔案裡

cat -n log2012.log log2013.log

(2)把 log2012.log 和 log2013.log 的檔案內容加上行號(空白行不加)之後將內容附加到 log.log 裡

cat -b log2012.log log2013.log log.log

(3)使用 here doc 生成新檔案

cat >log.txt <<EOF
>Hello
>World
>PWD=$(pwd)
>EOF
ls -l log.txt
cat log.txt
Hello
World
PWD=/opt/soft/test

(4)反向列示

tac log.txt
PWD=/opt/soft/test
World
Hello

chmod 命令

Linux/Unix 的檔案呼叫許可權分為三級 : 檔案擁有者、群組、其他。利用 chmod 可以控制檔案如何被他人所呼叫。

用於改變 linux 系統檔案或目錄的訪問許可權。用它控制檔案或目錄的訪問許可權。該命令有兩種用法。一種是包含字母和操作符表示式的文字設定法;另一種是包含數字的數字設定法。

每一檔案或目錄的訪問許可權都有三組,每組用三位表示,分別為檔案屬主的讀、寫和執行許可權;與屬主同組的使用者的讀、寫和執行許可權;系統中其他使用者的讀、寫和執行許可權。可使用 ls -l test.txt 查詢。

以檔案 log2012.log 為例:

-rw-r--r-- 1 root root 296K 11-13 06:03 log2012.log

第一列共有 10 個位置,第一個字元指定了檔案型別。在通常意義上,一個目錄也是一個檔案。如果第一個字元是橫線,表示是一個非目錄的檔案。如果是 d,表示是一個目錄。從第二個字元開始到第十個 9 個字元,3 個字元一組,分別表示了 3 組使用者對檔案或者目錄的許可權。許可權字元用橫線代表空許可,r 代表只讀,w 代表寫,x 代表可執行。

常用引數

-c 當發生改變時,報告處理資訊
-R 處理指定目錄以及其子目錄下所有檔案

許可權範圍:

u :目錄或者檔案的當前的使用者
g :目錄或者檔案的當前的群組
o :除了目錄或者檔案的當前使用者或群組之外的使用者或者群組
a :所有的使用者及群組

許可權代號:

r :讀許可權,用數字4表示
w :寫許可權,用數字2表示
x :執行許可權,用數字1表示
- :刪除許可權,用數字0表示
s :特殊許可權

例項

(1)增加檔案 t.log 所有使用者可執行許可權

chmod a+x t.log

(2)撤銷原來所有的許可權,然後使擁有者具有可讀許可權,並輸出處理資訊

chmod u=r t.log -c

(3)給 file 的屬主分配讀、寫、執行(7)的許可權,給file的所在組分配讀、執行(5)的許可權,給其他使用者分配執行(1)的許可權

chmod 751 t.log -c(或者:chmod u=rwx,g=rx,o=x t.log -c)

(4)將 test 目錄及其子目錄所有檔案新增可讀許可權

chmod u+r,g+r,o+r -R text/ -c

chown 命令

chown 將指定檔案的擁有者改為指定的使用者或組,使用者可以是使用者名稱或者使用者 ID;組可以是組名或者組 ID;檔案是以空格分開的要改變許可權的檔案列表,支援萬用字元。

-c 顯示更改的部分的資訊
-R 處理指定目錄及子目錄

例項

(1)改變擁有者和群組 並顯示改變資訊

chown -c mail:mail log2012.log

(2)改變檔案群組

chown -c :mail t.log

(3)改變資料夾及子檔案目錄屬主及屬組為 mail

chown -cR mail: test/

cp 命令

將原始檔複製至目標檔案,或將多個原始檔複製至目標目錄。

注意:命令列復制,如果目標檔案已經存在會提示是否覆蓋,而在 shell 指令碼中,如果不加 -i 引數,則不會提示,而是直接覆蓋!

-i 提示
-r 複製目錄及目錄內所有專案
-a 複製的檔案與原檔案時間一樣

例項

(1)複製 a.txt 到 test 目錄下,保持原檔案時間,如果原檔案存在提示是否覆蓋。

cp -ai a.txt test

(2)為 a.txt 建議一個連結(快捷方式)

cp -s a.txt link_a.txt

find 命令

用於在檔案樹中查詢檔案,並作出相應的處理。

命令格式:

find pathname -options [-print -exec -ok ...]

命令引數:

pathname: find命令所查詢的目錄路徑。例如用.來表示當前目錄,用/來表示系統根目錄。
-print: find命令將匹配的檔案輸出到標準輸出。
-exec: find命令對匹配的檔案執行該引數所給出的shell命令。相應命令的形式為'command' {  } \;,注意{   }和\;之間的空格。
-ok: 和-exec的作用相同,只不過以一種更為安全的模式來執行該引數所給出的shell命令,在執行每一個命令之前,都會給出提示,讓使用者來確定是否執行。

命令選項

-name 按照檔名查詢檔案
-perm 按檔案許可權查詢檔案
-user 按檔案屬主查詢檔案
-group  按照檔案所屬的組來查詢檔案。
-type  查詢某一型別的檔案,諸如:
   b - 塊裝置檔案
   d - 目錄
   c - 字元裝置檔案
   l - 符號連結檔案
   p - 管道檔案
   f - 普通檔案

例項

(1)查詢 48 小時內修改過的檔案

find -atime -2

(2)在當前目錄查詢 以 .log 結尾的檔案。 . 代表當前目錄

find ./ -name '*.log'

(3)查詢 /opt 目錄下 許可權為 777 的檔案

find /opt -perm 777

(4)查詢大於 1K 的檔案

find -size +1000c

查詢等於 1000 字元的檔案

find -size 1000c 

-exec 引數後面跟的是 command 命令,它的終止是以 ; 為結束標誌的,所以這句命令後面的分號是不可缺少的,考慮到各個系統中分號會有不同的意義,所以前面加反斜槓。{} 花括號代表前面find查詢出來的檔名。

head 命令

head 用來顯示檔案的開頭至標準輸出中,預設 head 命令列印其相應檔案的開頭 10 行。

常用引數

-n<行數> 顯示的行數(行數為複數表示從最後向前數)

例項

(1)顯示 1.log 檔案中前 20 行

head 1.log -n 20

(2)顯示 1.log 檔案前 20 位元組

head -c 20 log2014.log

(3)顯示 t.log最後 10 行

head -n -10 t.log

less 命令

less 與 more 類似,但使用 less 可以隨意瀏覽檔案,而 more 僅能向前移動,卻不能向後移動,而且 less 在檢視之前不會載入整個檔案。

常用命令引數

-i  忽略搜尋時的大小寫
-N  顯示每行的行號
-o  <檔名> 將less 輸出的內容在指定檔案中儲存起來
-s  顯示連續空行為一行
/字串:向下搜尋“字串”的功能
?字串:向上搜尋“字串”的功能
n:重複前一個搜尋(與 / 或 ? 有關)
N:反向重複前一個搜尋(與 / 或 ? 有關)
-x <數字> 將“tab”鍵顯示為規定的數字空格
b  向後翻一頁
d  向後翻半頁
h  顯示幫助介面
Q  退出less 命令
u  向前滾動半頁
y  向前滾動一行
空格鍵 滾動一行
Enter鍵 滾動一頁
[pagedown]: 向下翻動一頁
[pageup]:   向上翻動一頁

例項

(1)ps 檢視程式資訊並通過 less 分頁顯示

ps -aux | less -N

(2)檢視多個檔案

less 1.log 2.log

可以使用 n 檢視下一個,使用 p 檢視前一個。

ln 命令

功能是為檔案在另外一個位置建立一個同步的連結,當在不同目錄需要該問題時,就不需要為每一個目錄建立同樣的檔案,通過 ln 建立的連結(link)減少磁碟佔用量。

連結分類:軟體連結及硬連結

軟連結:

  • 1.軟連結,以路徑的形式存在。類似於Windows作業系統中的快捷方式
  • 2.軟連結可以 跨檔案系統 ,硬連結不可以
  • 3.軟連結可以對一個不存在的檔名進行連結
  • 4.軟連結可以對目錄進行連結

硬連結:

  • 1.硬連結,以檔案副本的形式存在。但不佔用實際空間。
  • 2.不允許給目錄建立硬連結
  • 3.硬連結只有在同一個檔案系統中才能建立

需要注意

  • 第一:ln命令會保持每一處連結檔案的同步性,也就是說,不論你改動了哪一處,其它的檔案都會發生相同的變化;
  • 第二:ln的連結又分軟連結和硬連結兩種,軟連結就是ln –s 原始檔 目標檔案,它只會在你選定的位置上生成一個檔案的映象,不會佔用磁碟空間,硬連結 ln 原始檔 目標檔案,沒有引數-s, 它會在你選定的位置上生成一個和原始檔大小相同的檔案,無論是軟連結還是硬連結,檔案都保持同步變化。
  • 第三:ln指令用在連結檔案或目錄,如同時指定兩個以上的檔案或目錄,且最後的目的地是一個已經存在的目錄,則會把前面指定的所有檔案或目錄複製到該目錄中。若同時指定多個檔案或目錄,且最後的目的地並非是一個已存在的目錄,則會出現錯誤資訊。

常用引數

-b 刪除,覆蓋以前建立的連結
-s 軟連結(符號連結)
-v 顯示詳細處理過程

例項

(1)給檔案建立軟連結,並顯示操作資訊

ln -sv source.log link.log

(2)給檔案建立硬連結,並顯示操作資訊

ln -v source.log link1.log

(3)給目錄建立軟連結

ln -sv /opt/soft/test/test3 /opt/soft/test/test5

locate 命令

locate 通過搜尋系統內建文件資料庫達到快速找到檔案,資料庫由 updatedb 程式來更新,updatedb 是由 cron daemon 週期性呼叫的。預設情況下 locate 命令在搜尋資料庫時比由整個由硬碟資料來搜尋資料來得快,但較差勁的是 locate 所找到的檔案若是最近才建立或 剛更名的,可能會找不到,在內定值中,updatedb 每天會跑一次,可以由修改 crontab 來更新設定值 (etc/crontab)。

locate 與 find 命令相似,可以使用如 *、? 等進行正則匹配查詢

常用引數

-l num(要顯示的行數)
-f   將特定的檔案系統排除在外,如將proc排除在外
-r   使用正則運算式做為尋找條件

例項

(1)查詢和 pwd 相關的所有檔案(檔名中包含 pwd)

locate pwd

(2)搜尋 etc 目錄下所有以 sh 開頭的檔案

locate /etc/sh

(3)查詢 /var 目錄下,以 reason 結尾的檔案

locate -r '^/var.*reason$'(其中.表示一個字元,*表示任務多個;.*表示任意多個字元)

more 命令

功能類似於 cat, more 會以一頁一頁的顯示方便使用者逐頁閱讀,而最基本的指令就是按空白鍵(space)就往下一頁顯示,按 b 鍵就會往回(back)一頁顯示。

命令引數

+n      從笫 n 行開始顯示
-n       定義螢幕大小為n行
+/pattern 在每個檔案顯示前搜尋該字串(pattern),然後從該字串前兩行之後開始顯示 
-c       從頂部清屏,然後顯示
-d       提示“Press space to continue,’q’ to quit(按空格鍵繼續,按q鍵退出)”,禁用響鈴功能
-l        忽略Ctrl+l(換頁)字元
-p       通過清除視窗而不是滾屏來對檔案進行換頁,與-c選項相似
-s       把連續的多個空行顯示為一行
-u       把檔案內容中的下畫線去掉

常用操作命令

Enter    向下 n 行,需要定義。預設為 1 行
Ctrl+F   向下滾動一屏
空格鍵  向下滾動一屏
Ctrl+B  返回上一屏
=       輸出當前行的行號
:f     輸出檔名和當前行的行號
V      呼叫vi編輯器
!命令   呼叫Shell,並執行命令
q       退出more

例項

(1)顯示檔案中從第3行起的內容

more +3 text.txt

(2)在所列出檔案目錄詳細資訊,藉助管道使每次顯示 5 行

ls -l | more -5

按空格顯示下 5 行。

mv 命令

移動檔案或修改檔名,根據第二引數型別(如目錄,則移動檔案;如為檔案則重命令該檔案)。

當第二個引數為目錄時,第一個引數可以是多個以空格分隔的檔案或目錄,然後移動第一個引數指定的多個檔案到第二個引數指定的目錄中。

例項

(1)將檔案 test.log 重新命名為 test1.txt

mv test.log test1.txt

(2)將檔案 log1.txt,log2.txt,log3.txt 移動到根的 test3 目錄中

mv llog1.txt log2.txt log3.txt /test3

(3)將檔案 file1 改名為 file2,如果 file2 已經存在,則詢問是否覆蓋

mv -i log1.txt log2.txt

(4)移動當前資料夾下的所有檔案到上一級目錄

mv * ../

rm 命令

刪除一個目錄中的一個或多個檔案或目錄,如果沒有使用 -r 選項,則 rm 不會刪除目錄。如果使用 rm 來刪除檔案,通常仍可以將該檔案恢復原狀。

rm [選項] 檔案…

例項

(1)刪除任何 .log 檔案,刪除前逐一詢問確認:

rm -i *.log

(2)刪除 test 子目錄及子目錄中所有檔案刪除,並且不用一一確認:

rm -rf test

(3)刪除以 -f 開頭的檔案

rm -- -f*

tail 命令

用於顯示指定檔案末尾內容,不指定檔案時,作為輸入資訊進行處理。常用檢視日誌檔案。

常用引數

-f 迴圈讀取(常用於檢視遞增的日誌檔案)
-n<行數> 顯示行數(從後向前)

(1)迴圈讀取逐漸增加的檔案內容

ping 127.0.0.1 > ping.log &

後臺執行:可使用 jobs -l 檢視,也可使用 fg 將其移到前臺執行。

tail -f ping.log

(檢視日誌)

touch 命令

Linux touch命令用於修改檔案或者目錄的時間屬性,包括存取時間和更改時間。若檔案不存在,系統會建立一個新的檔案。

ls -l 可以顯示檔案的時間記錄。

語法

touch [-acfm][-d<日期時間>][-r<參考檔案或目錄>] [-t<日期時間>][--help][--version][檔案或目錄…]
  • 引數說明
  • a 改變檔案的讀取時間記錄。
  • m 改變檔案的修改時間記錄。
  • c 假如目的檔案不存在,不會建立新的檔案。與 --no-create 的效果一樣。
  • f 不使用,是為了與其他 unix 系統的相容性而保留。
  • r 使用參考檔的時間記錄,與 --file 的效果一樣。
  • d 設定時間與日期,可以使用各種不同的格式。
  • t 設定檔案的時間記錄,格式與 date 指令相同。
  • –no-create 不會建立新檔案。
  • –help 列出指令格式。
  • –version 列出版本訊息。

例項

使用指令"touch"修改檔案"testfile"的時間屬性為當前系統時間,輸入如下命令:

$ touch testfile                #修改檔案的時間屬性 

首先,使用ls命令檢視testfile檔案的屬性,如下所示:

$ ls -l testfile                #檢視檔案的時間屬性  
#原來檔案的修改時間為16:09  
-rw-r--r-- 1 hdd hdd 55 2011-08-22 16:09 testfile  

執行指令"touch"修改檔案屬性以後,並再次檢視該檔案的時間屬性,如下所示:

$ touch testfile                #修改檔案時間屬性為當前系統時間  
$ ls -l testfile                #檢視檔案的時間屬性  
#修改後檔案的時間屬性為當前系統時間  
-rw-r--r-- 1 hdd hdd 55 2011-08-22 19:53 testfile  

使用指令"touch"時,如果指定的檔案不存在,則將建立一個新的空白檔案。例如,在當前目錄下,使用該指令建立一個空白檔案"file",輸入如下命令:

$ touch file            #建立一個名為“file”的新的空白檔案 

vim 命令

Vim是從 vi 發展出來的一個文字編輯器。程式碼補完、編譯及錯誤跳轉等方便程式設計的功能特別豐富,在程式設計師中被廣泛使用。

  • 開啟檔案並跳到第 10 行:vim +10 filename.txt
  • 開啟檔案跳到第一個匹配的行:vim +/search-term filename.txt
  • 以只讀模式開啟檔案:vim -R /etc/passwd

基本上 vi/vim 共分為三種模式,分別是命令模式(Command mode)輸入模式(Insert mode)底線命令模式(Last line mode)

簡單的說,我們可以將這三個模式想成底下的圖示來表示:

whereis 命令

whereis 命令只能用於程式名的搜尋,而且只搜尋二進位制檔案(引數-b)、man說明檔案(引數-m)和原始碼檔案(引數-s)。如果省略引數,則返回所有資訊。whereis 及 locate 都是基於系統內建的資料庫進行搜尋,因此效率很高,而find則是遍歷硬碟查詢檔案。

常用引數

-b   定位可執行檔案。
-m   定位幫助檔案。
-s   定位原始碼檔案。
-u   搜尋預設路徑下除可執行檔案、原始碼檔案、幫助檔案以外的其它檔案。

例項

(1)查詢 locate 程式相關檔案

whereis locate

(2)查詢 locate 的原始碼檔案

whereis -s locate

(3)查詢 lcoate 的幫助檔案

whereis -m locate

which 命令

在 linux 要查詢某個檔案,但不知道放在哪裡了,可以使用下面的一些命令來搜尋:

which     檢視可執行檔案的位置。
whereis 檢視檔案的位置。
locate  配合資料庫檢視檔案位置。
find        實際搜尋硬碟查詢檔名稱。

which 是在 PATH 就是指定的路徑中,搜尋某個系統命令的位置,並返回第一個搜尋結果。使用 which 命令,就可以看到某個系統命令是否存在,以及執行的到底是哪一個位置的命令。

常用引數

-n  指定檔名長度,指定的長度必須大於或等於所有檔案中最長的檔名。

例項

(1)檢視 ls 命令是否存在,執行哪個

which ls

(2)檢視 which

which which

(3)檢視 cd

which cd(顯示不存在,因為 cd 是內建命令,而 which 查詢顯示是 PATH 中的命令)

檢視當前 PATH 配置:

echo $PATH

或使用 env 檢視所有環境變數及對應值

文件編輯命令

grep 命令

強大的文字搜尋命令,grep(Global Regular Expression Print) 全域性正規表示式搜尋。

grep 的工作方式是這樣的,它在一個或多個檔案中搜尋字串模板。如果模板包括空格,則必須被引用,模板後的所有字串被看作檔名。搜尋的結果被送到標準輸出,不影響原檔案內容。

命令格式:

grep [option] pattern file|dir

常用引數

-A n --after-context顯示匹配字元後n行
-B n --before-context顯示匹配字元前n行
-C n --context 顯示匹配字元前後n行
-c --count 計算符合樣式的列數
-i 忽略大小寫
-l 只列出檔案內容符合指定的樣式的檔名稱
-f 從檔案中讀取關鍵詞
-n 顯示匹配內容的所在檔案中行數
-R 遞迴查詢資料夾

grep 的規則表示式:

^  #錨定行的開始 如:'^grep'匹配所有以grep開頭的行。 
$  #錨定行的結束 如:'grep$'匹配所有以grep結尾的行。 
.  #匹配一個非換行符的字元 如:'gr.p'匹配gr後接一個任意字元,然後是p。  
*  #匹配零個或多個先前字元 如:'*grep'匹配所有一個或多個空格後緊跟grep的行。
.*   #一起用代表任意字元。  
[]   #匹配一個指定範圍內的字元,如'[Gg]rep'匹配Grep和grep。 
[^]  #匹配一個不在指定範圍內的字元,如:'[^A-FH-Z]rep'匹配不包含A-R和T-Z的一個字母開頭,緊跟rep的行。  
\(..\)  #標記匹配字元,如'\(love\)',love被標記為1。   
\<      #錨定單詞的開始,如:'\<grep'匹配包含以grep開頭的單詞的行。
\>      #錨定單詞的結束,如'grep\>'匹配包含以grep結尾的單詞的行。
x\{m\}  #重複字元x,m次,如:'0\{5\}'匹配包含5個o的行。 
x\{m,\}  #重複字元x,至少m次,如:'o\{5,\}'匹配至少有5個o的行。  
x\{m,n\}  #重複字元x,至少m次,不多於n次,如:'o\{5,10\}'匹配5--10個o的行。  
\w    #匹配文字和數字字元,也就是[A-Za-z0-9],如:'G\w*p'匹配以G後跟零個或多個文字或數字字元,然後是p。  
\W    #\w的反置形式,匹配一個或多個非單詞字元,如點號句號等。  
\b    #單詞鎖定符,如: '\bgrep\b'只匹配grep。

例項

(1)查詢指定程式

ps -ef | grep svn

(2)查詢指定程式個數

ps -ef | grep svn -c

(3)從檔案中讀取關鍵詞

cat test1.txt | grep -f key.log

(4)從資料夾中遞迴查詢以grep開頭的行,並只列出檔案

grep -lR '^grep' /tmp

(5)查詢非x開關的行內容

grep '^[^x]' test.txt

(6)顯示包含 ed 或者 at 字元的內容行

grep -E 'ed|at' test.txt

wc 命令

wc(word count)功能為統計指定的檔案中位元組數、字數、行數,並將統計結果輸出

命令格式:

wc [option] file..

命令引數

-c 統計位元組數
-l 統計行數
-m 統計字元數
-w 統計詞數,一個字被定義為由空白、跳格或換行字元分隔的字串

例項

(1)查詢檔案的 行數 單詞數 位元組數 檔名

wc text.txt

結果:

7     8     70     test.txt

(2)統計輸出結果的行數

cat test.txt | wc -l

磁碟管理命令

cd 命令

cd(changeDirectory) 命令語法:

cd [目錄名]

說明:切換當前目錄至 dirName。

例項

(1)進入要目錄

cd /

(2)進入 “home” 目錄

cd ~

(3)進入上一次工作路徑

cd -

(4)把上個命令的引數作為cd引數使用。

cd !$

df 命令

顯示磁碟空間使用情況。獲取硬碟被佔用了多少空間,目前還剩下多少空間等資訊,如果沒有檔名被指定,則所有當前被掛載的檔案系統的可用空間將被顯示。預設情況下,磁碟空間將以 1KB 為單位進行顯示,除非環境變數 POSIXLY_CORRECT 被指定,那樣將以512位元組為單位進行顯示:

-a 全部檔案系統列表
-h 以方便閱讀的方式顯示資訊
-i 顯示inode資訊
-k 區塊為1024位元組
-l 只顯示本地磁碟
-T 列出檔案系統型別

例項

(1)顯示磁碟使用情況

df -l

(2)以易讀方式列出所有檔案系統及其型別

df -haT

du 命令

du 命令也是檢視使用空間的,但是與 df 命令不同的是 Linux du 命令是對檔案和目錄磁碟使用的空間的檢視:

命令格式:

du [選項] [檔案]

常用引數

-a 顯示目錄中所有檔案大小
-k 以KB為單位顯示檔案大小
-m 以MB為單位顯示檔案大小
-g 以GB為單位顯示檔案大小
-h 以易讀方式顯示檔案大小
-s 僅顯示總計
-c或--total  除了顯示個別目錄或檔案的大小外,同時也顯示所有目錄或檔案的總和

例項

(1)以易讀方式顯示資料夾內及子資料夾大小

du -h scf/

(2)以易讀方式顯示資料夾內所有檔案大小

du -ah scf/

(3)顯示幾個檔案或目錄各自佔用磁碟空間的大小,還統計它們的總和

du -hc test/ scf/

(4)輸出當前目錄下各個子目錄所使用的空間

du -hc --max-depth=1 scf/

ls命令

就是 list 的縮寫,通過 ls 命令不僅可以檢視 linux 資料夾包含的檔案,而且可以檢視檔案許可權(包括目錄、資料夾、檔案許可權)檢視目錄資訊等等。

常用引數搭配

ls -a 列出目錄所有檔案,包含以.開始的隱藏檔案
ls -A 列出除.及..的其它檔案
ls -r 反序排列
ls -t 以檔案修改時間排序
ls -S 以檔案大小排序
ls -h 以易讀大小顯示
ls -l 除了檔名之外,還將檔案的許可權、所有者、檔案大小等資訊詳細列出來

例項

(1) 按易讀方式按時間反序排序,並顯示檔案詳細資訊

ls -lhrt

(2) 按大小反序顯示檔案詳細資訊

ls -lrS

(3)列出當前目錄中所有以"t"開頭的目錄的詳細內容

ls -l t*

(4) 列出檔案絕對路徑(不包含隱藏檔案)

ls | sed "s:^:`pwd`/:"

(5) 列出檔案絕對路徑(包含隱藏檔案)

find $pwd -maxdepth 1 | xargs ls -ld

mkdir 命令

mkdir 命令用於建立資料夾。

可用選項:

  • -m: 對新建目錄設定存取許可權,也可以用 chmod 命令設定;
  • -p: 可以是一個路徑名稱。此時若路徑中的某些目錄尚不存在,加上此選項後,系統將自動建立好那些尚不在的目錄,即一次可以建立多個目錄。

例項

(1)當前工作目錄下建立名為 t的資料夾

mkdir t

(2)在 tmp 目錄下建立路徑為 test/t1/t 的目錄,若不存在,則建立:

mkdir -p /tmp/test/t1/t

pwd 命令

pwd 命令用於檢視當前工作目錄路徑。

例項

(1)檢視當前路徑

pwd

(2)檢視軟連結的實際路徑

pwd -P

rmdir 命令

從一個目錄中刪除一個或多個子目錄項,刪除某目錄時也必須具有對其父目錄的寫許可權。

注意:不能刪除非空目錄

例項

(1)當 parent 子目錄被刪除後使它也成為空目錄的話,則順便一併刪除:

rmdir -p parent/child/child11

網路通訊命令

ifconfig 命令

  • ifconfig 用於檢視和配置 Linux 系統的網路介面。
  • 檢視所有網路介面及其狀態:ifconfig -a
  • 使用 up 和 down 命令啟動或停止某個介面:ifconfig eth0 upifconfig eth0 down

iptables 命令

iptables ,是一個配置 Linux 核心防火牆的命令列工具。功能非常強大,對於我們開發來說,主要掌握如何開放埠即可。例如:

  • 把來源 IP 為 192.168.1.101 訪問本機 80 埠的包直接拒絕:iptables -I INPUT -s 192.168.1.101 -p tcp --dport 80 -j REJECT

  • 開啟 80 埠,因為web對外都是這個埠

    iptables -A INPUT -p tcp --dport 80 -j ACCEP
    
  • 另外,要注意使用 iptables save 命令,進行儲存。否則,伺服器重啟後,配置的規則將丟失。

netstat 命令

Linux netstat命令用於顯示網路狀態。

利用netstat指令可讓你得知整個Linux系統的網路情況。

語法

netstat [-acCeFghilMnNoprstuvVwx][-A<網路型別>][--ip]

引數說明

  • -a或–all 顯示所有連線中的Socket。
  • -A<網路型別>或–<網路型別> 列出該網路型別連線中的相關地址。
  • -c或–continuous 持續列出網路狀態。
  • -C或–cache 顯示路由器配置的快取資訊。
  • -e或–extend 顯示網路其他相關資訊。
  • -F或–fib 顯示FIB。
  • -g或–groups 顯示多重廣播功能群組組員名單。
  • -h或–help 線上幫助。
  • -i或–interfaces 顯示網路介面資訊表單。
  • -l或–listening 顯示監控中的伺服器的Socket。
  • -M或–masquerade 顯示偽裝的網路連線。
  • -n或–numeric 直接使用IP地址,而不通過域名伺服器。
  • -N或–netlink或–symbolic 顯示網路硬體外圍裝置的符號連線名稱。
  • -o或–timers 顯示計時器。
  • -p或–programs 顯示正在使用Socket的程式識別碼和程式名稱。
  • -r或–route 顯示Routing Table。
  • -s或–statistice 顯示網路工作資訊統計表。
  • -t或–tcp 顯示TCP傳輸協議的連線狀況。
  • -u或–udp 顯示UDP傳輸協議的連線狀況。
  • -v或–verbose 顯示指令執行過程。
  • -V或–version 顯示版本資訊。
  • -w或–raw 顯示RAW傳輸協議的連線狀況。
  • -x或–unix 此引數的效果和指定"-A unix"引數相同。
  • –ip或–inet 此引數的效果和指定"-A inet"引數相同。

例項

如何檢視系統都開啟了哪些埠?

[root@centos6 ~ 13:20 #55]# netstat -lnp
Active Internet connections (only servers)
Proto Recv-Q Send-Q Local Address               Foreign Address             State       PID/Program name
tcp        0      0 0.0.0.0:22                  0.0.0.0:*                   LISTEN      1035/sshd
tcp        0      0 :::22                       :::*                        LISTEN      1035/sshd
udp        0      0 0.0.0.0:68                  0.0.0.0:*                               931/dhclient
Active UNIX domain sockets (only servers)
Proto RefCnt Flags       Type       State         I-Node PID/Program name    Path
unix  2      [ ACC ]     STREAM     LISTENING     6825   1/init              @/com/ubuntu/upstart
unix  2      [ ACC ]     STREAM     LISTENING     8429   1003/dbus-daemon    /var/run/dbus/system_bus_socket

如何檢視網路連線狀況?

[root@centos6 ~ 13:22 #58]# netstat -an
Active Internet connections (servers and established)
Proto Recv-Q Send-Q Local Address               Foreign Address             State
tcp        0      0 0.0.0.0:22                  0.0.0.0:*                   LISTEN
tcp        0      0 192.168.147.130:22          192.168.147.1:23893         ESTABLISHED
tcp        0      0 :::22                       :::*                        LISTEN
udp        0      0 0.0.0.0:68                  0.0.0.0:*

如何統計系統當前程式連線數?

  • 輸入命令 netstat -an | grep ESTABLISHED | wc -l
  • 輸出結果 177 。一共有 177 連線數。

用 netstat 命令配合其他命令,按照源 IP 統計所有到 80 埠的 ESTABLISHED 狀態連結的個數?

嚴格來說,這個題目考驗的是對 awk 的使用。

首先,使用 netstat -an|grep ESTABLISHED 命令。結果如下:

tcp        0      0 120.27.146.122:80       113.65.18.33:62721      ESTABLISHED
tcp        0      0 120.27.146.122:80       27.43.83.115:47148      ESTABLISHED
tcp        0      0 120.27.146.122:58838    106.39.162.96:443       ESTABLISHED
tcp        0      0 120.27.146.122:52304    203.208.40.121:443      ESTABLISHED
tcp        0      0 120.27.146.122:33194    203.208.40.122:443      ESTABLISHED
tcp        0      0 120.27.146.122:53758    101.37.183.144:443      ESTABLISHED
tcp        0      0 120.27.146.122:27017    23.105.193.30:50556     ESTABLISHED

ping 命令

Linux ping命令用於檢測主機。

執行ping指令會使用ICMP傳輸協議,發出要求回應的資訊,若遠端主機的網路功能沒有問題,就會回應該資訊,因而得知該主機運作正常。

指定接收包的次數

ping -c 2 www.baidu.com

telnet 命令

Linux telnet命令用於遠端登入。

執行telnet指令開啟終端機階段作業,並登入遠端主機。

語法

telnet [-8acdEfFKLrx][-b<主機別名>][-e<脫離字元>][-k<域名>][-l<使用者名稱稱>][-n<記錄檔案>][-S<服務型別>][-X<認證形態>][主機名稱或IP地址<通訊埠>]

引數說明

  • -8 允許使用8位字元資料,包括輸入與輸出。
  • -a 嘗試自動登入遠端系統。
  • -b<主機別名> 使用別名指定遠端主機名稱。
  • -c 不讀取使用者專屬目錄裡的.telnetrc檔案。
  • -d 啟動排錯模式。
  • -e<脫離字元> 設定脫離字元。
  • -E 濾除脫離字元。
  • -f 此引數的效果和指定"-F"引數相同。
  • -F 使用Kerberos V5認證時,加上此引數可把本地主機的認證資料上傳到遠端主機。
  • -k<域名> 使用Kerberos認證時,加上此引數讓遠端主機採用指定的領域名,而非該主機的域名。
  • -K 不自動登入遠端主機。
  • -l<使用者名稱稱> 指定要登入遠端主機的使用者名稱稱。
  • -L 允許輸出8位字元資料。
  • -n<記錄檔案> 指定檔案記錄相關資訊。
  • -r 使用類似rlogin指令的使用者介面。
  • -S<服務型別> 設定telnet連線所需的IP TOS資訊。
  • -x 假設主機有支援資料加密的功能,就使用它。
  • -X<認證形態> 關閉指定的認證形態。

例項

登入遠端主機

# 登入IP為 192.168.0.5 的遠端主機
telnet 192.168.0.5 

系統管理命令

date 命令

顯示或設定系統的日期與時間。

命令引數:

-d<字串>  顯示字串所指的日期與時間。字串前後必須加上雙引號。
-s<字串>  根據字串來設定日期與時間。字串前後必須加上雙引號。
-u  顯示GMT。
%H 小時(00-23)
%I 小時(00-12)
%M 分鐘(以00-59來表示)
%s 總秒數。起算時間為1970-01-01 00:00:00 UTC。
%S 秒(以本地的慣用法來表示)
%a 星期的縮寫。
%A 星期的完整名稱。
%d 日期(以01-31來表示)。
%D 日期(含年月日)。
%m 月份(以01-12來表示)。
%y 年份(以00-99來表示)。
%Y 年份(以四位數來表示)。

例項

(1)顯示下一天

date +%Y%m%d --date="+1 day"  //顯示下一天的日期

(2)-d引數使用

date -d "nov 22"  今年的 11 月 22 日是星期三
date -d '2 weeks' 2周後的日期
date -d 'next monday' (下週一的日期)
date -d next-day +%Y%m%d(明天的日期)或者:date -d tomorrow +%Y%m%d
date -d last-day +%Y%m%d(昨天的日期) 或者:date -d yesterday +%Y%m%d
date -d last-month +%Y%m(上個月是幾月)
date -d next-month +%Y%m(下個月是幾月)

free 命令

顯示系統記憶體使用情況,包括實體記憶體、互動區記憶體(swap)和核心緩衝區記憶體。

命令引數

-b 以Byte顯示記憶體使用情況
-k 以kb為單位顯示記憶體使用情況
-m 以mb為單位顯示記憶體使用情況
-g 以gb為單位顯示記憶體使用情況
-s<間隔秒數> 持續顯示記憶體
-t 顯示記憶體使用總合

例項

(1)顯示記憶體使用情況

free
free -k
free -m

(2)以總和的形式顯示記憶體的使用資訊

free -t

(3)週期性查詢記憶體使用情況

free -s 10

kill 命令

傳送指定的訊號到相應程式。不指定型號將傳送SIGTERM(15)終止指定程式。如果任無法終止該程式可用"-KILL" 引數,其傳送的訊號為SIGKILL(9) ,將強制結束程式,使用ps命令或者jobs 命令可以檢視程式號。root使用者將影響使用者的程式,非root使用者只能影響自己的程式。

常用引數

-l  訊號,若果不加訊號的編號引數,則使用“-l”引數會列出全部的訊號名稱
-a  當處理當前程式時,不限制命令名和程式號的對應關係
-p  指定kill 命令只列印相關程式的程式號,而不傳送任何訊號
-s  指定傳送訊號
-u  指定使用者

例項

(1)先使用ps查詢程式pro1,然後用kill殺掉

kill -9 $(ps -ef | grep pro1)

ps 命令

ps(process status),用來檢視當前執行的程式狀態,一次性檢視,如果需要動態連續結果使用 top

linux上程式有5種狀態:

  1. 執行(正在執行或在執行佇列中等待)

  2. 中斷(休眠中, 受阻, 在等待某個條件的形成或接受到訊號)

  3. 不可中斷(收到訊號不喚醒和不可執行, 程式必須等待直到有中斷髮生)

  4. 僵死(程式已終止, 但程式描述符存在, 直到父程式呼叫wait4()系統呼叫後釋放)

  5. 停止(程式收到SIGSTOP, SIGSTP, SIGTIN, SIGTOU訊號後停止執行執行)

ps 工具標識程式的5種狀態碼:

D 不可中斷 uninterruptible sleep (usually IO)
R 執行 runnable (on run queue)
S 中斷 sleeping
T 停止 traced or stopped
Z 僵死 a defunct (”zombie”) process

命令引數

-A 顯示所有程式
a 顯示所有程式
-a 顯示同一終端下所有程式
c 顯示程式真實名稱
e 顯示環境變數
f 顯示程式間的關係
r 顯示當前終端執行的程式
-aux 顯示所有包含其它使用的程式

例項

(1)顯示當前所有程式環境變數及程式間關係

ps -ef

(2)顯示當前所有程式

ps -A

(3)與grep聯用查詢某程式

ps -aux | grep apache

(4)找出與 cron 與 syslog 這兩個服務有關的 PID 號碼

ps aux | grep '(cron|syslog)'

rpm 命令

Linux rpm 命令用於管理套件。

rpm(redhat package manager) 原本是 Red Hat Linux 發行版專門用來管理 Linux 各項套件的程式,由於它遵循 GPL 規則且功能強大方便,因而廣受歡迎。逐漸受到其他發行版的採用。RPM 套件管理方式的出現,讓 Linux 易於安裝,升級,間接提升了 Linux 的適用度。

# 檢視系統自帶jdk
rpm -qa | grep jdk
# 刪除系統自帶jdk
rpm -e --nodeps 檢視jdk顯示的資料
# 安裝jdk
rpm -ivh jdk-7u80-linux-x64.rpm

top 命令

顯示當前系統正在執行的程式的相關資訊,包括程式 ID、記憶體佔用率、CPU 佔用率等

常用引數

-c 顯示完整的程式命令
-s 保密模式
-p <程式號> 指定程式顯示
-n <次數>迴圈顯示次數

例項

top - 14:06:23 up 70 days, 16:44,  2 users,  load average: 1.25, 1.32, 1.35
Tasks: 206 total,   1 running, 205 sleeping,   0 stopped,   0 zombie
Cpu(s):  5.9%us,  3.4%sy,  0.0%ni, 90.4%id,  0.0%wa,  0.0%hi,  0.2%si,  0.0%st
Mem:  32949016k total, 14411180k used, 18537836k free,   169884k buffers
Swap: 32764556k total,        0k used, 32764556k free,  3612636k cached
PID USER      PR  NI  VIRT  RES  SHR S %CPU %MEM    TIME+  COMMAND  
28894 root      22   0 1501m 405m  10m S 52.2  1.3   2534:16 java  

前五行是當前系統情況整體的統計資訊區。

第一行,任務佇列資訊,同 uptime 命令的執行結果,具體引數說明情況如下

14:06:23 — 當前系統時間

up 70 days, 16:44 — 系統已經執行了70天16小時44分鐘(在這期間系統沒有重啟過的吆!)

2 users — 當前有2個使用者登入系統

load average: 1.15, 1.42, 1.44 — load average後面的三個數分別是1分鐘、5分鐘、15分鐘的負載情況。

load average資料是每隔5秒鐘檢查一次活躍的程式數,然後按特定演算法計算出的數值。如果這個數除以邏輯CPU的數量,結果高於5的時候就表明系統在超負荷運轉了。

第二行,Tasks — 任務(程式),具體資訊說明如下

系統現在共有206個程式,其中處於執行中的有1個,205個在休眠(sleep),stoped狀態的有0個,zombie狀態(殭屍)的有0個。

第三行,cpu狀態資訊,具體屬性說明如下

5.9%us — 使用者空間佔用CPU的百分比。
3.4% sy — 核心空間佔用CPU的百分比。
0.0% ni — 改變過優先順序的程式佔用CPU的百分比
90.4% id — 空閒CPU百分比
0.0% wa — IO等待佔用CPU的百分比
0.0% hi — 硬中斷(Hardware IRQ)佔用CPU的百分比
0.2% si — 軟中斷(Software Interrupts)佔用CPU的百分比

備註:在這裡CPU的使用比率和windows概念不同,需要理解linux系統使用者空間和核心空間的相關知識!

第四行,記憶體狀態,具體資訊如下:

32949016k total — 實體記憶體總量(32GB)
14411180k used — 使用中的記憶體總量(14GB)
18537836k free — 空閒記憶體總量(18GB)
169884k buffers — 快取的記憶體量 (169M)

第五行,swap交換分割槽資訊,具體資訊說明如下

32764556k total — 交換區總量(32GB)
0k used — 使用的交換區總量(0K)
32764556k free — 空閒交換區總量(32GB)
3612636k cached — 緩衝的交換區總量(3.6GB)

第六行,空行。

第七行以下:各程式(任務)的狀態監控,專案列資訊說明如下

PID — 程式id
USER — 程式所有者
PR — 程式優先順序
NI — nice值。負值表示高優先順序,正值表示低優先順序
VIRT — 程式使用的虛擬記憶體總量,單位kb。VIRT=SWAP+RES
RES — 程式使用的、未被換出的實體記憶體大小,單位kb。RES=CODE+DATA
SHR — 共享記憶體大小,單位kb
S — 程式狀態。D=不可中斷的睡眠狀態 R=執行 S=睡眠 T=跟蹤/停止 Z=殭屍程式
%CPU — 上次更新到現在的CPU時間佔用百分比
%MEM — 程式使用的實體記憶體百分比
TIME+ — 程式使用的CPU時間總計,單位1/100秒
COMMAND — 程式名稱(命令名/命令列)

top 互動命令

h 顯示top互動命令幫助資訊
c 切換顯示命令名稱和完整命令列
m 以記憶體使用率排序
P 根據CPU使用百分比大小進行排序
T 根據時間/累計時間進行排序
W 將當前設定寫入~/.toprc檔案中
o或者O 改變顯示專案的順序

yum 命令

yum( Yellow dog Updater, Modified)是一個在Fedora和RedHat以及SUSE中的Shell前端軟體包管理器。

基於RPM包管理,能夠從指定的伺服器自動下載RPM包並且安裝,可以自動處理依賴性關係,並且一次安裝所有依賴的軟體包,無須繁瑣地一次次下載、安裝。

yum提供了查詢、安裝、刪除某一個、一組甚至全部軟體包的命令,而且命令簡潔而又好記。

  • 1.列出所有可更新的軟體清單命令:yum check-update
  • 2.更新所有軟體命令:yum update
  • 3.僅安裝指定的軟體命令:yum install <package_name>
  • 4.僅更新指定的軟體命令:yum update <package_name>
  • 5.列出所有可安裝的軟體清單命令:yum list
  • 6.刪除軟體包命令:yum remove <package_name>
  • 7.查詢軟體包 命令:yum search
  • 8.清除快取命令:
    • yum clean packages: 清除快取目錄下的軟體包
    • yum clean headers: 清除快取目錄下的 headers
    • yum clean oldheaders: 清除快取目錄下舊的 headers
    • yum clean, yum clean all (= yum clean packages; yum clean oldheaders) :清除快取目錄下的軟體包及舊的headers

例項

安裝 pam-devel

[root@www ~]# yum install pam-devel

備份壓縮命令

bzip2 命令

  • 建立 *.bz2 壓縮檔案:bzip2 test.txt
  • 解壓 *.bz2 檔案:bzip2 -d test.txt.bz2

gzip 命令

  • 建立一個 *.gz 的壓縮檔案:gzip test.txt
  • 解壓 *.gz 檔案:gzip -d test.txt.gz
  • 顯示壓縮的比率:gzip -l *.gz

tar 命令

用來壓縮和解壓檔案。tar 本身不具有壓縮功能,只具有打包功能,有關壓縮及解壓是呼叫其它的功能來完成。

弄清兩個概念:打包和壓縮。打包是指將一大堆檔案或目錄變成一個總的檔案;壓縮則是將一個大的檔案通過一些壓縮演算法變成一個小檔案

常用引數

-c 建立新的壓縮檔案
-f 指定壓縮檔案
-r 新增檔案到已經壓縮檔案包中
-u 新增改了和現有的檔案到壓縮包中
-x 從壓縮包中抽取檔案
-t 顯示壓縮檔案中的內容
-z 支援gzip壓縮
-j 支援bzip2壓縮
-Z 支援compress解壓檔案
-v 顯示操作過程

有關 gzip 及 bzip2 壓縮:

gzip 例項:壓縮 gzip fileName .tar.gz 和.tgz  解壓:gunzip filename.gz 或 gzip -d filename.gz
          對應:tar zcvf filename.tar.gz     tar zxvf filename.tar.gz

bz2例項:壓縮 bzip2 -z filename .tar.bz2 解壓:bunzip filename.bz2或bzip -d filename.bz2
       對應:tar jcvf filename.tar.gz         解壓:tar jxvf filename.tar.bz2

例項

(1)將檔案全部打包成 tar 包

tar -cvf log.tar 1.log,2.log 或tar -cvf log.*

(2)將 /etc 下的所有檔案及目錄打包到指定目錄,並使用 gz 壓縮

tar -zcvf /tmp/etc.tar.gz /etc

(3)檢視剛打包的檔案內容(一定加z,因為是使用 gzip 壓縮的)

tar -ztvf /tmp/etc.tar.gz

(4)要壓縮打包 /home, /etc ,但不要 /home/dmtsai

tar --exclude /home/dmtsai -zcvf myfile.tar.gz /home/* /etc

unzip 命令

  • 解壓 *.zip 檔案:unzip test.zip
  • 檢視 *.zip 檔案的內容:unzip -l jasper.zip

相關文章