阿里雲服務器ecs配置之安裝nginx

1、簡介

  Nginx是一款輕量級的網頁服務器、反向代理服務器。相較於Apache、lighttpd具備佔有內存少,穩定性高等優點。它最常的用途是提供反向代理服務。html

二 、安裝

一、準備工做nginx

Nginx的安裝依賴於如下三個包,意思就是在安裝Nginx以前首先必須安裝一下的三個包,注意安裝順序以下:正則表達式

  1 SSL功能須要openssl庫,直接經過yum安裝: #yum install openssl算法

  2 gzip模塊須要zlib庫,直接經過yum安裝: #yum install zlib後端

  3 rewrite模塊須要pcre庫,直接經過yum安裝: #yum install pcrecentos

二、安裝Nginx依賴項和Nginx瀏覽器

  1 使用yum安裝nginx須要包括Nginx的庫,安裝Nginx的庫服務器

    #rpm -Uvh http://nginx.org/packages/centos/7/noarch/RPMS/nginx-release-centos-7-0.el7.ngx.noarch.rpm負載均衡

  2 使用下面命令安裝nginxtcp

    #yum install nginx

  3 啓動Nginx

    #service nginx start

三、直接瀏覽器訪問localhost就會出現Nginx的歡迎界面表示你安裝成功了,不然就是安裝失敗了

  查看已開放的端口:firewall-cmd --list-ports

  默認80端口加入防火牆訪問白名單中:firewall-cmd --permanent --zone=public --add-port=80/tcp

  使用firewall-cmd --reload命令使其生效,以後能夠再查看下開放的端口。訪問ip:80端口,以下則表示安裝成功

四、配置Nginx

CentOS安裝Nginx後,安裝在了 /etc/nginx/目錄下,你能夠打開/etc/nginx/conf.d/default/conf查看裏面的配置,包括監聽端口,域名和nginx訪問的根目錄

3、配置

以上安裝方法nginx的配置文件位於

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

Nginx配置文件常見結構的從外到內依次是「http」「server」「location」等等,缺省的繼承關係是從外到內,也就是說內層塊會自動獲取外層塊的值做爲缺省值。

Server

接收請求的服務器須要將不一樣的請求按規則轉發到不一樣的後端服務器上,在 nginx 中咱們能夠經過構建虛擬主機(server)的概念來將這些不一樣的服務配置隔離。

server {
    listen       80;
    server_name  localhost;
    root   html;
    index  index.html index.htm;
}

例如咱們筆戈玩下的兩個子項目 passport 和 wan 就能夠經過在 nginx 的配置文件中配置兩個 server,servername 分別爲 passport.bigertech.com 和 wan.bigertech.com。這樣的話不一樣的 url 請求就會對應到 nginx 相應的設置,轉發到不一樣的後端服務器上。

這裏的 listen 指監聽端口,server_name 用來指定IP或域名,多個域名對應統一規則能夠空格分開,index 用於設定訪問的默認首頁地址,root 指令用於指定虛擬主機的網頁跟目錄,這個地方能夠是相對地址也能夠是絕對地址。

一般狀況下咱們能夠在 nginx.conf 中配置多個server,對不一樣的請求進行設置。就像這樣:

server {
    listen       80;
    server_name  host1;
    root   html;
    index  index.html index.htm;
}
server {
    listen       80;
    server_name  host2;
    root   /data/www/html;
    index  index.html index.htm;
}

可是當 server 超過2個時,建議將不一樣對虛擬主機的配置放在另外一個文件中,而後經過在主配置文件 nginx.conf 加上 include 指令包含進來。更便於管理。

include vhosts/*.conf;

就能夠把vhosts的文件都包含進去啦。

Localtion

每一個 url 請求都會對應的一個服務,nginx 進行處理轉發或者是本地的一個文件路徑,或者是其餘服務器的一個服務路徑。而這個路徑的匹配是經過 location 來進行的。咱們能夠將 server 當作對應一個域名進行的配置,而 location 是在一個域名下對更精細的路徑進行配置。

以上面的例子,能夠將root和index指令放到一個location中,那麼只有在匹配到這個location時纔會訪問root後的內容:

location / {
        root   /data/www/host2;
        index  index.html index.htm;
    }

location 匹配規則

~      波浪線表示執行一個正則匹配,區分大小寫
~*    表示執行一個正則匹配,不區分大小寫
^~    ^~表示普通字符匹配,若是該選項匹配,只匹配該選項,不匹配別的選項,通常用來匹配目錄
=      進行普通字符精確匹配

匹配例子:

location  = / {
  # 只匹配"/".
  [ configuration A ] 
}
location  / {
  # 匹配任何請求,由於全部請求都是以"/"開始
  # 可是更長字符匹配或者正則表達式匹配會優先匹配
  [ configuration B ] 
}
location ^~ /images/ {
  # 匹配任何以 /images/ 開始的請求,並中止匹配 其它location
  [ configuration C ] 
}
location ~* \.(gif|jpg|jpeg)$ {
  # 匹配以 gif, jpg, or jpeg結尾的請求. 
  # 可是全部 /images/ 目錄的請求將由 [Configuration C]處理.   
  [ configuration D ] 
}

請求:
/ -> 符合configuration A
/documents/document.html -> 符合configuration B
/images/1.gif -> 符合configuration C
/documents/1.jpg ->符合 configuration D

靜態文件映射

訪問文件的配置主要有 root 和 aliasp's 兩個指令。這兩個指令的區別容易弄混:

alias

alias後跟的指定目錄是準確的,而且末尾必須加 /。

location /c/ {
        alias /a/;
    }

若是訪問站點http://location/c訪問的就是/a/目錄下的站點信息。

root

root後跟的指定目錄是上級目錄,而且該上級目錄下要含有和location後指定名稱的同名目錄才行。

location /c/ {
        root /a/;
    }

這時訪問站點http://location/c訪問的就是/a/c目錄下的站點信息。

若是你須要將這個目錄展開,在這個location的末尾加上「autoindex on; 」就能夠了

轉發

配置起來很簡單好比我要將全部的請求到轉移到真正提供服務的一臺機器的 8001 端口,只要這樣:

location / {
    proxy_pass 172.16.1.1:8001;
}

這樣訪問host時,就都被轉發到 172.16.1.1的8001端口去了。

負載均衡

upstream myserver; {
    ip_hash;    
    server 172.16.1.1:8001;
    server 172.16.1.2:8002;
    server 172.16.1.3;
    server 172.16.1.4;
}
location / {
    proxy_pass http://myserver;
}

咱們在 upstream 中指定了一組機器,並將這個組命名爲 myserver,這樣在 proxypass 中只要將請求轉移到 myserver 這個 upstream 中咱們就實現了在四臺機器的反向代理加負載均衡。其中的 ip_hash 指明瞭咱們均衡的方式是按照用戶的 ip 地址進行分配。另外還有輪詢、指定權重輪詢、fair、url_hash幾種調度算法。

 

附註:配置完以後可使用測試命令驗證下配置是否正確

nginx -t

或者

nginx -tc [nginx文件地址]

詳見nginx 配置文件正確性驗證測試

相關文章
相關標籤/搜索