CentOS基本操作

Linux是一套免費使用和自由傳播的類Unix操作系統,是一個基於POSIX和UNIX的多用戶、多任務、支持多線程和多CPU的操作系統。它能運行主要的UNIX工具軟件、應用程序和網絡協議。它支持32位和64位硬件。Linux繼承了Unix以網絡爲核心的設計思想,是一個性能穩定的多用戶網絡操作系統。

Linux操作系統誕生於1991 年10 月5 日(這是第一次正式向外公佈時間)。Linux存在着許多不同的Linux版本,但它們都使用了Linux內核。Linux可安裝在各種計算機硬件設備中,比如手機、平板電腦、路由器、視頻遊戲控制檯、臺式計算機、大型機和超級計算機。
嚴格來講,Linux這個詞本身只表示Linux內核,但實際上人們已經習慣了用Linux來形容整個基於Linux內核,並且使用GNU 工程各種工具和數據庫的操作系統。

Linux的基本思想有兩點:第一,一切都是文件;第二,每個軟件都有確定的用途。其中第一條詳細來講就是系統中的所有都歸結爲一個文件,包括命令、硬件和軟件設備、操作系統、進程等等對於操作系統內核而言,都被視爲擁有各自特性或類型的文件。至於說Linux是基於Unix的,很大程度上也是因爲這兩者的基本思想十分相近。

Linux是一款免費的操作系統,用戶可以通過網絡或其他途徑免費獲得,並可以任意修改其源代碼。這是其他的操作系統所做不到的。正是由於這一點,來自全世界的無數程序員參與了Linux的修改、編寫工作,程序員可以根據自己的興趣和靈感對其進行改變,這讓Linux吸收了無數程序員的精華,不斷壯大。

目前,個人電腦安裝的操作系統大多是Windows系統,因此,在學習Linux系統時,可以考慮在電腦上安裝一款虛擬機,然後在虛擬機上搭建Linux系統。

在這裏,我們以VMware虛擬機爲例,在VMware虛擬機上安裝CentOS系統。

一、VMware安裝

VMware本身是一家誕生於美國的公司的名稱,VMware(威睿) 是全球桌面到數據中心虛擬化解決方案的領導廠商。VMware公司成立於1998,總部在美國加州帕洛阿爾託(Palo Alto)。

在一臺機器上同時運行二個或更多Windows、DOS、LINUX系統。與“多啓動”系統相比,VMWare採用了完全不同的概念。多啓動系統在一個時刻只能運行一個系統,在系統切換時需要重新啓動機器。

VMWare是真正“同時”運行,多個操作系統在主系統的平臺上,就象標準Windows應用程序那樣切換。而且每個操作系統你都可以進行虛擬的分區、配置而不影響真實硬盤的數據,通過網卡將幾臺虛擬機用網卡連接爲一個局域網,極其方便。安裝在VMware上的操作系統在性能上比直接安裝在硬盤上的系統低不少,因此,比較適合學習和測試。

二、CentOS安裝

CentOS(Community Enterprise Operating System,中文意思是:社區企業操作系統)是Linux發行版之一,它是來自於Red Hat Enterprise Linux依照開放源代碼規定釋出的源代碼所編譯而成。由於出自同樣的源代碼,因此有些要求高度穩定性的服務器以CentOS替代商業版的Red Hat Enterprise Linux使用。兩者的不同,在於CentOS並不包含封閉源代碼軟件。

CentOS 是RHEL(Red Hat Enterprise Linux)源代碼再編譯的產物,而且在RHEL的基礎上修正了不少已知的 Bug ,相對於其他 Linux 發行版,其穩定性值得信賴。

CentOS在2014初,宣佈加入Red Hat。
CentOS 加入紅帽後不變的是:
1. CentOS 繼續不收費
2. 保持贊助內容驅動的網絡中心不變
3. Bug、Issue 和緊急事件處理策略不變
4. Red Hat Enterprise Linux 和 CentOS 防火牆也依然存在
變化的是:
1. 我們是爲紅帽工作,不是爲 RHEL
2. 紅帽提供構建系統和初始內容分發資源的贊助
3. 一些開發的資源包括源碼的獲取將更加容易
4. 避免了原來和紅帽上一些法律的問題

CentOS,也叫做社區企業操作系統,是企業Linux發行版領頭羊Red Hat Enterprise Linux(以下稱之爲RHEL)的再編譯版本。RHEL是很多企業採用的Linux發行版本,但是如果想得到RedHat的服務與技術支持,用戶必須向Red Hat付費纔可以。CentOS的開發者們使用Red Hat Linux的源代碼創造了一個和RHEL近乎相同的Linux。但是一切和RedHat有關的商標都被去除了,因爲RedHat不允許他們這樣做。CentOS是免費的,你可以使用它像使用RHEL一樣去構築企業級的Linux系統環境,但不需要向RedHat付任何的費用。CentOS的技術支持主要通過社區的官方郵件列表、論壇和聊天室。

在VMware上安裝CentOS7,安裝過程中,可以爲root用戶設置密碼,還可以添加自定義的用戶。

安裝好CentOS後,可以在VMware上啓動CentOS,選擇一個用戶登錄(如root或自定義用戶)。

總的來說,Linux系統的啓動過程大致可以分爲5個階段:

  • 內核的引導。
  • 運行 init。
  • 系統初始化。
  • 建立終端 。
  • 用戶登錄系統。

我們分析下上面的啓動過程。

內核引導

當計算機打開電源後,首先是BIOS開機自檢,按照BIOS中設置的啓動設備(通常是硬盤)來啓動。

操作系統接管硬件以後,首先讀入 /boot 目錄下的內核文件。

運行init

init 進程是系統所有進程的起點,你可以把它比擬成系統所有進程的老祖宗,沒有這個進程,系統中任何進程都不會啓動。

init 程序首先是需要讀取配置文件 /etc/inittab。

運行級別

許多程序需要開機啓動。它們在Windows叫做"服務"(service),在Linux就叫做"守護進程"(daemon)。

init進程的一大任務,就是去運行這些開機啓動的程序。

但是,不同的場合需要啓動不同的程序,比如用作服務器時,需要啓動Apache,用作桌面就不需要。

Linux允許爲不同的場合,分配不同的開機啓動程序,這就叫做"運行級別"(runlevel)。也就是說,啓動時根據"運行級別",確定要運行哪些程序。

Linux系統有7個運行級別(runlevel):

  • 運行級別0:系統停機狀態,系統默認運行級別不能設爲0,否則不能正常啓動
  • 運行級別1:單用戶工作狀態,root權限,用於系統維護,禁止遠程登陸
  • 運行級別2:多用戶狀態(沒有NFS)
  • 運行級別3:完全的多用戶狀態(有NFS),登陸後進入控制檯命令行模式
  • 運行級別4:系統未使用,保留
  • 運行級別5:X11控制檯,登陸後進入圖形GUI模式
  • 運行級別6:系統正常關閉並重啓,默認運行級別不能設爲6,否則不能正常啓動

系統初始化

在init的配置文件中有這麼一行: si::sysinit:/etc/rc.d/rc.sysinit 它調用執行了/etc/rc.d/rc.sysinit,而rc.sysinit是一個bash shell的腳本,它主要是完成一些系統初始化的工作,rc.sysinit是每一個運行級別都要首先運行的重要腳本。

它主要完成的工作有:激活交換分區,檢查磁盤,加載硬件模塊以及其它一些需要優先執行任務。

真正的rc啓動腳本實際上都是放在/etc/rc.d/init.d/目錄下。

建立終端

rc執行完畢後,返回init。這時基本系統環境已經設置好了,各種守護進程也已經啓動了。

init接下來會打開6個終端,以便用戶登錄系統。

在inittab中的以下6行就是定義了6個終端:

1:2345:respawn:/sbin/mingetty tty1
2:2345:respawn:/sbin/mingetty tty2
3:2345:respawn:/sbin/mingetty tty3
4:2345:respawn:/sbin/mingetty tty4
5:2345:respawn:/sbin/mingetty tty5
6:2345:respawn:/sbin/mingetty tty6

從上面可以看出在2、3、4、5的運行級別中都將以respawn方式運行mingetty程序,mingetty程序能打開終端、設置模式。

同時它會顯示一個文本登錄界面,這個界面就是我們經常看到的登錄界面,在這個登錄界面中會提示用戶輸入用戶名,而用戶輸入的用戶將作爲參數傳給login程序來驗證用戶的身份。

用戶登錄系統

一般來說,用戶的登錄方式有三種:

  • (1)命令行登錄
  • (2)ssh登錄
  • (3)圖形界面登錄

對於運行級別爲5的圖形方式用戶來說,他們的登錄是通過一個圖形化的登錄界面。登錄成功後可以直接進入 KDE、Gnome 等窗口管理器。

而本文主要講的還是文本方式登錄的情況:當我們看到mingetty的登錄界面時,我們就可以輸入用戶名和密碼來登錄系統了。

Linux 的賬號驗證程序是 login,login 會接收 mingetty 傳來的用戶名作爲用戶名參數。

然後 login 會對用戶名進行分析:如果用戶名不是 root,且存在 /etc/nologin 文件,login 將輸出 nologin 文件的內容,然後退出。

這通常用來系統維護時防止非root用戶登錄。只有/etc/securetty中登記了的終端才允許 root 用戶登錄,如果不存在這個文件,則 root 用戶可以在任何終端上登錄。

/etc/usertty文件用於對用戶作出附加訪問限制,如果不存在這個文件,則沒有其他限制。

圖形模式與文字模式的切換方式

Linux預設提供了六個命令窗口終端機讓我們來登錄。

默認我們登錄的就是第一個窗口,也就是tty1,這個六個窗口分別爲tty1,tty2 … tty6,你可以按下Ctrl + Alt + F1 ~ F6 來切換它們。

如果你安裝了圖形界面,默認情況下是進入圖形界面的,此時你就可以按Ctrl + Alt + F1 ~ F6來進入其中一個命令窗口界面。

當你進入命令窗口界面後再返回圖形界面只要按下Ctrl + Alt + F7 就回來了。

如果你用的vmware 虛擬機,命令窗口切換的快捷鍵爲 Alt + Space + F1~F6. 如果你在圖形界面下請按Alt + Shift + Ctrl + F1~F6 切換至命令窗口。

登錄系統後,可以打開命令行終端窗口,在裏面輸入命令“ cat /etc/os-release”,這時,終端窗口會顯示CentOS系統的版本信息:

接下來可以對CentOS進行操作了。

三、CentOS7基本操作

 Linux一般作爲服務器使用,而服務器一般放在機房,你不可能在機房操作你的Linux服務器。

這時我們就需要遠程登錄到Linux服務器來管理維護系統。

Linux系統中是通過ssh服務實現的遠程登錄功能,默認ssh服務端口號爲 22。

Window系統上 Linux 遠程登錄客戶端有SecureCRT, Putty, SSH Secure Shell等。由於Putty比較小巧簡易,我們這裏以Putty爲例。

在CentOS的操作裏,我們分爲這樣幾個方面來介紹:

1.Linux 文件基本屬性

Linux系統是一種典型的多用戶系統,不同的用戶處於不同的地位,擁有不同的權限。爲了保護系統的安全性,Linux系統對不同的用戶訪問同一文件(包括目錄文件)的權限做了不同的規定。在Linux中我們可以使用ll或者ls –l命令來顯示一個文件的屬性以及文件所屬的用戶和組。

[root@localhost ~]# ls -l
總用量 8
-rw-------. 1 root root 1802 9月  22 18:47 anaconda-ks.cfg
-rw-r--r--. 1 root root 1818 9月  22 10:50 initial-setup-ks.cfg
drwxr-xr-x. 2 root root    6 9月  22 10:51 公共

 bin文件的第一個屬性用"d"表示。"d"在Linux中代表該文件是一個目錄文件。

在Linux中第一個字符代表這個文件是目錄、文件或鏈接文件等等。

  • 當爲[ d ]則是目錄
  • 當爲[ - ]則是文件;
  • 若是[ l ]則表示爲鏈接文檔(link file);
  • 若是[ b ]則表示爲裝置文件裏面的可供儲存的接口設備(可隨機存取裝置);
  • 若是[ c ]則表示爲裝置文件裏面的串行端口設備,例如鍵盤、鼠標(一次性讀取裝置)。

接下來的字符中,以三個爲一組,且均爲『rwx』 的三個參數的組合。其中,[ r ]代表可讀(read)、[ w ]代表可寫(write)、[ x ]代表可執行(execute)。 要注意的是,這三個權限的位置不會改變,如果沒有權限,就會出現減號[ - ]而已。
每個文件的屬性由左邊第一部分的10個字符來確定(如下圖):

從左至右用0-9這些數字來表示。

第0位確定文件類型,第1-3位確定屬主(該文件的所有者)擁有該文件的權限。

第4-6位確定屬組(所有者的同組用戶)擁有該文件的權限,第7-9位確定其他用戶擁有該文件的權限。

其中,第1、4、7位表示讀權限,如果用"r"字符表示,則有讀權限,如果用"-"字符表示,則沒有讀權限;

第2、5、8位表示寫權限,如果用"w"字符表示,則有寫權限,如果用"-"字符表示沒有寫權限;第3、6、9位表示可執行權限,如果用"x"字符表示,則有執行權限,如果用"-"字符表示,則沒有執行權限。

Linux文件屬主和屬組

對於文件來說,它都有一個特定的所有者,也就是對該文件具有所有權的用戶。

同時,在Linux系統中,用戶是按組分類的,一個用戶屬於一個或多個組。

文件所有者以外的用戶又可以分爲文件所有者的同組用戶和其他用戶。

因此,Linux系統按文件所有者、文件所有者同組用戶和其他用戶來規定了不同的文件訪問權限。

對於 root 用戶來說,一般情況下,文件的權限對其不起作用。

Linux文件屬性有兩種設置方法,一種是數字,一種是符號。

Linux文件的基本權限就有九個,分別是owner/group/others三種身份各有自己的read/write/execute權限。

[root@localhost test4]# touch test1
[root@localhost test4]# ls -al test1
-rw-r--r--. 1 root root 0 10月 12 15:46 test1
[root@localhost test4]# chmod u=rwx,g=rx,o=r test1
[root@localhost test4]# ls -al test1
-rwxr-xr--. 1 root root 0 10月 12 15:46 test1
[root@localhost test4]# chmod a-x test1
[root@localhost test4]# ls -al test1
-rw-r--r--. 1 root root 0 10月 12 15:46 test1 

2.Linux 文件與目錄管理

Linux的目錄結構爲樹狀結構,最頂級的目錄爲根目錄 /。

其他目錄通過掛載可以將它們添加到樹中,通過解除掛載可以移除它們。

在開始本教程前我們需要先知道什麼是絕對路徑與相對路徑。

    • 絕對路徑:
      路徑的寫法,由根目錄 / 寫起,例如: /usr/share/doc 這個目錄。
    • 相對路徑:
      路徑的寫法,不是由 / 寫起,例如由 /usr/share/doc 要到 /usr/share/man 底下時,可以寫成: cd ../man 這就是相對路徑的寫法了。

處理目錄的常用命令

接下來我們就來看幾個常見的處理目錄的命令吧:

  • ls: 列出目錄
  • cd:切換目錄
  • pwd:顯示目前的目錄
  • mkdir:創建一個新的目錄
  • rmdir:刪除一個空的目錄
  • cp: 複製文件或目錄
  • rm: 移除文件或目錄

Linux 文件內容查看

Linux系統中使用以下命令來查看文件的內容:

  • cat  由第一行開始顯示文件內容
  • tac  從最後一行開始顯示,可以看出 tac 是 cat 的倒著寫!
  • nl   顯示的時候,順道輸出行號!
  • more 一頁一頁的顯示文件內容
  • less 與 more 類似,但是比 more 更好的是,他可以往前翻頁!
  • head 只看頭幾行
  • tail 只看尾巴幾行

3.Linux 用戶和用戶組管理

Linux系統是一個多用戶多任務的分時操作系統,任何一個要使用系統資源的用戶,都必須首先向系統管理員申請一個賬號,然後以這個賬號的身份進入系統。

用戶的賬號一方面可以幫助系統管理員對使用系統的用戶進行跟蹤,並控制他們對系統資源的訪問;另一方面也可以幫助用戶組織文件,併爲用戶提供安全性保護。

每個用戶賬號都擁有一個惟一的用戶名和各自的口令。

用戶在登錄時鍵入正確的用戶名和口令後,就能夠進入系統和自己的主目錄。

實現用戶賬號的管理,要完成的工作主要有如下幾個方面:

  • 用戶賬號的添加、刪除與修改。
  • 用戶口令的管理。
  • 用戶組的管理。

用戶賬號的管理工作主要涉及到用戶賬號的添加、修改和刪除。

添加用戶賬號就是在系統中創建一個新賬號,然後爲新賬號分配用戶號、用戶組、主目錄和登錄Shell等資源。剛添加的賬號是被鎖定的,無法使用。

每個用戶都有一個用戶組,系統可以對一個用戶組中的所有用戶進行集中管理。不同Linux 系統對用戶組的規定有所不同,如Linux下的用戶屬於與它同名的用戶組,這個用戶組在創建用戶時同時創建。

用戶組的管理涉及用戶組的添加、刪除和修改。組的增加、刪除和修改實際上就是對/etc/group文件的更新。

完成用戶管理的工作有許多種方法,但是每一種方法實際上都是對有關的系統文件進行修改。

與用戶和用戶組相關的信息都存放在一些系統文件中,這些文件包括/etc/passwd, /etc/shadow, /etc/group等。

Linux系統中的每個用戶都在/etc/passwd文件中有一個對應的記錄行,它記錄了這個用戶的一些基本屬性。

這個文件對所有用戶都是可讀的。

將用戶分組是Linux 系統中對用戶進行管理及控制訪問權限的一種手段。

每個用戶都屬於某個用戶組;一個組中可以有多個用戶,一個用戶也可以屬於不同的組。

當一個用戶同時是多個組中的成員時,在/etc/passwd文件中記錄的是用戶所屬的主組,也就是登錄時所屬的默認組,而其他組稱爲附加組。

用戶要訪問屬於附加組的文件時,必須首先使用newgrp命令使自己成爲所要訪問的組中的成員。

添加和刪除用戶對每位Linux系統管理員都是輕而易舉的事,比較棘手的是如果要添加幾十個、上百個甚至上千個用戶時,我們不太可能還使用useradd一個一個地添加,必然要找一種簡便的創建大量用戶的方法。Linux系統提供了創建大量用戶的工具,可以讓您立即創建大量用戶。

4.Linux磁盤管理好壞直接關係到整個系統的性能問題。

Linux磁盤管理常用三個命令爲df、du和fdisk。

  • df:列出文件系統的整體磁盤使用量
  • du:檢查磁盤空間使用量
  • fdisk:用於磁盤分區

四、vim操作

所有的 Unix Like 系統都會內建 vi 文書編輯器,其他的文書編輯器則不一定會存在。

但是目前我們使用比較多的是 vim 編輯器。

vim 具有程序編輯的能力,可以主動的以字體顏色辨別語法的正確性,方便程序設計。

簡單的來說, vi 是老式的字處理器,不過功能已經很齊全了,但是還是有可以進步的地方。 vim 則可以說是程序開發者的一項很好用的工具。

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

五、linux yum 命令

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

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

六、補充

如何對Linux進行關機呢?

在linux領域內大多用在服務器上,很少遇到關機的操作。畢竟服務器上跑一個服務是永無止境的,除非特殊情況下,不得已纔會關機。

正確的關機流程爲:sync > shutdown > reboot > halt

關機指令爲:shutdown ,你可以man shutdown 來看一下幫助文檔。

例如你可以運行如下命令關機:

sync 將數據由內存同步到硬盤中。

shutdown 關機指令,你可以man shutdown 來看一下幫助文檔。例如你可以運行如下命令關機:

shutdown –h 10 ‘This server will shutdown after 10 mins’ 這個命令告訴大家,計算機將在10分鐘後關機,並且會顯示在登陸用戶的當前屏幕中。

Shutdown –h now 立馬關機

Shutdown –h 20:25 系統會在今天20:25關機

Shutdown –h +10 十分鐘後關機

Shutdown –r now 系統立馬重啓

Shutdown –r +10 系統十分鐘後重啓

reboot 就是重啓,等同於 shutdown –r now

halt 關閉系統,等同於shutdown –h now 和 poweroff

 最後總結一下,不管是重啓系統還是關閉系統,首先要運行 sync 命令,把內存中的數據寫到磁盤中。

關機的命令有 shutdown –h now halt poweroff init 0 , 重啓系統的命令有 shutdown –r now reboot init 6

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章