Haproxy 安裝配置詳解-端口映射


Haproxy

簡介:

HAProxy提供高可用性、負載均衡以及基於TCP和HTTP應用的代理,支持虛擬主機,它是免費、快速並且可靠的一種解決方案。

HAProxy特別適用於那些負載特大的web站點,這些站點通常又需要會話保持或七層處理。

HAProxy運行在當前的硬件上,完全可以支持數以萬計的並發連接。並且它的運行模式使得它可以很簡單安全的整合進您當前的架構中, 同時可以保護你的web服務器不被暴露到網絡上。

HAProxy實現了一種事件驅動, 單一進程模型,此模型支持非常大的並發連接數。多進程或多線程模型受內存限制 、系統調度器限制以及無處不在的鎖限制,很少能處理數千並發連接。事件驅動模型因為在有更好的資源和時間管理的用戶空間(User-Space) 實現所有這

些任務,所以沒有這些問題。此模型的弊端是,在多核系統上,這些程序通常擴展性較差。這就是為什么他們必須進行優化以 使每個CPU時間片(Cycle)做更多的工作。

 

安裝:

#下載
wget http://fossies.org/linux/misc/haproxy-1.6.9.tar.gz
#解壓
tar -zxvf haproxy-1.6.9.tar.gz
cd haproxy-1.6.9
#安裝
make TARGET=linux2628 ARCH=x86_64 PREFIX=/usr/local/haproxy
make install PREFIX=/usr/local/haproxy

#參數說明
TARGET=linux26   #內核版本,使用uname -r查看內核,如:2.6.18-371.el5,此時該參數就為linux26;kernel 大於2.6.28的用:TARGET=linux2628
ARCH=x86_64      #系統位數
PREFIX=/usr/local/haprpxy  #/usr/local/haprpxy為haprpxy安裝路徑

 

配置:

【/usr/local/haproxy/haproxy.conf】

global
        daemon
        log 127.0.0.1 local3 info
        maxconn 1000
        ulimit-n 4000
        uid     1001                               #普通用戶的uid和gid
        gid     1001
        quiet
        quiet
        nbproc  1
        pidfile /home/work/env/haproxy/haproxy.pid  #普通用戶路徑權限
defaults
        mode tcp                                    #協議
        timeout connect 5000ms
        timeout client 50000ms
        timeout server 50000ms
frontend http-in-unstable                           #名字
        bind 43.243.130.89:1115                     #本地端口 ,注本地端口防火牆也要放開
        default_backend httpunstable
backend httpunstable
        server proxy00 192.168.122.173:1115 check inter 2000 fall 3 weight 30 maxconn 1000
                                                    #外部端口(虛擬機)端口
frontend http-in-unstable_1443
        bind 43.243.130.89:1443
        default_backend httpunstable_1443
backend httpunstable_1443
        server proxy00 192.168.122.173:1443 check inter 2000 fall 3 weight 30 maxconn 1000

 啟動腳本:

/home/work/env/haproxy/check_haproxy.sh  #注意路徑權限

#!/bin/sh
dir=`dirname $(realpath $0)`
selfname=`basename $0`
cd $dir
PID=`ps aux | grep '/usr/local/haproxy/sbin/haproxy' | grep -v grep | grep -v "$selfname" |  awk '{ print $2 }'`
if [ -z "$PID" ]; then
    /usr/local/haproxy/sbin/haproxy -f /usr/local/haproxy/conf/haproxy.conf
fi

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM