真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

Nginx中反向代理和緩存的使用方法-創(chuàng)新互聯(lián)

一.反向代理(案例)

概述

創(chuàng)新互聯(lián)建站堅(jiān)持“要么做到,要么別承諾”的工作理念,服務(wù)領(lǐng)域包括:網(wǎng)站建設(shè)、做網(wǎng)站、企業(yè)官網(wǎng)、英文網(wǎng)站、手機(jī)端網(wǎng)站、網(wǎng)站推廣等服務(wù),滿足客戶于互聯(lián)網(wǎng)時(shí)代的祿豐網(wǎng)站設(shè)計(jì)、移動(dòng)媒體設(shè)計(jì)的需求,幫助企業(yè)找到有效的互聯(lián)網(wǎng)解決方案。努力成為您成熟可靠的網(wǎng)絡(luò)建設(shè)合作伙伴!

1.反向代理(Reverse Proxy)方式是指以代理服務(wù)器來接受Internet上的連接請求,然后將請求轉(zhuǎn)發(fā)給內(nèi)部網(wǎng)絡(luò)上的服務(wù)器;并將從服務(wù)器上得到的結(jié)果返回給Internet上請求連接的客戶端,此時(shí)代理服務(wù)器對外就表現(xiàn)為一個(gè)服務(wù)器。通常的代理服務(wù)器,只用于代理內(nèi)部網(wǎng)絡(luò)對Internet的連接請求,客戶機(jī)必須指定代理服務(wù)器,并將本來要直接發(fā)送到Web服務(wù)器上的http請求發(fā)送到代理服務(wù)器中。當(dāng)一個(gè)代理服務(wù)器能夠代理外部網(wǎng)絡(luò)上的主機(jī),訪問內(nèi)部網(wǎng)絡(luò)時(shí),這種代理服務(wù)的方式稱為反向代理服務(wù)。

Nginx中反向代理和緩存的使用方法

如圖可以看出:反向代理服務(wù)器代理網(wǎng)站 Web 服務(wù)器接收 Http 請求,對請求進(jìn)行轉(zhuǎn)發(fā)。而且nginx作為反向代理服務(wù)器可以根據(jù)用戶請求的內(nèi)容把請求轉(zhuǎn)發(fā)給后端不同的web服務(wù)器,例如靜動(dòng)分離,再例如在 nginx 上創(chuàng)建多個(gè)虛擬主機(jī),這樣就成功的做到了在瀏覽器中輸入不同域名(url)的時(shí)候訪問后端的不同 web 服務(wù)器或 web 群集。

2、反向代理的作用
①保護(hù)網(wǎng)站安全:任何來自 Internet 的請求都必須先經(jīng)過代理服務(wù)器

Nginx中反向代理和緩存的使用方法

②通過配置緩存功能加速 Web 請求:可以緩存真實(shí) Web 服務(wù)器上的某些靜態(tài)資源,減輕真實(shí) Web 服務(wù)器的負(fù)載壓力

Nginx中反向代理和緩存的使用方法

③實(shí)現(xiàn)負(fù)載均衡:充當(dāng)負(fù)載均衡服務(wù)器均衡地分發(fā)請求,平衡集群中各個(gè)服務(wù)器的負(fù)載壓力;

Nginx中反向代理和緩存的使用方法

  • 實(shí)驗(yàn)環(huán)境

Nginx中反向代理和緩存的使用方法

下載nginx軟件包

192.168.222.128   nginx服務(wù)器
192.168.222.129   web
192.168.222.130   web

  • nginx服務(wù)器操作如下:
[root@localhost / ]#tar zxf ngx_cache_purge-2.3.tar.gz 
[root@localhost / ]#unzip nginx-sticky-module.zip
[root@localhost / ]#tar zxf nginx-1.14.0.tar.gz 
[root@localhost /]# yum -y install pcre-devel openssl-devel
[root@localhost /]#cd nginx-1.14.0/
[root@localhost nginx-1.14.0]#./configure --prefix=/usr/local/nginx  \
--user=nginx --group=nginx --with-http_stub_status_module --with-http_realip_module --with-http_ssl_module  \
--with-http_gzip_static_module --http-client-body-temp-path=/var/tmp/nginx/client  \
--http-fastcgi-temp-path=/var/tmp/nginx/fcgi  \
--with-pcre  --add-module=../ngx_cache_purge-2.3  \
--add-module=../nginx-sticky-module  \
--with-http_flv_module  \
[root@localhost nginx-1.14.0]# make && make install
[root@localhost nginx-1.14.0]# ln -s /usr/local/nginx/sbin/nginx  /usr/local/sbin/
[root@localhost nginx-1.14.0]# nginx -t
nginx: the configuration file /usr/local/nginx/conf/nginx.conf syntax is ok
nginx: [emerg] getpwnam("nginx") failed
\\可以看到報(bào)錯(cuò),沒有創(chuàng)建nginx用戶
[root@localhost nginx-1.14.0]# useradd -s /sbin/nologin -M nginx
[root@localhost nginx-1.14.0]# nginx -t
nginx: the configuration file /usr/local/nginx/conf/nginx.conf syntax is ok
nginx: [emerg] mkdir() "/var/tmp/nginx/client" failed (2: No such file or directory)
nginx: configuration file /usr/local/nginx/conf/nginx.conf test failed
\\報(bào)錯(cuò)顯示沒有創(chuàng)建目錄
[root@localhost nginx-1.14.0]# mkdir -p /var/tmp/nginx/client 
[root@localhost nginx-1.14.0]# nginx -t
nginx: the configuration file /usr/local/nginx/conf/nginx.conf syntax is ok
nginx: configuration file /usr/local/nginx/conf/nginx.conf test is successful
[root@localhost nginx-1.14.0]# nginx
[root@localhost ~]# netstat -anpt | grep nginx
tcp     0    0 0.0.0.0:80        0.0.0.0:      LISTEN    9886/nginx: master  
[root@localhost ~]# vim /usr/local/nginx/conf/nginx.conf 
\\在http中添加如下
 upstream backend {
     sticky;
     server 192.168.222.129:80 weight=1 max_fails=2 fail_timeout=10s;   
     server 192.168.222.130:80 weight=1 max_fails=2 fail_timeout=10s;
}
\\
weight : 輪詢權(quán)值也是可以用在 ip_hash 的,默認(rèn)值為 1
max_fails :允許請求失敗的次數(shù),默認(rèn)為 1。當(dāng)超過大次數(shù)時(shí),返回 proxy_next_upstream模塊定義的錯(cuò)誤。
fail_timeout : 有兩層含義,一是在 10s 時(shí)間內(nèi)最多容許 2 次失敗;二是在經(jīng)歷了 2 次失敗以后,10s 時(shí)間內(nèi)不分配請求到這臺服務(wù)器。

\\在location添加,可以把以前的localtion注釋掉
 location / {
     proxy_pass http://backend;
}
[root@localhost /]# nginx -s reload  //重載nginx服務(wù)
  • 模塊解釋
    nginx-sticky-module 模塊:這個(gè)模塊的作用是通過 cookie 黏貼的方式將來自同一個(gè)客戶端(瀏覽器)的請求發(fā)送到同一個(gè)后端服務(wù)器上處理,這樣一定程度上可以解決多個(gè) backend servers 的 session 同步的問題 —— 因?yàn)椴辉傩枰?,?RR 輪詢模式必須要運(yùn)維人員自己考慮 session 同步的實(shí)現(xiàn)。

load-balance 其它調(diào)度方案:

  • 輪詢(默認(rèn)) : 每個(gè)請求按時(shí)間順序逐一分配到不同的后端服務(wù)器,如果后端某臺服務(wù)器,故障系統(tǒng)被自動(dòng)剔除,使用戶訪問不受影響。Weight 指定輪詢權(quán)值,Weight 值越大,分配到的訪問機(jī)率越高,主要用于后端每個(gè)服務(wù)器性能不均的情況下。
    ip_hash : 每個(gè)請求按訪問 IP 的 hash 結(jié)果分配,這樣來自同一個(gè) IP 的訪客固定訪問一個(gè)后端服務(wù)器,有效解決了動(dòng)態(tài)網(wǎng)頁存在的 session 共享問題。當(dāng)然如果這個(gè)節(jié)點(diǎn)不可用了,會發(fā)到下個(gè)節(jié)點(diǎn),而此時(shí)沒有 session 同步的話就注銷掉了。
    least_conn :請求被發(fā)送到當(dāng)前活躍連接最少的 realserver 上。會考慮 weight 的值。
    url_hash : 此方法按訪問 url 的 hash 結(jié)果來分配請求,使每個(gè) url 定向到同一個(gè)后端服務(wù)
    器,可以進(jìn)一步提高后端緩存服務(wù)器的效率。Nginx 本身是不支持 url_hash 的,如果需要使用這種調(diào)度算法,必須安裝 Nginx 的 hash 軟件包 nginx_upstream_hash 。
    fair :這是比上面兩個(gè)更加智能的負(fù)載均衡算法。此種算法可以依據(jù)頁面大小和加載時(shí)間長短智能地進(jìn)行負(fù)載均衡,也就是根據(jù)后端服務(wù)器的響應(yīng)時(shí)間來分配請求,響應(yīng)時(shí)間短的優(yōu)先分配。Nginx 本身是不支持 fair 的,如果需要使用這種調(diào)度算法,必須下載 Nginx 的upstream_fair 模塊。

  • web
[root@localhost ~]# yum -y install httpd
[root@localhost ~]# echo aaaaaaaaaa > /var/www/html/index.html 
[root@localhost ~]# systemctl start httpd
  • 另一臺web
[root@localhost ~]# yum -y install httpd
[root@localhost ~]# echo bbbbbbbbbbb > /var/www/html/index.html 
[root@localhost ~]# systemctl start httpd
  • 測試效果如下
[root@localhost ~]# curl 127.0.0.1
aaaaaaaaaaaaaaa
[root@localhost ~]# curl 127.0.0.1
bbbbbbbbbbbb
[root@localhost ~]# curl 127.0.0.1
aaaaaaaaaaaaaaa
[root@localhost ~]# curl 127.0.0.1
bbbbbbbbbbbb
\\可以看到nginx服務(wù)器把請求分別給兩臺web
  • 可以編輯nginx啟動(dòng)腳本
[root@localhost ~]# vim /etc/init.d/nginx 
#!/bin/bash
#chkconfig: 2345 99 20
#description: Nginx Service Control Script
PROG="/usr/local/nginx1.10/sbin/nginx"
PIDF="/usr/local/nginx1.10/logs/nginx.pid"
case "$1" in
     start)
      netstat -anplt |grep ":80" &> /dev/null && pgrep "nginx" &> /dev/null
      if [ $? -eq 0 ]
      then
        echo "Nginx service already running."
      else
        $PROG -t &> /dev/null
        if [ $? -eq 0 ] ; then
         $PROG
         echo "Nginx service start success."
        else
         $PROG -t
        fi
      fi
     ;;
     stop)
      netstat -anplt |grep ":80" &> /dev/null && pgrep "nginx" &> /dev/null
      if [ $? -eq 0 ]
      then
         kill -s QUIT $(cat $PIDF)
         echo "Nginx service stop success."
       else
         echo "Nginx service already stop"
       fi
     ;;
     restart)
         $0 stop
         $0 start
     ;;
     status)
      netstat -anplt |grep ":80" &> /dev/null && pgrep "nginx" &> /dev/null
      if [ $? -eq 0 ]
      then
         echo "Nginx service is running."
      else
         echo "Nginx is stop."
      fi
     ;;
     reload)
      netstat -anplt |grep ":80" &> /dev/null && pgrep "nginx" &> /dev/null
      if [ $? -eq 0 ]
      then
         $PROG -t &> /dev/null
        if [ $? -eq 0 ] ; then
         kill -s HUP $(cat $PIDF)
         echo "reload Nginx config success."
        else
         $PROG -t
        fi
      else
         echo "Nginx service is not run."
      fi  
     ;; 
     *)
         echo "Usage: $0 {start|stop|restart|reload}"
         exit 1
     esac
[root@localhost ~]#  chmod +x /etc/init.d/nginx 
[root@localhost ~]# chkconfig --add nginx
[root@localhost ~]# service nginx start
Nginx service start success.
[root@localhost ~]# service nginx status
Nginx service is running.

二.nginx緩存使用

Nginx基于Proxy Store實(shí)現(xiàn),使用Nginx的http_proxy模塊可以實(shí)現(xiàn)類似于squid的緩存功能。當(dāng)啟用緩存時(shí),Nginx會將相應(yīng)數(shù)據(jù)保存在磁盤緩存中,只要緩存數(shù)據(jù)尚未過期,就會使用緩存數(shù)據(jù)來響應(yīng)客戶端的請求。

nginx的web緩存功能只要就是由proxy_cache、fastcgi_cache指令集和相關(guān)指令集完成:

proxy_cache:負(fù)責(zé)反向代理緩存后端服務(wù)器的靜態(tài)內(nèi)容;
fastcgi_cache:主要用來處理fastcgi動(dòng)態(tài)進(jìn)程緩存;

  • 在nginx主配置文件中添加如下
[root@localhost ~]# vim /usr/local/nginx/conf/nginx.conf
…………   //省略部分內(nèi)容
log_format  main  '$remote_addr - $remote_user [$time_local] "$request" '
            '$status $body_bytes_sent "$http_referer" '
            '"$http_user_agent" "$http_x_forwarded_for"'
            '"$upstream_cache_status"';       //記錄緩沖命中率,注意這是一個(gè)整段,所以只在末尾有一個(gè)分號
//以上內(nèi)容原本已經(jīng)存在,只需添加最后一行即可!
   access_log  logs/access.log  main;
   proxy_buffering on;     //代理時(shí),開啟緩沖后端服務(wù)器的響應(yīng)
   proxy_temp_path /usr/local/nginx/proxy_temp;     //定義緩存臨時(shí)目錄
   proxy_cache_path /usr/local/nginx/proxy_cache levels=1:2 keys_zone=my-cache:100m inactive=600m max_size=2g;
//定義緩存目錄,具體信息已在配置文件外部進(jìn)行說明
…………   //省略部分內(nèi)容
     location ~/purge(/.*) {         //定義緩存清除策略
         allow 127.0.0.1;
         allow 192.168.222.0/24;
         deny all;
         proxy_cache_purge my-cache $host$1$is_args$args;
     }

     location / {
         proxy_pass http://lzj;       //請求轉(zhuǎn)向lzj定義的服務(wù)器列表
         proxy_redirect off;       指定是否修改被代理服務(wù)器返回的響應(yīng)頭中的 location 頭域跟 refresh 頭域數(shù)值
#例如:
 設(shè)置后端服務(wù)器“Location”響應(yīng)頭和“Refresh”響應(yīng)頭的替換文本。 假設(shè)后端服務(wù)器返回的
 響應(yīng)頭是 “Location: http://localhost:8000/two/some/uri/”,那么指令proxy_redirect  
# http://localhost:8000/two/ http://frontend/one/;將把字符串改寫為 “Location: 
# http://frontend/one/some/uri/”。                
         proxy_set_header Host $host;   //允許重新定義或者添加發(fā)往后端服務(wù)器的請求頭
#Host 的含義是表明請求的主機(jī)名,nginx 反向代理服務(wù)器會向后端真實(shí)服務(wù)器發(fā)送請求,
#并且請求頭中的host字段重寫為proxy_pass指令設(shè)置的服務(wù)器。因?yàn)閚ginx作為反向代理使
#用,而如果后端真實(shí)的服務(wù)器設(shè)置有類似防盜鏈或者根據(jù) http 請求頭中的 host 字段來進(jìn)行
#路由或判斷功能的話,如果反向代理層的nginx不重寫請求頭中的host字段,將會導(dǎo)致請求失敗。                 
         proxy_set_header X-Real-IP $remote_addr;
                 //web 服務(wù)器端獲得用戶的真實(shí) ip 但是,實(shí)際上要獲得用戶的真實(shí) ip,也可以通過下面的X-Forward-For

         proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
                 #后端的 Web服務(wù)器可以通過 X-Forwarded-For 獲取用戶真實(shí) IP,X_Forward_For 字段
#表示該條 http 請求是有誰發(fā)起的?如果反向代理服務(wù)器不重寫該請求頭的話,那么后端
#真實(shí)服務(wù)器在處理時(shí)會認(rèn)為所有的請求都來自反向代理服務(wù)器,如果后端有防護(hù)策略
#的話,那么機(jī)器就被封掉了。因此,在配置用作反向代理的 nginx 中一般會增加兩條配置,以便修改 http 的請求頭部
         proxy_next_upstream error timeout invalid_header http_500 http_502 http_503 http_504;
                 #增加故障轉(zhuǎn)移,如果后端的服務(wù)器返回 502、504、執(zhí)行超時(shí)等錯(cuò)誤,
#自動(dòng)將請求轉(zhuǎn)發(fā)到upstream 負(fù)載均衡池中的另一臺服務(wù)器,實(shí)現(xiàn)故障轉(zhuǎn)移。
         proxy_cache my-cache;
         add_header Nginx-Cache $upstream_cache_status;
         proxy_cache_valid 200 304 301 302 8h;
         proxy_cache_valid 404 1m;
         proxy_cache_valid any 1d;
         proxy_cache_key $host$uri$is_args$args;
         expires 30d;
     }
[root@localhost ~]# nginx -t
nginx: the configuration file /usr/local/nginx/conf/nginx.conf syntax is ok
nginx: configuration file /usr/local/nginx/conf/nginx.conf test is successful
//檢測配置文件沒有問題
[root@localhost ~]# nginx -s reload       //重新加載nginx配置文件
  • 訪問如下:

Nginx中反向代理和緩存的使用方法

刷新一下顯示如:

Nginx中反向代理和緩存的使用方法

  • 清除緩存

Nginx中反向代理和緩存的使用方法

  • 再重新訪問192.168.222.128時(shí),如下:可以看到已經(jīng)清楚緩存了

Nginx中反向代理和緩存的使用方法

另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)cdcxhl.cn,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時(shí)售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務(wù)可用性高、性價(jià)比高”等特點(diǎn)與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場景需求。


當(dāng)前題目:Nginx中反向代理和緩存的使用方法-創(chuàng)新互聯(lián)
轉(zhuǎn)載源于:http://weahome.cn/article/ddjsoi.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部