接觸linux好久了,但一直沒有總線,總是嚐鮮,什麼都想學,但好多沒多沒有記住,特的總結了一些基本的東西,查了不少資料,不完善的方面我會慢慢的更新……
操做系統與外部最主要的接口就叫作shell。shell是操做系統最外面的一層。shell管理你與操做系統之間的交互:等待你輸入,向操做系統解釋你的輸入,而且處理各類各樣的操做系統的輸出結果。
Shell提供了你與操做系統之間通信的方式。這種通信能夠以交互方式(從鍵盤輸入,而且能夠當即獲得響應),或者以shell script(非交互)方式執行。shell script是放在文件中的一串shell和操做系統命令,它們能夠被重複使用。本質上,shell script是命令行命令簡單的組合到一個文件裏面。
Shell基本上是一個命令解釋器,相似於DOS下的command.com。它接收用戶命令(如ls等),而後調用相應的應用程序。較爲通用的shell有標準的Bourne shell (sh)和C shell (csh)。
交互式Shell和非交互式Shell
交互式模式就是shell等待你的輸入,而且執行你提交的命令。這種模式被稱做交互式是由於shell與用戶進行交互。這種模式也是大多數用戶很是熟悉的:登陸、執行一些命令、簽退。當你簽退後,shell也終止了。
shell也能夠運行在另一種模式:非交互式模式。在這種模式下,shell不與你進行交互,而是讀取存放在文件中的命令,而且執行它們。當它讀到文件的結尾,shell也就終止了。
Shell的類型
在UNIX中主要有兩大類shell
Bourne shell (包括 sh, ksh, and bash)
Bourne shell ( sh)
Korn shell ( ksh)
Bourne Again shell ( bash)
POSIX shell ( sh)
C shell (包括 csh and tcsh)
C shell ( csh)
TENEX/TOPS C shell ( tcsh)
Bourne Shell
最初的UNIX shell是由Stephen R. Bourne於20世紀70年代中期在新澤西的AT&T貝爾實驗室編寫的,這就是Bourne shell。Bourne shell 是一個交換式的命令解釋器和命令編程語言。Bourne shell 能夠運行爲login shell或者login shell的子shell(subshell)。只有login命令能夠調用Bourne shell做爲一個login shell。此時,shell先讀取/etc/profile文件和$HOME/.profile文件。/etc/profile文件爲全部的用戶定製環 境,$HOME/.profile文件爲本用戶定製環境。最後,shell會等待讀取你的輸入。
C Shell
Bill Joy於20世紀80年代早期,在Berkeley的加利福尼亞大學開發了C shell。它主要是爲了讓用戶更容易的使用交互式功能,並把ALGOL風格的語法結構變成了C語言風格。它新增了命令歷史、別名、文件名替換、做業控制等功能。
Korn Shell
有很長一段時間,只有兩類shell供人們選擇,Bourne shell用來編程,C shell用來交互。爲了改變這種情況,AT&T的bell實驗室David Korn開發了Korn shell。ksh結合了全部的C shell的交互式特性,並融入了Bourne shell的語法。所以,Korn shell廣受用戶的歡迎。它還新增了數學計算,進程協做(coprocess)、行內編輯(inline editing)等功能。Korn Shell 是一個交互式的命令解釋器和命令編程語言.它符合POSIX——一個操做系統的國際標準.POSIX不是一個操做系統,而是一個目標在於應用程序的移植性 的標準——在源程序一級跨越多種平臺。
Bourne Again Shell (bash)
bash是GNU計劃的一部分,用來替代Bourne shell。它用於基於GNU的系統如Linux.大多數的Linux(Red Hat, Slackware, Caldera)都以bash做爲缺省的shell,而且運行sh時,其實調用的是bash。
POSIX Shell
POSIX shell 是Korn shell的一個變種. 當前提供POSIX shell的最大賣主是Hewlett-Packard。在HP-UX 11.0 , POSIX shell 就是/bin/sh,而bsh是/usr/old/bin/sh.
各主要操做系統下缺省的Shell:
AIX 下是Korn Shell.
Solaris和FreeBSD缺省的是Bourne Shell
HP-UX缺省的是POSIX Shell
Linux是Bourne Again Shell
shell是一個命令解析器,它解釋用戶輸入的命令而且把它們送到系統的內核去執行。換句話說shell就是用戶與操做系統對話的一個接口,咱們發出一個命令,經過shell告訴系統讓系統執行咱們的命令。
黑客入侵時要獲得的是有admin權限的shell這樣才能徹底的控制系統。
當你用溢出獲得的shell就是擁有admin權限的shell這樣在你的命令提示付後就會出現"c:\\documents and setting \\"這和操做本身的機器沒什麼區別。