设为首页 收藏本站
查看: 1544|回复: 0

[经验分享] 企业级高可用Web架构之HAProxy+Keepalived

[复制链接]

尚未签到

发表于 2017-4-18 07:56:56 | 显示全部楼层 |阅读模式
  细数下来,算是东莞的项目的话,HAProxy+Keepalived我差不多也有三套在线上跑了,另外,这套Web方案也是我的一拍网的备份方案之一,目前也在测试,如果速度和稳定性够强劲的话,我也考虑将LVS+Keepalived换成HAProxy+Keepalived,关于HAProxy的语法和安装步骤请参考我的专题系列文章http://network.iyunv.com/art/201101/241997.htm,另外,此篇文章跟刘天斯的不一样,我主要用其作为Web级别的负载均衡(七层应用)。
  一、线上跑的HAProxy配置文件,代码如下:
  global
  log 127.0.0.1   local0
  maxconn 65535
  chroot /usr/local/haproxy
  uid 99
  gid 99
  daemon
  nbproc 8
  pidfile /usr/local/haproxy/haproxy.pid
  debug
  defaults
  log     127.0.0.1       local3
  mode   http
  option httplog
  option httpclose
  option dontlognull
  option forwardfor
  option redispatch
  retries 2
  maxconn 2000
  balance source
  stats   uri     /web-status
  contimeout      5000
  clitimeout      50000
  srvtimeout      50000
  listen  www.1paituan.com
  bind *:80
  mode http
  option httplog
  log global
  option httpchk HEAD /index.jsp HTTP/1.0
  server web1  203.93.236.147:80 weight 5  check inter 2000 rise 2 fall 3
  server web2  203.93.236.146:80 weight 3  check inter 2000 rise 2 fall 3
  二、HAProxy的启动、关闭和重启脚本,代码如下:
  #!/bin/sh
  # chkconfig 35 on
  # description: HAProxy is a TCP/HTTP reverse proxy which is particularly suited for high availability environments.
  # Source function library.
  if [ -f /etc/init.d/functions ]; then
  . /etc/init.d/functions
  elif [ -f /etc/rc.d/init.d/functions ] ; then
  . /etc/rc.d/init.d/functions
  else
  exit 0
  fi
  # Source networking configuration.
  . /etc/sysconfig/network
  # Check that networking is up.
  [ ${NETWORKING} = "no" ] && exit 0
  [ -f /usr/local/haproxy/conf/haproxy.cfg ] || exit 1
  RETVAL=0
  start() {
  /usr/local/haproxy/sbin/haproxy -c -q -f /usr/local/haproxy/conf/haproxy.cfg
  if [ $? -ne 0 ]; then
  echo "Errors found in configuration file."
  return 1
  fi
  echo -n "Starting HAproxy: "
  daemon /usr/local/haproxy/sbin/haproxy -D -f /usr/local/haproxy/conf/haproxy.cfg -p /var/run/haproxy.pid
  RETVAL=$?
  echo
  [ $RETVAL -eq 0 ] && touch /var/lock/subsys/haproxy
  return $RETVAL
  }
  stop() {
  echo -n "Shutting down HAproxy: "
  killproc haproxy -USR1
  RETVAL=$?
  echo
  [ $RETVAL -eq 0 ] && rm -f /var/lock/subsys/haproxy
  [ $RETVAL -eq 0 ] && rm -f /var/run/haproxy.pid
  return $RETVAL
  }
  restart() {
  /usr/local/haproxy/sbin/haproxy -c -q -f /usr/local/haproxy/conf/haproxy.cfg
  if [ $? -ne 0 ]; then
  echo "Errors found in configuration file, check it with 'haproxy check'."
  return 1
  fi
  stop
  start
  }
  check() {
  /usr/local/haproxy/sbin/haproxy -c -q -V -f /usr/local/haproxy/conf/haproxy.cfg
  }
  rhstatus() {
  status haproxy
  }
  condrestart() {
  [ -e /var/lock/subsys/haproxy ] && restart || :
  }
  # See how we were called.
  case "$1" in
  start)
  start
  ;;
  stop)
  stop
  ;;
  restart)
  restart
  ;;
  reload)
  restart
  ;;
  condrestart)
  condrestart
  ;;
  status)
  rhstatus
  ;;
  check)
  check
  ;;
  *)
  echo $"Usage: haproxy {start|stop|restart|reload|condrestart|status|check}"
  RETVAL=1
  esac
  exit $RETVAL
  三、HAProxy的监控脚本我没有做,这个实施起来也简单,我们可以用curl -s --head http://www.1paituan.com/index.jsp | awk '/HTTP/ {print $2}'的方法,判断是否返回了正常的200代码。
  四、加上日志支持,代码如下:
  #vim /etc/syslog.conf
  添加:
  local3.*        /var/log/haproxy.log
  local0.*        /var/log/haproxy.log
  #vim /etc/sysconfig/syslog
  修改:
  SYSLOGD_OPTIONS="-r -m 0"
  service syslog restart
  五、大家需要注意的几个地方是:
  1)HAProyx采用的是balance source机制,它跟Nginx的ip_hash机制原理类似,是让客户机访问时始终访问后端的某一台真实的web服务器,这样让session就固定下来了;
  2)option httpchk HEAD /index.jsp HTTP/1.0 是网页监控,如果HAProxy检测不到Web的根目录下没有index.jsp,就会产生503报错。
  3)有网友说HAProxy必须采用listen 203.93.236.141:80这样类似的格式,这样其实不好,做集群时会导致从机启动不了,我们可以用bind *:80的方式代替。
  4)HAProxy的并发监控和日志收集分析是下一步考虑的事情。

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-365682-1-1.html 上篇帖子: haproxy+keepalived高可用负载均衡(七层) 下篇帖子: Httpd-Nginx1.6+JBOSS7.1.1+keepalived-1.2.12集群配置
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表