一、要解決的問題 (1)後臺web server要考慮擴容和負載均衡; (2)要保護後臺webserver ,避免webserver 因爲負載太高,形成系統不可用 二、試驗環境php
haproxy:HA-Proxy version 1.6.0 2015/10/13 apache2 : Server version: Apache/2.4.7 (Ubuntu) Server built: Jan 14 2016 17:45:23 目的:全部訪問 192.168.1.2:80 的web 請求,會經過 haproxy 均衡的分配給爲 192.168.1.2:8001 192.168.101.2:8002 ,這是兩個監聽不一樣端口的apache 服務器; 三、解決思路 讓全部 訪問haproxy的請求都轉發給,8001 和 8002 ,haprxy 要對這些請求進行調度,由8001 和8002 進行實際的處理php 文件 四、配置文件 haproxy :配置文件路徑:/etc/haproxy/haproxy.cfg ``` global log 127.0.0.1 local0 #maxconn 20000
#uid 535 #uid和gid按照實際狀況進行配置 #gid 520
#chroot /var/chroot/haproxy daemon nbproc 1html
defaults log global mode http
option httplog #option httpclose option dontlognull #option forwardfor option redispatch retries 3 balance roundrobin maxconn 1000 stats uri /haproxy-stats timeout connect 5000 timeout client 50000 timeout server 50000node
#frontend http-inlinux
#backend pool1git
listen webfarm 192.168.101.129:80 mode http stats enable stats uri /haproxy?stats stats realm Haproxy\ Statistics stats auth haproxy:stats balance roundrobin cookie LBN insert indirect nocache option httpclose option forwardfor server web01 192.168.101.129:8001 cookie node1 check server web02 192.168.101.129:8002 cookie node2 checkgithub
haproxy 操做命令:service haproxy start/stop/restart apache 配置: /etc/apache2/ports.conf 增長監聽8001 和 8002 註釋掉監聽80,由於haproxy 要監聽80 ``` #Listen 80 Listen 8001 Listen 8002 <IfModule ssl_module> Listen 443 </IfModule> <IfModule mod_gnutls.c> Listen 443 </IfModule>
/etc/apache2/sites-available/8001.conf 主要是端口和web目錄,web目錄下只有一個php 文件
<VirtualHost *:8001> # The ServerName directive sets the request scheme, hostname and port that # the server uses to identify itself. This is used when creating # redirection URLs. In the context of virtual hosts, the ServerName # specifies what hostname must appear in the request's Host: header to # match this virtual host. For the default virtual host (this file) this # value is not decisive as it is used as a last resort host regardless. # However, you must set it for any further virtual host explicitly. #ServerName www.example.com ServerAdmin webmaster@localhost DocumentRoot /var/www/html/8001/ # Available loglevels: trace8, ..., trace1, debug, info, notice, warn, # error, crit, alert, emerg. # It is also possible to configure the loglevel for particular # modules, e.g. #LogLevel info ssl:warn ErrorLog ${APACHE_LOG_DIR}/error.log CustomLog ${APACHE_LOG_DIR}/8001_access.log combined # For most configuration files from conf-available/, which are # enabled or disabled at a global level, it is possible to # include a line for only one particular virtual host. For example the # following line enables the CGI configuration for this host only # after it has been globally disabled with "a2disconf". #Include conf-available/serve-cgi-bin.conf </VirtualHost>
/etc/apache2/sites-available/8002.conf 與8001 相似,除了端口和web目錄不一樣web
啓動8001 和8002 :sudo a2ensite 8801 ;sudo a2ensite 8002 重啓apache :sudo service apache2 restartredis
驗證步驟: (1)從另一臺機器使用 ab -c 10 -n 1000 http://192.168.1.2/,待測試結束後,查看access_log,能夠看到相應的增長 (2)調整haproxy.conf 中的maxconn 與ab -c 10 併發數,能夠看到這個maxconn 會起到限流做用 好比:maxconn 設置爲3 則 ab -c 10 須要花費較長時間完成 若maxconn 爲20 ,則 ab -c 10 則較快便可完成 五、主要參考資料 https://linux.cn/article-4765-1.html#2_3510 https://cbonte.github.io/haproxy-dconv/configuration-1.5.htmlapache