1,簡介四層負載均衡 七層負載均衡linux
四層負載均衡,在網絡模型中的傳輸層中,基於主要是基於tcp協議報文實現負載均衡(好比LVS、haproxy就是四層負載均衡器),使用改寫報文的源地址和目的地址。nginx
nginx 1.9 以後也能夠經過配置實現四層負載均衡。四層負載均衡支持全部的負載均衡功能好比數據庫,web 服務器等。c++
七層負載均衡,在網絡模型中應用層中,基於URL或者HTTP協議實現負載均衡,Web服務器。nginx 是七層負載均衡器。git
2,基於nginx 1.9 搭建四層負載均衡github
1,安裝一些包web
1.安裝gcc gcc-c++(如新環境,未安裝請先安裝)
$ yum install -y gcc gcc-c++
2.安裝wget
$ yum -y install wget
2.安裝PCRE庫
$ cd /usr/local/
$ wget http://jaist.dl.sourceforge.net/project/pcre/pcre/8.33/pcre-8.33.tar.gz
$ tar -zxvf pcre-8.33.tar.gz
$ cd pcre-8.33
$ ./configure
$ make && make install
若是報錯:
在 linux 中執行 wget 命令提示 -bash: wget: command not found 解決方法
解決辦法 yum -y install wget
3.安裝SSL庫
$ cd /usr/local/
$ wget http://www.openssl.org/source/openssl-1.0.1j.tar.gz
$ tar -zxvf openssl-1.0.1j.tar.gz
$ cd openssl-1.0.1j
$ ./config
$ make && make install
4.安裝zlib庫存
$ cd /usr/local/
$ wget http://zlib.net/zlib-1.2.11.tar.gz
$ tar -zxvf zlib-1.2.11.tar.gz
$ cd zlib-1.2.11
$ ./configure
$ make && make install
5.安裝patch
yum -y install patch 安裝便可數據庫
2,安裝Nginxbash
wget http://nginx.org/download/nginx-1.9.10.tar.gz
安裝nginx_tcp_proxy_module 插件
服務器
wget https://github.com/yaoweibin/nginx_tcp_proxy_module/tarball/master
解壓網絡
tar -zxvf master,解壓以後能夠看到一個yaoweibin-nginx_tcp_proxy_module-b8a3028
tar -zxvf nginx-1.9.10.tar.gz
cd nginx-1.9.10,下載tcp.patch最新補丁
patch -p1 < ../yaoweibin-nginx_tcp_proxy_module-b8a3028/tcp.patch
若是報錯
-bash: patch: 未找到命令 執行 yum -y install patch 安裝便可。
編譯Nginx
./configure --add-module=../yaoweibin-nginx_tcp_proxy_module-b8a3028
make && make install
若是報錯
In file included from ../nginx_tcp_proxy_module-master/ngx_tcp.h:32,
from ../nginx_tcp_proxy_module-master/ngx_tcp.c:5:
../nginx_tcp_proxy_module-master/ngx_tcp_upstream.h:144: error: expected specifier-qualifier-list before 'ngx_resolver_addr_t'
make[1]: *** [objs/addon/nginx_tcp_proxy_module-master/ngx_tcp.o] Error 1
make[1]: Leaving directory `/opt/apps_install/nginx-1.9.9'
make: *** [build] Error 2
cd /usr/local/yaoweibin-nginx_tcp_proxy_module-b8a3028 找到ngx_tcp_upstream.h
修改第三方模塊包裏的頭文件,ngx_tcp_upstream.h 144 行將ngx_resolver_addr_t 改成 ngx_addr_t
3,配置nginx.conf,而且啓動
tcp {
### 定義多個上游服務器
upstream aiyuesheng{
### 定義TCP模塊上游服務器
server 192.168.178.1:8001;
server 192.168.178.1:8002;
}
server {
listen 9999;
server_name 192.168.178.110;
### 反向代理upstream
proxy_pass aiyuesheng;
}
}
4,在tcp 測試工具裏面添加客戶端 和 服務器
服務器是本地的物理機ip 地址,兩個服務
客戶端是虛擬機配置者四層負載均衡的linux 服務
客戶端主動鏈接以後,由於nginx 輪詢機制,會鏈接其中一臺服務器,斷開鏈接以後,再次鏈接,會鏈接另外一臺。
由於是TCP 四層負載均衡使用的是長鏈接,只要客戶端和服務器保持鏈接,就不會輪詢到下一臺機器。
這樣,四層負載均衡就配置OK 了