Unix系統中常見的shell有:sh、csh、ksh、tcsh、bash
使用命令: vim /etc/shells 可以查看當前系統支持的bash
shell執行腳本是一門解釋性語言、批量化處理語言,大大的節省了工作成本
shell腳本第一行必須以 #!開頭,它表示該腳本使用後面的解釋器解釋執行。
舉個栗子:
//script.sh 注:這是一個文本文件
1 2 3 4 5#!/bin/bash
echo
"this is a test"
ls
ls -l
echo
"there are all files"
執行方式:
1 2 3 4 5 6//第一種執行方式:
[admin@localhost Shell]$ chmod +x script.sh
[admin@localhost Shell]$ ./script.sh
//第二種執行方式:
[admin@localhost Shell]$ /bin/bash script.sh
執行過程:
Shell會fork一個子進程並調用exec執行./script.sh這個程序,exec系統調用應該把子進程的代碼段替換成./script.sh程序的代碼段,並從它的_start開始執行。然而script.sh是個文本文件,根 本沒有代碼段和_start函數,怎麼辦呢?其實exec還有另外一種機制,如果要執行的是一個文本文件,並且第一行 指定了解釋器,則用解釋器程序的代碼段替換當前進程,並且從解釋器 的_start開始執行,而這個文本文件被當作命令行參數傳給解釋器。因此,執行上述腳本相當於執行程序!
輸入命令執行shell腳本後:
注意:像export、cd、env、set 這些內置命令,在鍵入命令行後,交互式進程不會創建子進程,而是調用bash內部的函數執行這些命令,改變的是交互式進程。
如果在命令行下,將多個命令用括號括起來,並用分號隔開來執行,交互式進程依然會創建一個子shell執行括號中的命令:
如果不加括號則是另一種情況,cd .. 命令會直接在交互式shell下執行:
. 或者 source這兩個命令是Shell的內建命令,這種方式不會創建子Shell,而是直接在交互式Shell下逐行 執行腳本中的命令。
例證:
script.sh
1 2 3 4 5#!/bin/bash
ls
echo
"#################"
cd ..
ls