精讀Nginx原始碼·自動指令碼篇(1)如何讀取配置選項?
精讀 Nginx 原始碼·自動指令碼篇(1)如何讀取配置選項?
- Author: Poechant
- Blog: blog.CSDN.net/Poechant
- Email: zhongchao.ustc#gmail.com (#->@)
- Date: March 4th, 2012
- Copyright © 柳大·Poechant
在安裝Nginx
之前(即執行make
指令碼之前),首先是進行安裝的配置準備,包括環境檢查及生成檔案。這些工作是由自動指令碼完成的。和絕大多數軟體一樣,Nginx
的自動指令碼的入口,同樣是名為configure
的檔案。
除了configure
,其他的自動指令碼都在auto
目錄下。通過分析configure
指令碼原始碼,我們可以看到,configure
首先執行了auto
目錄下的幾個自動指令碼,如下:
. auto/options
. auto/init
. auto/sources
其中通過執行auto/options
指令碼,來設定配置選項。下面將逐步分析auto/options
指令碼是如何工作的。
1 讀取configure
配置引數
開始先宣告瞭 N 多變數,然後最主要的部分從這段開始:
opt=
for option
do
...
done
這段實際上是處理執行./configure
的時候攜帶的引數選項,for
迴圈每次對應一個引數選項 option。要注意for
迴圈體上面有一個全域性的opt
變數。這個迴圈體內的第一個語句是最重要是,它是:
opt="$opt `echo $option | sed -e \"s/\(--[^=]*=\)\(.* .*\)/\1'\2'/\"`"
通過迴圈執行該語句後,opt
的值就是一個由空格來分隔的引數列表。然後在迴圈體中接下來是一個case-esac
,用來得到引數值,如下:
case "$option" in
-*=*) value=`echo "$option" | sed -e 's/[-_a-zA-Z0-9]*=//'` ;;
*) value="" ;;
esac
其含義是將value
賦值為引數選項值,如果選項值不與-*=*
的模式匹配,則value
值為""
。接下來的case-esac
語句用來匹配引數的型別。
case "$option" in
--help) help=yes ;;
--prefix=) NGX_PREFIX="!" ;;
--prefix=*) NGX_PREFIX="$value" ;;
--sbin-path=*) NGX_SBIN_PATH="$value" ;;
--conf-path=*) NGX_CONF_PATH="$value" ;;
...
esac
各匹配的分支語句中進行配置變數的賦值。這些變數在auto/options
指令碼的最開始處賦以預設值,其中那些模組配置變數被賦以YES
的表示預設開啟,賦以NO
的表示預設關閉。但它們開啟與否由這個auto/options
中的case-esac
語句來決定。還有一些是安裝相關的選項變數也在這裡被賦值,比如:
-
prefix
引數值被賦予NGX_PREFIX
-
sbin-path
引數值被賦予NGX_SBIN_PATH
-
conf-path
引數值被賦予NGX_CONF_PATH
-
error-log-path
引數值被賦予NGX_ERROR_LOG_PATH
-
pid-path
引數值被賦予NGX_PID_PATH
-
lock-path
引數值被賦予NGX_LOCK_PATH
如果option
並不符合預設的這些匹配,也就是使用者使用configure
指令碼的時候攜帶的引數錯誤,則auto/options
會匹配該語句:
*)
echo "$0: error: invalid option \"$option\""
exit 1
從而提示使用者引數錯誤,並使指令碼退出執行。經過多次迴圈,for-do-done
就結束。
2 設定NGX_CONFIGURE
變數
處理完所有option
後,opt
就如我們上面提到的,成為由空格分割的配置項值,並被賦給NGX_CONFIGURE
變數:
NGX_CONFIGURE="$opt"
3 是否顯示configure
的幫助資訊
再看下面這句:
if [ $help = yes ]; then
cat << END
…
END
exit 1
fi
預設情況下$help
變數值在初始化時就為no
。如果configure
選項中指定了help
引數,則$help
引數為yes
,則會執行cat
命令,顯示大段的幫助資訊,然後退出。
4 是否關閉 HTTP 功能
預設情況下HTTP
的一些基本功能是被開啟的,如果使用者指定了--without-http
引數,則變數HTTP
會被賦值為NO
,則下面這段程式碼if-fi
中的語句會被執行:
if [ $HTTP = NO ]; then
HTTP_CHARSET=NO
HTTP_GZIP=NO
HTTP_SSI=NO
HTTP_USERID=NO
HTTP_ACCESS=NO
HTTP_STATUS=NO
HTTP_REWRITE=NO
HTTP_PROXY=NO
HTTP_FASTCGI=NO
fi
5 是否指定執行於 Windows 平臺
如果顯式指定了--crossbuild
引數,則變數NGX_PLATFORM
會被賦予當前for-do-done
迴圈中的"$value"
值,也就是--crossbuild
的引數值,一般在考慮在Windows
平臺使用時才會用到,看下面的語句:
if [ ".$NGX_PLATFORM" = ".win32" ]; then
NGX_WINE=$WINE
fi
如果指定--crossbuild=win32
,則NGX_WINE
就會被賦值了。
6 Nginx 配置檔案路徑
在載入configure
的引數時,如果沒有指定了--conf-path
引數,則$NGX_CONF_PATH
變數是沒有值的,則下面的語句會為NGX_CONF_PATH
賦以conf/nginx.conf
的預設值。不過我在想老毛子 Igor Sysoev 同學完全可以在auto/options
開始處和其他引數一樣先指定NGX_CONF_PATH
的預設值。
NGX_CONF_PATH=${NGX_CONF_PATH:-conf/nginx.conf}
然後獲取配置檔案所在目錄的:
NGX_CONF_PREFIX=`dirname $NGX_CONF_PATH`
如果指定引數--conf-path=/home/michael/nginx/conf/nginx.conf
,則NGX_CONF_PREFIX
的值就是/home/michael/nginx/conf
。
7 Nginx 程式 ID 檔案和鎖檔案路徑
下面是同樣的方式初始化NGX_PID_PATH
和NGX_LOCK_PATH
,分別對應configure
引數--pid-path
和--lock-path
,其預設值分別為logs/nginx.pid
和logs/nginx.lock
。
NGX_PID_PATH=${NGX_PID_PATH:-logs/nginx.pid}
NGX_LOCK_PATH=${NGX_LOCK_PATH:-logs/nginx.lock}
8 錯誤日誌檔案路徑
如果指定了引數--error-log-path
則NGX_ERROR_LOG_PATH
變數的值會被指定,根據下面的語句,如果指定的是stderr
則將NGX_ERROR_LOG_PATH
修改為空,即不需要錯誤日誌檔案。如果不是標準輸出,且其值為空,則設定為預設值logs/error.log
。
if [ ".$NGX_ERROR_LOG_PATH" = ".stderr" ]; then
NGX_ERROR_LOG_PATH=
else
NGX_ERROR_LOG_PATH=${NGX_ERROR_LOG_PATH:-logs/error.log}
fi
9 HTTP 相關各路徑
NGX_HTTP_LOG_PATH=${NGX_HTTP_LOG_PATH:-logs/access.log}
NGX_HTTP_CLIENT_TEMP_PATH=${NGX_HTTP_CLIENT_TEMP_PATH:-client_body_temp}
NGX_HTTP_PROXY_TEMP_PATH=${NGX_HTTP_PROXY_TEMP_PATH:-proxy_temp}
NGX_HTTP_FASTCGI_TEMP_PATH=${NGX_HTTP_FASTCGI_TEMP_PATH:-fastcgi_temp}
NGX_HTTP_UWSGI_TEMP_PATH=${NGX_HTTP_UWSGI_TEMP_PATH:-uwsgi_temp}
NGX_HTTP_SCGI_TEMP_PATH=${NGX_HTTP_SCGI_TEMP_PATH:-scgi_temp}
10 Perl 模組
如果指定了--with-perl_modules_path
引數,則NGX_PERL_MODULES
變數即被設定。如果指定的值為一個絕對路徑或未指定(空),則當做相對路徑來處理,設定為$NGX_PREFIX/$NGX_PERL_MODULES
。
case ".$NGX_PERL_MODULES" in
./*)
;;
.)
;;
*)
NGX_PERL_MODULES=$NGX_PREFIX/$NGX_PERL_MODULES
;;
esac
11 小結
通過執行auto/options
指令碼,所有的配置項已經被正確解析並載入到相應的配置變數中了。
-
轉載請註明來自“柳大的CSDN部落格”:blog.csdn.net/Poechant
-
相關文章
- Java動態指令碼Groovy讀取配置檔案Java指令碼
- NGINX原始碼閱讀Nginx原始碼
- 精讀《sqorn 原始碼》原始碼
- 精讀《zustand 原始碼》原始碼
- 【原始碼解讀】asp.net core原始碼啟動流程精細解讀原始碼ASP.NET
- 精讀《React PowerPlug 原始碼》React原始碼
- 精讀《Htm - Hyperscript 原始碼》原始碼
- 精讀《原始碼學習》原始碼
- Laravel 原始碼閱讀指南 -- 載入和讀取 ENV 配置Laravel原始碼
- Redis【1】- 如何閱讀 Redis 原始碼Redis原始碼
- Redis【1】- 如何閱讀 Redis原始碼Redis原始碼
- iOS開發原始碼閱讀篇--FMDB原始碼分析1(FMResultSet)iOS原始碼
- PostgreSQL 原始碼解讀(3)- 如何閱讀原始碼SQL原始碼
- 精讀《syntax-parser 原始碼》原始碼
- 精讀《Immer.js》原始碼JS原始碼
- 精讀《vue-lit 原始碼》Vue原始碼
- 「讀懂原始碼系列1」還在恐懼讀原始碼?看完這篇就不怕了原始碼
- 原始碼閱讀技巧篇原始碼
- 如何在Shell指令碼中逐行讀取檔案指令碼
- Axios 原始碼解讀 —— 原始碼實現篇iOS原始碼
- 精讀《react-easy-state 原始碼》React原始碼
- 精讀《Epitath 原始碼 - renderProps 新用法》原始碼
- 精讀《react-intersection-observer 原始碼》ReactServer原始碼
- 精讀《react-snippets - Router 原始碼》React原始碼
- Axios 原始碼解讀 —— request 篇iOS原始碼
- PostgreSQL 原始碼解讀(116)- MVCC#1(獲取快照#1)SQL原始碼MVCC#
- Ubuntu自動啟動配置指令碼Ubuntu指令碼
- 【原始碼閱讀】AndPermission原始碼閱讀原始碼
- 精盡MyBatis原始碼分析 - 文章導讀MyBatis原始碼
- Vue 原始碼解讀(1)—— 前言Vue原始碼
- 如何閱讀Java原始碼?Java原始碼
- 如何閱讀框架原始碼框架原始碼
- 如何閱讀jdk原始碼?JDK原始碼
- 如何快速閱讀原始碼原始碼
- 如何開始讀原始碼?原始碼
- 物件屬性讀取(核心原始碼)物件原始碼
- Java 讀取 sun 包的原始碼Java原始碼
- Vue2.0原始碼閱讀筆記(一):選項合併Vue原始碼筆記
- Vue 原始碼解讀(6)—— 例項方法Vue原始碼