Nginx的使用

1 什麼是nginx

_ Nginx是一款高性能的http 服務器/反向代理服務器 及電子郵件(IMAP/POP3)代理服務器。由俄羅斯的程序 設計師Igor Sysoev所開發,官方測試nginx可以支支撐5萬 併發連接,而且cpu、內存等資源消耗卻很是低,運行很是穩定。_html

2 應用場景

一、http服務器。Nginx是一個http服務能夠獨立提供http服務。能夠作網頁靜態服務器。nginx

二、虛擬主機。能夠實如今一臺服務器虛擬出多個網站。例如我的網站使用的虛擬主機。web

三、反向代理,負載均衡。當網站的訪問量達到必定程度後,單臺服務器不能知足用戶的請求時,須要用多臺服務器集羣可使用nginx作反向代理。而且多臺服務器能夠平均分擔負載,不會由於某臺服務器負載高宕機而某臺服務器閒置的狀況。後端

3 nginx安裝 (見個人liunx的經常使用軟件安裝)

4 配置虛擬主機

就是在一臺服務器啓動多個網站。tomcat

如何區分不一樣的網站:服務器

一、域名不一樣併發

二、端口不一樣app

7.1. 經過端口區分不一樣虛擬機 能夠配置多個server,配置了多個虛擬主機。負載均衡

Nginx的配置文件:
/usr/local/nginx/conf/nginx.conf
#user  nobody;
worker_processes  1;

#error_log  logs/error.log;
#error_log  logs/error.log  notice;
#error_log  logs/error.log  info;

#pid        logs/nginx.pid;


events {
    worker_connections  1024;
}


http {
    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;
    #tcp_nopush     on;

    #keepalive_timeout  0;
    keepalive_timeout  65;

    #gzip  on;


#  經過端口來區分
    server {
        listen       80;
        server_name  localhost;
        location / {
            root   html;
            index  index.html index.htm;
        }

    }
    server {
        listen       81;
        server_name  localhost;
        location / {
            root   html81;
            index  index.html index.htm;
        }

    }

 #  經過域名區分
    server {
        listen       80;
        server_name  www.text.com;
        location / {
            root   html-text;
            index  index.html index.htm;
        }

    }
     server {
        listen       80;
        server_name  www.text1.com;
        location / {
            root   html-text1;
            index  index.html index.htm;
        }

    }


}

1

4.2. 經過域名區分虛擬主機tcp

4.2.1. 什麼是域名

域名就是網站。

www.baidu.com
www.taobao.com
www.jd.com
Tcp/ip

Dns服務器:把域名解析爲ip地址。保存的就是域名和ip的映射關係。

一級域名:
Baidu.com
Taobao.com
Jd.com
二級域名:
www.baidu.com
Image.baidu.com
Item.baidu.com
三級域名:
1.Image.baidu.com
Aaa.image.baidu.com

一個域名對應一個ip地址,一個ip地址能夠被多個域名綁定。

本地測試能夠修改hosts文件。

修改window的hosts文件:(C:\Windows\System32\drivers\etc)

能夠配置域名和ip的映射關係,若是hosts文件中配置了域名和ip的對應關係,不須要走DNS服務器。

192.168.36.210 www.text.com

192.168.36.210 www.text1.com

5 反向代理

    1. 什麼是反向代理

2

3

5.2. Nginx實現反向代理

兩個域名指向同一臺nginx服務器,用戶訪問不一樣的域名顯示不一樣的網頁內容。

兩個域名是www.sian.com.cn和www.sohu.com

nginx服務器使用虛擬機192.168.101.3

4

第一步:安裝兩個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.25.148 www.sina.com.cn

192.168.25.148 www.sohu.com

6 負載均衡

若是一個服務由多條服務器提供,須要把負載分配到不一樣的服務器處理,須要負載均衡。

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

能夠根據服務器的實際狀況調整服務器權重。 權重越高分配的請求越多,權重越低,請求越少。默認是都是1

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

7. Nginx的高可用(瞭解)

要實現nginx的高可用,須要實現備份機。

7.1. 什麼是負載均衡高可用

nginx做爲負載均衡器,全部請求都到了nginx, 可見nginx處於很是重點的位置,若是nginx服務器宕機 後端web服務將沒法提供服務,影響嚴重。_

爲了屏蔽負載均衡服務器的宕機,須要創建一個備份機。主服務器和備份機上都運行高可用(High Availability)監控程序,經過傳送諸如「I am alive」這樣的信息來監控對方的運行情況。當備份機不能在必定的時間內收到這樣的信息時,它就接管主服務器的服務IP並繼續提供負載均衡服務;當備份管理器又從主管理器收到「I am alive」這樣的信息時,它就釋放服務IP地址,這樣的主服務器就開始再次提供負載均衡服務。 7.2. keepalived+nginx實現主備

7.2.1. 什麼是keepalived

keepalived是集羣管理中保證集羣高可用的一個服務軟件, 用來防止單點故障。**

Keepalived的做用是檢測web服務器的狀態,若是有一臺web服務器死機,或工做出現故障,Keepalived將檢測到,並將有故障的web服務器從系統中剔除,當web服務器工做正常後Keepalived自動將web服務器加入到服務器羣中,這些工做所有自動完成,不須要人工干涉,須要人工作的只是修復故障的web服務器。_*

7.2.2. keepalived工做原理

keepalived是以VRRP協議爲實現基礎的,VRRP全稱Virtual Router Redundancy Protocol,即虛擬路由冗餘協議。

虛擬路由冗餘協議,能夠認爲是實現路由器高可用的協議,即將N臺提供相同功能的路由器組成一個路由器組,這個組裏面有一個master和多個backup,master上面有一個對外提供服務的vip(VIP = Virtual IP Address,虛擬IP地址,該路由器所在局域網內其餘機器的默認路由爲該vip),master會發組播,當backup收不到VRRP包時就認爲master宕掉了,這時就須要根據VRRP的優先級來選舉一個backup當master。這樣的話就能夠保證路由器的高可用了。

keepalived主要有三個模塊,分別是core、check和VRRP。core模塊爲keepalived的核心,負責主進程的啓動、維護以及全局配置文件的加載和解析。check負責健康檢查,包括常見的各類檢查方式。VRRP模塊是來實現VRRP協議的

詳細參考:Keepalived權威指南中文.pdf_

7.2.3. keepalived+nginx實現主備過程

初始狀態

6

主機宕機

7

主機恢復

8

7.2.4. 高可用環境

兩臺nginx,一主一備:192.168.101.3和192.168.101.4

兩臺tomcat服務器:192.168.101.五、192.168.101.6

7.2.5. 安裝keepalived

分別在主備nginx上安裝keepalived,參考「安裝手冊」進行安裝:

9

相關文章
相關標籤/搜索