四層負載均衡,七層負載均衡

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 了

相關文章
相關標籤/搜索