Nginx:engine X ,2002年,開源,商業版 Nginx是免費的、開源的、高性能的HTTP和反向代理服務器、郵件代理服務器、以及TCP/UDP代理服務器 解決C10K問題(10K Connections),http://www.ideawu.net/blog/archives/740.html Nginx官網:http://nginx.org nginx的其它的二次發行版: Tengine:由淘寶網發起的Web服務器項目。它在Nginx的基礎上,針對大訪問量網站的需求,添加了不少高級功能和特性。Tengine的性能和穩定性已經在大型的網站如淘寶網,天貓商城等獲得了很好的檢驗。它的最終目標是打造一個高效、穩定、安全、易用的Web平臺。從2011年12月開始,Tengine成爲一個開源項目,官網 http://tengine.taobao.org/ OpenResty:基於Nginx 與 Lua 語言的高性能 Web 平臺, 章亦春團隊開發,官網:http://openresty.org/cn/php
Nginx是多進程組織模型,並且是一個由Master主進程和Worker工做進程組成。html
是 Nginx 服務器正常運行 必不可少 的模塊,提供 錯誤日誌記錄 、 配置文件解析 、 事件驅動機制 、進程管理 等核心功能java
標準HTTP模塊:提供 HTTP 協議解析相關的功能,好比: 端口配置 、 網頁編碼設置 、HTTP響應頭設置 等等 python
主要用於擴展標準的 HTTP 功能,讓 Nginx 能處理一些特殊的服務,好比: Flash 多媒體傳輸 、解析 GeoIP 請求、 網絡傳輸壓縮 、 安全協議 SSL 支持等 nginx
主要用於支持Nginx 的郵件服務 ,包括對 POP3 協議、 IMAP 協議和 SMTP協議的支持 c++
是爲了擴展 Nginx 服務器應用,完成開發者自定義功能,好比: Json 支持、 Lua 支持等web
Nginx的安裝版本分爲開發版、穩定版和過時版, Nginx安裝可使用yum或源碼安裝,可是推薦使用源碼,一是yum的版本比較舊,二是編譯安裝能夠更方便自定義相關路徑,三是使用源碼編譯能夠自定義相關功能,更方便業務的上的使用,源碼安裝須要提早準備標準的編譯器,GCC的全稱是(GNU Compiler collection),其有GNU開發,並以GPL即LGPL許可,是自由的類UNIX即蘋果電腦Mac OS X操做系統的標準編譯器,由於GCC本來只能處理C語言,因此原名爲GNU C語言編譯器,後來獲得快速發展,能夠處理C++,Fortran,pascal,objective-C,java以及Ada等其餘語言,此外還須要Automake工具,以完成自動建立Makefile的工做,Nginx的一些模塊須要依賴第三方庫,好比pcre(支持rewrite),zlib(支持gzip模塊)和openssl(支持ssl模塊)等。正則表達式
安裝前須要提早配置好epel源vim
[root@CentOS7 ~]#yum install -y nginx
準備編譯安裝的基礎環境後端
[root@CentOS7 ~]#yum install -y vim lrzsz tree screen psmisc lsof tcpdump wget ntpdate gcc gcc-c++ glibc glibc-devel pcre pcre-devel openssl openssl-devel systemd-devel net-tools iotop bc zip unzip zlib-devel bash-completion nfs-utils automake libxml2 libxml2-devel libxslt libxslt-devel perl perl-ExtUtils-Embed gcc爲GNU Compiler Collection的縮寫,能夠編譯C和C++源代碼等,它是GNU開發的C和C++以及其餘不少種語言的編譯器(最先的時候只能編譯C,後來很快進化成一個編譯多種語言的集合,如Fortran、Pascal、Objective-C、Java、Ada、 Go等。) gcc 在編譯C++源代碼的階段,只能編譯 C++ 源文件,而不能自動和 C++ 程序使用的庫連接(編譯過程分爲編譯、連接兩個階段,注意不要和可執行文件這個概念搞混,相對可執行文件來講有三個重要的概念:編譯(compile)、連接(link)、加載(load)。源程序文件被編譯成目標文件,多個目標文件連同庫被連接成一個最終的可執行文件,可執行文件被加載到內存中運行)。所以,一般使用 g++ 命令來完成 C++ 程序的編譯和鏈接,該程序會自動調用 gcc 實現編譯。 gcc-c++也能編譯C源代碼,只不過把會把它當成C++源代碼,後綴爲.c的,gcc把它看成是C程序,而g++看成是c++程序;後綴爲.cpp的,二者都會認爲是c++程序,注意,雖然c++是c的超集,可是二者對語法的要求是有區別的。 automake是一個從Makefile.am文件自動生成Makefile.in的工具。爲了生成Makefile.in,automake還需用到perl,因爲automake建立的發佈徹底遵循GNU標準,因此在建立中不須要perl。libtool是一款方便生成各類程序庫的工具。 pcre pcre-devel:在Nginx編譯須要 PCRE(Perl Compatible Regular Expression),由於Nginx的Rewrite模塊和HTTP 核心模塊會使用到PCRE正則表達式語法。 zlip zlib-devel:nginx啓用壓縮功能的時候,須要此模塊的支持。 openssl openssl-devel:開啓SSL的時候須要此模塊的支持。
下載源碼包,解壓
[root@CentOS7 ~]# cd /usr/local/src/ [root@CentOS7 src]# wget https://nginx.org/download/nginx-1.14.2.tar.gz [root@CentOS7 src]# tar xf nginx-1.14.2.tar.gz [root@CentOS7 src]# cd nginx-1.14.2/
編譯安裝
[root@CentOS7 nginx-1.14.2]#./configure --prefix=/apps/nginx \ --user=nginx \ --group=nginx \ --with-http_ssl_module \ --with-http_v2_module \ --with-http_realip_module \ --with-http_stub_status_module \ --with-http_gzip_static_module \ --with-pcre \ --with-stream \ --with-stream_ssl_module \ --with-stream_realip_module [root@CentOS7 nginx-1.14.2]# make # 編譯步驟,根據Makefile文件生成相應的模塊 [root@CentOS7 nginx-1.14.2]# make install # 建立目錄,並將生成的模塊和文件複製到相應的目錄 Nginx安裝完成以後會生成四個主要目錄: 一、conf:保存nginx全部的配置文件,其中nginx.conf是nginx服務器的最核心最主要的配置文件,其餘的.conf則是用來配置nginx相關的功能的,例如fastcgi功能使用的是fastcgi.conf和fastcgi_params兩個文件,配置文件通常都有個樣板配置文件,是文件名.default結尾,使用的使用將其複製爲並將default去掉便可。 二、html目錄中保存了nginx服務器的web文件,可是能夠更改成其餘目錄保存web文件,另外還有一個50x的web文件是默認的錯誤頁面提示頁面。 三、logs:用來保存nginx服務器的訪問日誌錯誤日誌等日誌,logs目錄能夠放在其餘路徑,好比/var/logs/nginx裏面。 四、sbin:保存nginx二進制啓動腳本,能夠接受不一樣的參數以實現不一樣的功能。
建立nginx用戶
[root@CentOS7 nginx-1.14.2]# useradd nginx -s /sbin/nologin -u 2000
對安裝目錄受權
[root@CentOS7 nginx-1.14.2]# chown nginx.nginx -R /apps/nginx/
驗證版本即編譯參數
[root@CentOS7 ~]#/apps/nginx/sbin/nginx -V nginx version: nginx/1.14.2 built by gcc 4.8.5 20150623 (Red Hat 4.8.5-36) (GCC) built with OpenSSL 1.0.2k-fips 26 Jan 2017 TLS SNI support enabled configure arguments: --prefix=/apps/nginx --user=nginx --group=nginx --with-http_ssl_module --with-http_v2_module --with-http_realip_module --with-http_stub_status_module --with-http_gzip_static_module --with-pcre --with-stream --with-stream_ssl_module --with-stream_realip_module
啓動nginx
[root@CentOS ~]#/apps/nginx/sbin/nginx [root@CentOS ~]#ss -ntl | grep 80 LISTEN 0 128 *:80 *:*
Nginx測試頁訪問
[root@CentOS-Test ~]#cat /apps/nginx/conf/nginx.conf user nginx nginx; #啓動Nginx工做進程的用戶和組 worker_processes 1; #啓動Nginx工做進程的數量 #錯誤日誌記錄配置 #error_log logs/error.log; #error_log logs/error.log notice; #error_log logs/error.log info; pid logs/nginx.pid; #pid文件保存路徑 events { #events設置快,主要影響nginx服務器與用戶的網絡鏈接,好比是否容許同時接受多個網絡鏈接,使用哪一種事件驅動模型處理請求,每一個工做進程能夠同時支持的最大鏈接數,是否開啓對多工做進程下的網絡鏈接進行序列化等。 worker_connections 1024; #設置單個nginx工做進程能夠接受的最大併發,做爲web服務器的時候最大併發數爲worker_connections * worker_processes,做爲反向代理的時候爲(worker_connections * worker_processes)/2 } http { #http塊是Nginx服務器配置中的重要部分,緩存、代理和日誌格式定義等絕大多數功能和第三方模塊均可以在這設置,http塊能夠包含多個server塊,而一個server塊中又能夠包含多個location塊,server塊能夠配置文件引入、MIME-Type定義、日誌自定義、是否啓用sendfile、鏈接超時時間和單個連接的請求上限等。 include mime.types; default_type application/octet-stream; # 經過變量設置日誌文件內容格式 #log_format main '$remote_addr - $remote_user [$time_local] "$request" ' # '$status $body_bytes_sent "$http_referer" ' # '"$http_user_agent" "$http_x_forwarded_for"'; #access_log logs/access.log main; # 引用日誌文件格式 sendfile on; # 做爲web服務器的時候打開sendfile加快靜態文件傳輸,指定是否使用sendfile系統調用來傳輸文件,sendfile系統調用在兩個文件描述符之間直接傳遞數據(徹底在內核中操做),從而避免了數據在內核緩衝區和用戶緩衝區之間的拷貝,操做效率很高,被稱之爲零拷貝,硬盤 >> kernel buffer (快速拷貝到kernelsocket buffer) >>協議棧。 #tcp_nopush on; # 在開啓了sendfile的狀況下,合併請求後統一發送給客戶端。 #keepalive_timeout 0; keepalive_timeout 65; # 長鏈接超時時間(會話保持時長),單位是秒 #gzip on; # 開啓文件壓縮 server { # 設置一個虛擬機主機,能夠包含本身的全局快,同時也能夠包含多個location模塊。好比本虛擬機監聽的端口、本虛擬機的名稱和IP配置,多個server 可使用一個端口,好比都使用80端口提供web服務 listen 80; # 配置server監聽的端口 server_name localhost; # 本server的名稱,當訪問此名稱的時候nginx會調用當前serevr內部的配置進程匹配。 #charset koi8-r; # nginx編碼格式,默認爲俄語,建議設置成utf-8格式 #access_log logs/host.access.log main; location / { # location實際上是server的一個指令,爲nginx服務器提供比較多並且靈活的指令,都是在location中提現的,主要是基於nginx接受到的請求字符串,對用戶請求的UIL進行匹配,並對特定的指令進行處理,包括地址重定向、數據緩存和應答控制等功能都是在這部分實現,另外不少第三方模塊的配置也是在location模塊中配置。 root html; # 至關於默認頁面的目錄名稱,默認是相對路徑,可使用絕對路徑配置。 index index.html index.htm; # 默認的頁面文件名稱 } #error_page 404 /404.html; # 錯誤頁面的文件名稱 # redirect server error pages to the static page /50x.html # error_page 500 502 503 504 /50x.html; # 錯誤頁面的文件名稱 location = /50x.html { # location處理對應的不一樣錯誤碼的頁面定義到/50x.html,這個跟對應其server中定義的目錄下 root html; # 定義默認頁面所在的目錄 } # PHP頁面配置 # proxy the PHP scripts to Apache listening on 127.0.0.1:80 # #location ~ \.php$ { # 以http的方式轉發php請求到指定web服務器 # proxy_pass http://127.0.0.1; #} # pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000 # #location ~ \.php$ { # 以fastcgi的方式轉發php請求到php處理 # root html; # fastcgi_pass 127.0.0.1:9000; # fastcgi_index index.php; # fastcgi_param SCRIPT_FILENAME /scripts$fastcgi_script_name; # include fastcgi_params; #} # deny access to .htaccess files, if Apache's document root # concurs with nginx's one # #location ~ /\.ht { # 拒絕web形式訪問指定文件,如不少的網站都是經過.htaccess文件來改變本身的重定向等功能。 # deny all; # 拒絕全部 #} } # another virtual host using mix of IP-, name-, and port-based configuration # #server { # 自定義虛擬server # listen 8000; # listen somename:8080; # server_name somename alias another.alias; # location / { # root html; # index index.html index.htm; # 指定默認網頁文件,此指令由ngx_http_index_module模塊提供 # } #} # HTTPS server # #server { # https服務器配置 # listen 443 ssl; # server_name localhost; # ssl_certificate cert.pem; # ssl_certificate_key cert.key; # ssl_session_cache shared:SSL:1m; # ssl_session_timeout 5m; # ssl_ciphers HIGH:!aNULL:!MD5; # ssl_prefer_server_ciphers on; # location / { # root html; # index index.html index.htm; # } #} #導入其餘路徑的配置文件 #include /apps/nginx/conf.d/*.conf }