1. 程式人生 > >Nginx初探究:安裝與簡單使用

Nginx初探究:安裝與簡單使用

nginx_logo

在學習淘淘商城的過程中接觸到了nginx,今天就把使用它的過程記錄下來,作為留存。

一、什麼是Nginx

Nginx是一款高效能的http伺服器/反向代理伺服器及電子郵件(IMAP/POP3)代理伺服器。由俄羅斯的程式設計師Igor Sysoev所開發,官方測試nginx能夠支支撐5萬併發連結,並且cpu、記憶體等資源消耗卻非常低,執行非常穩定。

應用場景

  • http伺服器。Nginx是一個http服務可以獨立提供http服務。可以做網頁靜態伺服器。
  • 虛擬主機。可以實現在一臺伺服器虛擬出多個網站。例如個人網站使用的虛擬主機。
  • 反向代理,負載均衡。當網站的訪問量達到一定程度後,單臺伺服器不能滿足使用者的請求時,需要用多臺伺服器叢集可以使用nginx做反向代理。並且多臺伺服器可以平均分擔負載,不會因為某臺伺服器負載高宕機而某臺伺服器閒置的情況。

二、nginx安裝

1.官網下載nginx原始碼。

2.外部環境準備:

  • 需要安裝gcc的環境:yum install gcc-c++
  • 第三方的開發包:
    ① PCRE(Perl Compatible Regular Expressions)是一個Perl庫,包括 perl 相容的正則表示式庫。nginx的http模組使用pcre來解析正則表示式,所以需要在linux上安裝pcre庫。
yum install -y pcre pcre-devel

②zlib庫提供了很多種壓縮和解壓縮的方式,nginx使用zlib對http包的內容進行gzip,所以需要在linux上安裝zlib庫。

yum install -y zlib zlib-devel

③OpenSSL 是一個強大的安全套接字層密碼庫,囊括主要的密碼演算法、常用的金鑰和證書封裝管理功能及SSL協議,並提供豐富的應用程式供測試或其它目的使用。nginx不僅支援http協議,還支援https(即在ssl協議上傳輸http)

yum install -y openssl openssl-devel

3.正式安裝

第一步:把nginx的原始碼包上傳到linux系統
第二步:解壓縮

tar zxf nginx-1.8.0.tar.gz 

第三步:使用configure命令建立一makeFile檔案。
./configure
–prefix=/usr/local/nginx
–pid-path=/var/run/nginx/nginx.pid
–lock-path=/var/lock/nginx.lock
–error-log-path=/var/log/nginx/error.log
–http-log-path=/var/log/nginx/access.log
–with-http_gzip_static_module
–http-client-body-temp-path=/var/temp/nginx/client
–http-proxy-temp-path=/var/temp/nginx/proxy
–http-fastcgi-temp-path=/var/temp/nginx/fastcgi
–http-uwsgi-temp-path=/var/temp/nginx/uwsgi
–http-scgi-temp-path=/var/temp/nginx/scgi
注意:以上都是一些安裝時配置nginx的一些引數,具體含義可以自行百度。另外在啟動nginx之前,上邊將臨時檔案目錄指定為/var/temp/nginx,需要在/var下建立temp及nginx目錄

mkdir /var/temp/nginx/client -p

第四步:編譯,執行make命令
第五步:安裝執行make install命令
第六步:測試
進入安裝目錄下的sbin檔案,執行./nginx後,開啟瀏覽器訪問主機ip。
注意:①預設是80埠。②是否關閉防火牆。
nginx_1
如果出現上圖,恭喜你,nginx安裝成功。
相關命令:

./nginx -s stop ##關閉nginx
./nginx -s quit ##關閉nginx(推薦使用)
./nginx -s reload ##重啟nginx

三、配置虛擬主機

1.通過埠號區分虛擬主機

開啟nginx的配置檔案

vim /usr/local/nginx/conf/nginx.conf

可以看到一個server節點,這個就是我們配置虛擬主機的關鍵,每一個此節點代表一臺主機。

    server {
        listen       80;    ##埠號
        server_name  localhost;

        #charset koi8-r;

        #access_log  logs/host.access.log  main;

        location / {
            root   html;    ##nginx安裝目錄下的html目錄
            index  index.html index.htm; ##每臺主機對應的頁面
        }
    }

當我們配置了多個server,就相當於配置了多個虛擬主機。這時我們就可以通過不同的埠號來進行訪問。

2.通過域名區分虛擬主機

首先我們要知道當我們開啟瀏覽器訪問每一個域名的時候,每一個域名對應的是一個ip地址。並且一個ip地址可以被多個域名繫結。當我們在本地hosts檔案(C:\Windows\System32\drivers\etc)中配置了域名與ip的對應的對映關係時,瀏覽器就不會再去走DNS伺服器
為了方便測試,我們先在本地hosts檔案配置一下測試所用資料

192.168.71.121 www.taobao.com
192.168.21.121 www.baidu.com

然後配置兩個server節點

    server {
        listen       80;
        server_name  www.taobao.com; ##不同域名配置

        #charset koi8-r;

        #access_log  logs/host.access.log  main;

        location / {
            root   html-taobao; ##不同域名訪問的不同資料夾
            index  index.html index.htm;
        }
    }
    server {
        listen       80;
        server_name  www.baidu.com; ##不同域名配置

        #charset koi8-r;

        #access_log  logs/host.access.log  main;

        location / {
            root   html-baidu; ##不同域名訪問的不同資料夾
            index  index.html index.htm;
        }
    }

然後在瀏覽器上訪問這兩個地址就可以訪問到我們配置的兩臺虛擬主機。

四、反向代理

1.什麼是反向代理

兩個域名指向同一臺nginx伺服器,使用者訪問不同的域名顯示不同的網頁內容。
兩個域名是www.sian.com.cn和www.sohu.com
nginx伺服器使用虛擬機器192.168.101.3

2.實現反向代理

第一步:安裝兩個tomcat,分別執行在8080和8081埠。
第二步:啟動兩個tomcat。
第三步:反向代理伺服器的配置

upstream tomcat1 {
	server 192.168.25.148:8080;
    }
    server {
        listen       80;
        server_name  www.sina.com.cn;

        #charset koi8-r;

        #access_log  logs/host.access.log  main;

        location / {
            proxy_pass   http://tomcat1;
            index  index.html index.htm;
        }
    }
    upstream tomcat2 {
	server 192.168.25.148:8081;
    }
    server {
        listen       80;
        server_name  www.sohu.com;

        #charset koi8-r;

        #access_log  logs/host.access.log  main;

        location / {
            proxy_pass   http://tomcat2;
            index  index.html index.htm;
        }
    }

第四步:nginx重新載入配置檔案
第五步:配置域名
在hosts檔案中新增域名和ip的對映關係

192.168.71.121 www.sina.com.cn
192.168.71.121 www.sohu.com

五、負載均衡

如果一個服務由多條伺服器提供,需要把負載分配到不同的伺服器處理,需要負載均衡。

 upstream tomcat2 {
	server 192.168.71.121:8081;
	server 192.168.71.121:8082;
  }

可以根據伺服器的實際情況調整伺服器權重。權重越高分配的請求越多,權重越低,請求越少。預設是都是1

 upstream tomcat2 {
	server 192.168.71.121:8081;
	server 192.168.71.121:8082 weight=2;
    }