通過Haproxy的ACL規(guī)劃實現(xiàn)智能負載均衡,并簡述tcp、http、health的配置示例

實驗環(huán)境

后端主機1

  • 設置seLinux、取消防火墻和同步時間
yum install -y ntpdate
ntpdate time1.aliyun.com
[root@node-73 ~]# yum -y install httpd
[root@node-73 ~]# mkdir /data/web/vhost{1,2} -pv
mkdir: 已創(chuàng)建目錄 "/data/web"
mkdir: 已創(chuàng)建目錄 "/data/web/vhost1"
mkdir: 已創(chuàng)建目錄 "/data/web/vhost2"
[root@node-73 ~]# find /usr/share -iname "*.jpg" -exec cp {} /data/web/vhost1/ \;
[root@node-73 ~]# find /usr/share -iname "*.jpg" -exec cp {} /data/web/vhost2/ \;

[root@node-73 ~]# vim /data/web/vhost1/test.txt
ImageServer 1
[root@node-73 ~]# vim /data/web/vhost2/test.txt
ImageServer 2
[root@node-73 ~]# vim /etc/httpd/conf.d/vhost1.conf
[root@node-73 ~]# vim /etc/httpd/conf.d/vhost2.conf
[root@node-73 ~]# systemctl start httpd
[root@node-73 ~]# ss -tnl                
LISTEN      0      128    :::8080               :::*                  
LISTEN      0      128    :::80                 :::*   

后端主機2:

  • 設置seLinux、取消防火墻和同步時間
yum install -y ntpdate
ntpdate time1.aliyun.com
[root@node-74 ~]# yum -y install httpd
[root@node-74 ~]# mkdir /data/web/vhost{1,2} -pv
mkdir: 已創(chuàng)建目錄 "/data/web"
mkdir: 已創(chuàng)建目錄 "/data/web/vhost1"
mkdir: 已創(chuàng)建目錄 "/data/web/vhost2"
[root@node-74 ~]# vim /data/web/vhost1/info.php

<h1>Application Server1</h1>
 <?php
        phpinfo();
   ?>   
[root@node-74 ~]# cp  /data/web/vhost{1,2}/info.php #復制文件到vhsot2
[root@node-74 ~]# vim /data/web/vhost2/info.php

<h1>Application Server2</h1>  #修改
 <?php
        phpinfo();
   ?> 
[root@node-74 ~]# vim /etc/httpd/conf.d/vhost1.conf #配置虛擬主機1

<VirtualHost *:80>
         ServerName www1.hehe.com
         DocumentRoot "/data/web/vhost1"
         <Directory "/data/web/vhost1">
               Options FollowSymLinks
               AllowOverride None
               Require all granted
         </Directory>
</VirtualHost>
[root@node-74 ~]# cp /etc/httpd/conf.d/vhost{1,2}.conf #拷貝配置
[root@node-74 ~]# vim /etc/httpd/conf.d/vhost2.conf #編輯虛擬主機2

listen 8080
<VirtualHost *:8080>
         ServerName www1.hehe.com
         DocumentRoot "/data/web/vhost2"
         <Directory "/data/web/vhost2">
               Options FollowSymLinks
               AllowOverride None
               Require all granted
         </Directory>
</VirtualHost>
[root@node-74 ~]# scp /etc/httpd/conf.d/vhost*.conf 192.168.1.73:/etc/httpd/conf.d/   #把配置拷貝到node1主機上

[root@node-74 ~]# systemctl start httpd.service #啟動httpd
[root@node-74 ~]# ss -tnl                 
LISTEN      0      128    :::8080               :::*                  
LISTEN      0      128    :::80                 :::*      

haproxy主機

  • 設置seLinux、取消防火墻和同步時間
yum install -y ntpdate
ntpdate time1.aliyun.com
  • 創(chuàng)建CA自簽證
[root@haproxy-75 ~]# cd /etc/pki/CA/
[root@haproxy-75 CA]# (umask 077; openssl genrsa -out private/cakey.pem 4096)
[root@haproxy-75 CA]# openssl req -new -x509 -key private/cakey.pem -out cacert.pem -days 365
[root@haproxy-75 CA]# touch index.txt
[root@haproxy-75 CA]# echo 01 > serial

[root@haproxy-75 CA]# cd /etc/haproxy/
[root@haproxy-75 haproxy]# mkdir certs
[root@haproxy-75 haproxy]# cd certs

[root@haproxy-75 certs]# openssl genrsa -out haproxy.key 2048
[root@haproxy-75 certs]# openssl req -new -key haproxy.key -out haproxy.csr
[root@haproxy-75 certs]# ls
haproxy.csr  haproxy.key

[root@haproxy-75 certs]# openssl ca -in haproxy.csr -out haproxy.crt
[root@haproxy-75 certs]# cat haproxy.crt haproxy.key > haproxy.pem
[root@haproxy-75 certs]# ls
haproxy.crt  haproxy.csr  haproxy.key  haproxy.pem
[root@haproxy-75 certs]# chmod 600 haproxy.pem

[root@haproxy-75 ~]# vim /etc/haproxy/haproxy.cfg
frontend web *:80
   compression algo gzip
   compression type text/html text/plain /application/xml application/javascript
   acl static path_end .jpg .jpeg.png .gif .txt .html .css .javascript .
js  #定義靜態(tài)acl匹配規(guī)則,后綴匹配
   acl static path_beg /imgs /css /javascripts #定義靜態(tài)acl匹配規(guī)則,前綴匹配
   acl bad_browsers hdr_reg(User-Agent) .*curl.* #定義名為bad_browsers的acl規(guī)則,url中后綴匹配字符中有curl
   block if bad_browsers #調(diào)用bad_browsers規(guī)則 ,符合就阻塞
   acl valid_referers hdr_reg(Referer) \.hehe1\.com #定義一個名為valid_referers的acl,正則表達式匹配
   block unless valid_referers #調(diào)用acl,如果匹配則放行
   use_backend staticsrvs if static  #使用靜態(tài)acl匹配規(guī)則
   default_backend dynsrvs #未匹配到acl的,使用默認后端主機,動態(tài)內(nèi)容

frontend https
   bind *:443 ssl crt /etc/haproxy/certs/haproxy.pem #使用認證并指明pem認證文件路徑
   acl static path_end .jpg .jpeg.png .gif .txt .html .css .javascript .js #定義后綴匹配規(guī)則
   acl static path_beg /imgs /css /javascripts
   use_backend staticsrvs if static
   default_backend dynsrvs

frontend http
    bind *.8080
    redirect scheme https if !{ ssl_fc } #把8080端口的請求重向定443

backend dynsrvs   #動態(tài)主機組
   cookie SRV insert indirect nocache #啟用cookie綁定
   balance roundrobin
   server dynsrv1 192.168.1.74:80 check cookie dynsrv1
   server dynsrv2 192.168.1.74:8080 check cookie dynsrv2

backend staticsrvs  #靜態(tài)主機組
   balance roundrobin
   server staticsrv1 192.168.1.73:80 check               
   server staticsrv2 192.168.1.73:8080 check 


listen stats
   bind *:9099
   stats enable
   stats uri /myproxy?admin #自定義信息頁地址
   stats realm "HAProxy Stats Page" #認證提示
   stats auth admin:admin #認證時用的用戶名和密碼
   stats admin if TRUE  #啟用信息頁管理功能,總是為真
[root@haproxy-75 ~]# systemctl restart haproxy
[root@haproxy-75 ~]# ss -tnl
LISTEN     0      128                                                                           *:9099                                                                                      *:*                  
LISTEN     0      128                                                                           *:8080                                                                                      *:*                  
LISTEN     0      128                                                                           *:80                                                                                        *:*                         
LISTEN     0      128                                                                           *:443                                                                                       *:*  

訪問測試


haproxy管理頁

cookie綁定

image.png

圖片訪問

https訪問
?著作權歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務。

相關閱讀更多精彩內(nèi)容

  • 參考文檔: 1.haproxy:http://www.haproxy.org/ 本文涉及haproxy的安裝,并做...
    Netonline閱讀 2,487評論 1 51
  • 在大型系統(tǒng)設計中用代理在負載均衡是最常見的一種方式,而相對靠譜的解決方案中Nginx、HAProxy、LVS、F5...
    歡醉閱讀 4,774評論 1 5
  • 本文描述的是haproxy做代理,負載均衡,haproxy狀態(tài)查看,后端主機的上下線,keepalived高可用 ...
    think_lonely閱讀 5,899評論 0 7
  • 后來你們就會明白,人的生活有兩個部分,一是向外,一是向內(nèi)。 向外的生活,顧名思義就是去拓寬,多交朋友,多赴場合,多...
    生山雅士閱讀 211評論 0 0
  • 她又生氣了,她生氣的時候我系心里面一直怨恨著自己,怎么又不爭氣的讓她不高興了。雖然心里面也會對她有所抱怨,女孩子怎...
    SZhua閱讀 140評論 0 0

友情鏈接更多精彩內(nèi)容