CentOS基于nginx反向代理實現(xiàn)負(fù)載均衡的方法
本文實例講述了CentOS基于nginx反向代理實現(xiàn)負(fù)載均衡的方法。分享給大家供大家參考,具體如下:
nginx做負(fù)載均衡的優(yōu)點:
1、工作在網(wǎng)絡(luò)的7層之上,可以針對http應(yīng)用做一些分流的策略,比如針對域名、目錄結(jié)構(gòu),它的正則規(guī)則比HAProxy更為強大和靈活,這也是它目前廣泛流行的主要原因之一,nginx單憑這點可利用的場合就遠(yuǎn)多于LVS了
2、nginx對網(wǎng)絡(luò)穩(wěn)定性的依賴非常小,理論上能ping通就就能進(jìn)行負(fù)載功能,這個也是它的優(yōu)勢之一;相反LVS對網(wǎng)絡(luò)穩(wěn)定性依賴比較大,這點本人深有體會
3、nginx安裝和配置比較簡單,測試起來比較方便,它基本能把錯誤用日志打印出來。LVS的配置、測試就要花比較長的時間了,LVS對網(wǎng)絡(luò)依賴比較大
4、可以承擔(dān)高負(fù)載壓力且穩(wěn)定,在硬件不差的情況下一般能支撐幾萬次的并發(fā)量,負(fù)載度比LVS相對小些
注意事項:
1、不同安裝方法nginx的配置文件位置不一樣
2、upstream如果使用ip_hash方式,則每個請求按訪問ip的hash結(jié)果分配,這樣每個訪客固定訪問一個后端服務(wù)器,可以解決session的問題
環(huán)境:
系統(tǒng):centos6.6
nginx ip:192.168.20.103
web1 ip:192.168.20.193
web2 ip:192.168.20.194
一、安裝nginx
兩種方法,我用的是第1種
第1種 yum安裝,需安裝第三方y(tǒng)um源,因為nginx默認(rèn)不在centos的yum源中 所以需更新
yum install wget #安裝下載工具 wget http://www.atomicorp.com/installers/atomic #下載 sh ./atomic #安裝 yum check-update #更新yum源 有的需要更新幾次 才有nginx最新版本 否則是老版本nginx yum remove httpd* php* #刪除系統(tǒng)自帶的軟件包 也可加mysql*前提備份數(shù)據(jù)庫 yum install nginx #安裝nginx根據(jù)提示輸入y進(jìn)行安裝 chkconfig nginx on #設(shè)置nginx開機啟動 service nginx start #啟動nginx 重啟 restart
第2種 編譯安裝
wget http://nginx.org/download/nginx-1.7.8.tar.gz tar -zxvf nginx-1.7.8.tar.gz cd nginx-1.7.8 ./configure make && make install
二、修改配置文件
nginx 的 upstream默認(rèn)是以輪詢的方式實現(xiàn)負(fù)載均衡,這種方式中,每個請求按時間順序逐一分配到不同的后端服務(wù)器,如果后端服務(wù)器down掉,能自動剔除。
另外一種方式是ip_hash:每個請求按訪問ip的hash結(jié)果分配,這樣每個訪客固定訪問一個后端服務(wù)器,可以解決session的問題
修改 /etc/nginx/nginx.conf 增加
#負(fù)載均衡配置 upstream backend { #ip_hash; server 192.168.20.193; server 192.168.20.194; }
修改 /etc/nginx/conf.d/default.conf
location / { #設(shè)置主機頭和客戶端真實地址,以便服務(wù)器獲取客戶端真實IP proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; #禁用緩存 proxy_buffering off; #反向代理的地址 proxy_pass http://backend; root /usr/share/nginx/html; index index.html index.htm; # example #ModSecurityEnabled on; #ModSecurityConfig /etc/nginx/modsecurity.conf; }
三、測試
第一次訪問轉(zhuǎn)發(fā)到193,因為 upstream默認(rèn)是輪詢,第二次則轉(zhuǎn)發(fā)到了194
希望本文所述對大家CentOS服務(wù)器維護(hù)有所幫助。
相關(guān)文章
linux系統(tǒng)之間通過nfs網(wǎng)絡(luò)文件系統(tǒng)掛載設(shè)置方法
NFS允許一個系統(tǒng)在網(wǎng)絡(luò)上與他人共享目錄和文件,通過使用NFS,用戶和程序可以像訪問本地文件一樣訪問遠(yuǎn)端系統(tǒng)上的文件,下面介紹linux系統(tǒng)之間通過nfs網(wǎng)絡(luò)文件系統(tǒng)掛載的設(shè)置方法2014-01-01在 RHEL8 /CentOS8 上建立多節(jié)點 Elastic stack 集群的方法
Elastic stack 俗稱 ELK stack,是一組包括 Elasticsearch、Logstash 和 Kibana 在內(nèi)的開源產(chǎn)品。Elastic Stack 由 Elastic 公司開發(fā)和維護(hù)。這篇文章主要介紹了如何在 RHEL8 /CentOS8 上建立多節(jié)點 Elastic stack 集群,需要的朋友可以參考下2019-09-09Linux本機與服務(wù)器文件互傳及Linux服務(wù)器文件上傳下載命令寫法
這篇文章主要介紹了Linux本機與服務(wù)器文件互傳及Linux服務(wù)器文件上傳下載命令寫法,需要的朋友可以參考下2017-08-08詳解負(fù)載均衡實現(xiàn)一個域名對應(yīng)多個IP地址
這篇文章主要介紹了詳解負(fù)載均衡實現(xiàn)一個域名對應(yīng)多個IP地址的相關(guān)資料,需要的朋友可以參考下2017-05-05linux下通過Squid反向代理搭建CDN緩存服務(wù)器的配置方法
在移動機房放置一臺CDN代理服務(wù)器,通過智能DNS解析,讓電信用戶直接訪問Web服務(wù)器、讓移動用戶訪問CDN代理服務(wù)器,解決移動用戶訪問Web服務(wù)器慢的問題2013-06-06CentOS 7下修改默認(rèn)網(wǎng)卡名為eth0的兩種方法
今天又從Centos 6.5裝回了Centos 7,畢竟還是要順應(yīng)潮流嘛。安裝完成之后,發(fā)現(xiàn)發(fā)現(xiàn)CentOS 7默認(rèn)的網(wǎng)卡名稱是eno16777736,所以想著改回eth0,下面這篇文章主要介紹了CentOS 7下修改默認(rèn)網(wǎng)卡名為eth0的兩種方法,需要的朋友可以參考借鑒。2017-02-02