506629361 发表于 2015-9-5 01:53:19

haproxy做tcp 层的负载均衡

  首先下载haproxy包:
  wget http://haproxy.1wt.eu/download/1.4/src/haproxy-1.4.13.tar.gz
  安装:
  tar zxvf haproxy-1.4.13.tar.gz
  make TARGET=linux26 PREFIX=/usr/local/haproxy  ##我的系统内核为2.6,所以target=linux26
  make install PREFIX=/usr/local/haproxy
  然后进行配置:
  vi /etc/haproxy/haproxy.cfg
  ##写入以下内容:



###########全局配置#########
global
      daemon
      nbproc 1
      pidfile /var/run/haproxy.pid

########默认配置############
defaults
      mode http               #默认的模式mode { tcp|http|health },tcp是4层,http是7层,health只会返回OK
      retries 2               #两次连接失败就认为是服务器不可用,也可以通过后面设置
      option redispatch       #当serverId对应的服务器挂掉后,强制定向到其他健康的服务器
      option abortonclose   #当服务器负载很高的时候,自动结束掉当前队列处理比较久的链接
      maxconn 4096            #默认的最大连接数
      timeout connect 5000ms#连接超时
      timeout client 30000ms#客户端超时
      timeout server 30000ms#服务器超时
      #timeout check 2000      #=心跳检测超时
      log 127.0.0.1 local0 err #

########统计页面配置########
listen admin_stats
      bind 0.0.0.0:1080               #监听端口
      mode http                     #http的7层模式
      option httplog                  #采用http日志格式
      #log 127.0.0.1 local0 err
      maxconn 10
      stats refresh 30s               #统计页面自动刷新时间
      stats uri /stats                #统计页面url
      stats realm XingCloud\ Haproxy#统计页面密码框上提示文本
      stats auth admin:admin          #统计页面用户名和密码设置
      stats hide-version            #隐藏统计页面上HAProxy的版本信息

########test1配置#################
listen test1
      bind 0.0.0.0:90
      mode tcp
      #maxconn 4086
      #log 127.0.0.1 local0 debug
      server s1 10.18.138.201:80
      server s2 10.18.102.190:80
      server s3 10.18.102.189:80
      server s4 10.18.102.188:80
      server s5 10.18.102.187:80
########frontend配置##############

########test2配置#################
listen test2
      bind 0.0.0.0:91
      mode tcp
      #maxconn 4086
      #log 127.0.0.1 local0 debug
      server s1 10.18.138.130:80      weight 1
      server s2 10.18.138.201:8080    weight 6
########frontend配置##############
  
ok. 启动haproxy.
  haproxy /etc/haproxy/haproxy.cfg
  马上试试, 发现负载已经成功了。
  但是有一个问题, 不能看到log.   是因为我没有启动syslog.
  在ubuntu下, 需要启动的是rsyslogd.
  我的机器上没有安装,先安装rsyslogd.
  apt-get install rsyslog
  
安装完成之后,配置rsyslog
  vi /etc/rsyslog.d/haproxy.conf
  加入以下内容:
  $ModLoad imudp
$UDPServerRun 514
local0.* /var/log/haproxy.log
  保存, 重启rsyslogd.
  restart rsyslogd
  ok.现在你就可以看到日志了。
  
试试看。
  tail -f /var/log/haproxy.log
  最后,再加一个平滑重启的命令:
  haproxy -f /etc/haproxy/haproxy.cfg -sf `cat /var/run/haproxy.pid`
页: [1]
查看完整版本: haproxy做tcp 层的负载均衡