昨天的學習計劃:nginx的簡單安裝,在安裝過程當中其實出現了很多問題,對於一些基礎知識,本身掌握的還不是很好。你們安裝能夠參考一下官方手冊:http://wiki.nginx.org/NginxChshtml
1. gzip module requires zlib library
2. rewrite module requires pcre library
3. ssl support requires openssl library
Nginx 使用 Unix 下經常使用的 './configure && make && make install' 過程來編譯安裝。
configure
腳本肯定系統所具備一些特性,特別是 nginx 用來處理鏈接的方法。而後,它建立 Makefile 文件。
configure 支持下面的選項:
--prefix=<path> - Nginx安裝路徑。若是沒有指定,默認爲 /usr/local/nginx。
--sbin-path=<path> - Nginx
可執行文件安裝路徑。只能安裝時指定,若是沒有指定,默認爲<prefix>/sbin/nginx。
--conf-path=<path> - 在沒有給定-c選項下默認的nginx.conf的路徑。若是沒有指定,默認爲<prefix>/conf/nginx.conf。
--pid-path=<path> - 在nginx.conf中沒有指定pid指令的狀況下,默認的nginx.pid的路徑。若是沒有指定,默認爲 <prefix>/logs/nginx.pid。
--lock-path=<path> - nginx.lock文件的路徑。
--error-log-path=<path> - 在nginx.conf中沒有指定error_log指令的狀況下,默認的
錯誤日誌的路徑。若是沒有指定,默認爲 <prefix>/logs/error.log。
--http-log-path=<path> - 在nginx.conf中沒有指定access_log指令的狀況下,默認的訪問日誌的路徑。若是沒有指定,默認爲 <prefix>/logs/access.log。
--user=<user> - 在nginx.conf中沒有指定user指令的狀況下,默認的nginx使用的用戶。若是沒有指定,默認爲 nobody。
--group=<group> - 在nginx.conf中沒有指定user指令的狀況下,默認的nginx使用的組。若是沒有指定,默認爲 nobody。
--builddir=DIR - 指定編譯的目錄
--with-rtsig_module - 啓用 rtsig
模塊
--with-select_module --without-select_module - Whether or not to enable the select module. This module is enabled by default if a more suitable method such as kqueue,epoll,rtsig or /dev/poll is not discovered by configure.
//容許或不容許開啓SELECT模式,若是 configure 沒有找到更合適的模式,好比:kqueue(sun os),epoll (linux kenel 2.6+),rtsig(實時信號)或者/dev/poll(一種相似select的模式,底層實現與SELECT基本相 同,都是採用輪訓方法) SELECT模式將是默認安裝模式
--with-poll_module --without-poll_module - Whether or not to enable the poll module. This module is enabled by default if a more suitable method such as kqueue,epoll,rtsig or /dev/poll is not discovered by configure.
--with-http_ssl_module - Enable ngx_http_ssl_module. Enables SSL support and the ability to handle HTTPS requests. Requires OpenSSL. On Debian,this is libssl-dev.
//開啓HTTP SSL
模塊,使NGINX能夠支持HTTPS請求。這個
模塊須要已經安裝了OPENSSL,在DEBIAN上是libssl
--with-http_realip_module - 啓用 ngx_http_realip_module
--with-http_addition_module - 啓用 ngx_http_addition_module
--with-http_sub_module - 啓用 ngx_http_sub_module
--with-http_dav_module - 啓用 ngx_http_dav_module
--with-http_flv_module - 啓用 ngx_http_flv_module
--with-http_stub_status_module - 啓用 "server status" 頁
--without-http_charset_module - 禁用 ngx_http_charset_module
--without-http_gzip_module - 禁用 ngx_http_gzip_module. 若是啓用,須要 zlib。
--without-http_ssi_module - 禁用 ngx_http_ssi_module
--without-http_userid_module - 禁用 ngx_http_userid_module
--without-http_access_module - 禁用 ngx_http_access_module
--without-http_auth_basic_module - 禁用 ngx_http_auth_basic_module
--without-http_autoindex_module - 禁用 ngx_http_autoindex_module
--without-http_geo_module - 禁用 ngx_http_geo_module
--without-http_map_module - 禁用 ngx_http_map_module
--without-http_referer_module - 禁用 ngx_http_referer_module
--without-http_rewrite_module - 禁用 ngx_http_rewrite_module. 若是啓用須要 PCRE。
--without-http_proxy_module - 禁用 ngx_http_proxy_module
--without-http_fastcgi_module - 禁用 ngx_http_fastcgi_module
--without-http_memcached_module - 禁用 ngx_http_memcached_module
--without-http_limit_zone_module - 禁用 ngx_http_limit_zone_module
--without-http_empty_gif_module - 禁用 ngx_http_empty_gif_module
--without-http_browser_module - 禁用 ngx_http_browser_module
--without-http_upstream_ip_hash_module - 禁用 ngx_http_upstream_ip_hash_module
--with-http_perl_module - 啓用 ngx_http_perl_module
--with-perl_modules_path=PATH - 指定 perl
模塊的路徑
--with-perl=PATH - 指定 perl 執行文件的路徑
--http-log-path=PATH - Set path to the http access log
--http-client-body-temp-path=PATH - Set path to the http client request body temporary files
--http-proxy-temp-path=PATH - Set path to the http proxy temporary files
--http-fastcgi-temp-path=PATH - Set path to the http fastcgi temporary files
--without-http - 禁用 HTTP server
--with-mail - 啓用 IMAP4/POP3/SMTP 代理
模塊
--with-mail_ssl_module - 啓用 ngx_mail_ssl_module
--with-cc=PATH - 指定 C
編譯器的路徑
--with-cpp=PATH - 指定 C
預處理器的路徑
--with-cc-opt=OPTIONS - Additional parameters which will be added to the variable CFLAGS. With the use of the system library PCRE in FreeBSD,it is necessary to indicate --with-cc-opt="-I /usr/local/include". If we are using select() and it is necessary to increase the number of file descriptors,then this also can be assigned here: --with-cc-opt="-D FD_SETSIZE=2048".
--with-ld-opt=OPTIONS - Additional parameters passed to the linker. With the use of the system library PCRE in FreeBSD,it is necessary to indicate --with-ld-opt="-L /usr/local/lib".
--with-cpu-opt=CPU - 爲特定的 CPU 編譯,有效的值包括:pentium,pentiumpro,pentium3,pentium4,athlon,opteron,amd64,sparc32,sparc64,ppc64
--without-pcre - 禁止 PCRE 庫的使用。同時也會禁止 HTTP rewrite 模塊。在 "location" 配置指令中的
正則表達式也須要 PCRE。
--with-pcre=DIR - 指定 PCRE 庫的
源代碼的路徑。
--with-pcre-opt=OPTIONS - Set additional options for PCRE building.
--with-md5=DIR - Set path to md5 library sources.
--with-md5-opt=OPTIONS - Set additional options for md5 building.
--with-md5-asm - Use md5 assembler sources.
--with-sha1=DIR - Set path to sha1 library sources.
--with-sha1-opt=OPTIONS - Set additional options for sha1 building.
--with-sha1-asm - Use sha1 assembler sources.
--with-zlib=DIR - Set path to zlib library sources.
--with-zlib-opt=OPTIONS - Set additional options for zlib building.
--with-zlib-asm=CPU - Use zlib assembler sources optimized for specified CPU,valid values are: pentium,pentiumpro
--with-openssl=DIR - Set path to OpenSSL library sources
--with-openssl-opt=OPTIONS - Set additional options for OpenSSL building
--with-debug - 啓用調試日誌
--add-module=PATH - Add in a third-party module found in directory PATH
在不一樣版本間,選項可能會有些許變化,請老是使用 ./configure --help 命令來檢查一下當前的選項列表
下來咱們啓動一下nginx,
./usr/local/nginx/sbin/nginx
到此爲止咱們的nginx安裝好了。
對於nginx的啓動和關閉咱們不能像其餘服務同樣直接使用service 命令那樣去啓動,
直接引用在別處按到的一些文章http://www.cnblogs.com/derekchen/archive/2011/02/17/1957209.html
中止操做
中止操做是經過向nginx進程發送信號(什麼是信號請參閱linux文 章)來進行的
步驟1:查詢nginx主進程號
ps -ef | grep nginx
在進程列表裏 面找master進程,它的編號就是主進程號了。
步驟2:發送信號
從容中止Nginx:
kill -QUIT 主進程號
快速中止Nginx:
kill -TERM 主進程號
強制中止Nginx:
pkill -9 nginx
另外, 若在nginx.conf配置了pid文件存放路徑則該文件存放的就是Nginx主進程號,若是沒指定則放在nginx的logs目錄下。有了pid文 件,咱們就不用先查詢Nginx的主進程號,而直接向Nginx發送信號了,命令以下:
kill -信號類型 '/usr/nginx/logs/nginx.pid'
平滑重啓
若是更改了配置就要重啓Nginx,要先關閉Nginx再打開?不是的,能夠向Nginx 發送信號,平滑重啓。
平滑重啓命令:
kill -HUP 住進稱號或進程號文件路徑
或者使用ide
/usr/nginx/sbin/nginx -s reload
memcached
注意,修改了配置文件後最好先檢查一下修改過的配置文件是否正 確,以避免重啓後Nginx出現錯誤影響服務器穩定運行。判斷Nginx配置是否正確命令以下:
nginx -t -c /usr/nginx/conf/nginx.conf
或者學習
/usr/nginx/sbin/nginx -t
平滑升級
若是服務器正在運行的Nginx要進行升級、添加或刪除模塊時,咱們需 要停掉服務器並作相應修改,這樣服務器就要在一段時間內中止服務,Nginx能夠在不停機的狀況下進行各類升級動做而不影響服務器運行。
步驟1:
如 果升級Nginx程序,先用新程序替換舊程序文件,編譯安裝的話新程序直接編譯到Nginx安裝目錄中。
步 驟2:執行命令
kill -USR2 舊版程序的主進程號或進程文件名
此時舊的Nginx主進程將會把本身的進程文件更名爲.oldbin,而後執行新版 Nginx。新舊Nginx會同市運行,共同處理請求。
這時要逐步中止舊版 Nginx,輸入命令:
kill -WINCH 舊版主進程號
慢慢舊的工做進程就都會隨着任務執行完畢而退出,新版的Nginx的工做進程會逐漸取代舊版 工做進程。
此 時,咱們能夠決定使用新版仍是恢復到舊版。
不重載配置啓動新/舊工做進程
kill -HUP 舊/新版主進程號
從容關閉舊/新進程
kill -QUIT 舊/新主進程號
若是此時報錯,提示還有進程沒有結束就用下面命令先關閉舊/新工做進程,再關閉主進程號:
kill -TERM 舊/新工做進程號
這樣下來,若是要恢復到舊版本,只須要上面的幾個步 驟都是操做新版主進程號,若是要用新版本就上面的幾個步驟都操做舊版主進程號就好了。
上面就是Nginx的一些基本的操做,但願之後Nginx能有更好的方法來處理這些操做, 最好是Nginx的命令而不是向Nginx進程發送系統信號。
"