一、Haproxy的理解

   Haproxy是一个使用c语言编写的自由开发源代码软件,它提供高可用性、负载均衡、以及基于http和tcp的应用程序代理。

   Haproxy特别使用于那些负载特别大的web站点,这些站点通常需要会话或七层处理。Haproxy运行再当前的硬件上,完全可以支持数以万计的并发连接。并且他的运行模式使得它可以很简单安全的整合进当前的架构中,同时也可以保护我们的web服务器不被暴露再网络上。

二、haproxy的安装配置和负载均衡

   1)首先在server1中下载haproxy的源码包,解压

   --->  yum install rpm-build  -y       # 安装rpmbuild命令

   --->  rpmbuild  -tb haproxy-1.4.26.tar.gz   # 建立haproxy的二进制软件包

   --->  cd rpmbuild/RPMS/x86_64

   --->  rpm  -ivh  haproxy-1.4.26-1.x86_64.rpm       # 安装haproxy软件包

   --->  rpm  -ql  haproxy      # 查看软件相关文件的路径

   2)生成haproxy的配置文件

   --->  cd  /root/

   --->  tar  zxf  haproxy-1.4.24.tar.gz          # 解压压缩包。

   --->  cd  haproxy-1.4.26/examples

    --->  cp  conten-sw-sample.cfg  /etc/haproxy/haproxy.cfg   # 若目录haproxy不存在,新建即可

    3)创建haproxy用户,并修改配置文件

   --->  useradd  haproxy

   --->  vim  /etc/haproxy/haproxy.cfg

  global

          maxconn         10000       # 最大连接数

          stats socket    /var/run/haproxy.stat mode 600 level admin

          log             127.0.0.1 local0

          uid             haproxy         # 此处为新建的haproxy用户的信息

          gid             haproxy 

          chroot          /var/empty

          daemon

  defaults

          mod             http

          log             global

          option          httplog

          option          dontlognull

          monitor-uri     /monitoruri

          maxconn         8000

          timeout client  30s

          option  prefer-last-server

          retries         2

          option  redispatch

          timeout connect 5s

          timeout server  5s

  frontend public

          bind             *:80 name clear     # 默认haproxy的端口号为1080

          #bind            192.168.1.10:443 ssl crt /etc/haproxy/haproxy.pem

          #mode            http

          default_backend dynamic

  backend dynamic    # 默认使用的后端服务集群

          balance         roundrobin        # 负载均衡的算法为rr

          server          statsrv1 172.25.2.2:80 check inter 1000   # 后端服务器

          server          statsrv2 172.25.2.3:80 check inter 1000

   4)修改内核最大文件数

   --->  vim  /etc/security/limits.conf         # 在最后一行输入以下内容

         haproxy     -     nofile    10000

   5)启动服务,测试haproxy是否安装成功

   --->  /etc/init.d/haproxy   start

   --->  netstat  -antlp| grep  1080         # 查看1080端口是否可用

   6)在真机中进行负载均衡的测试,轮询的方式(端口号自己可以在配置文件中修改)

   7)对后端服务器的管理和页面数据的监控

   8)172.25.31.6/monitoruri #网站健康检测URL,用来检测HAProxy管理的网站是否可以用,正常返回200 

三、基于tcp和http的应用程序代理

   (一)动态页面和静态页面的分离

   1、在server1中的httpd默认发布目录中编写文件index.html(server2);在server3中http默认发布目录编写文件index.php

   ---> yum install -y php php-mysql          # 在server3中安装php动态页面

   ---> vim /vat/www/html/index.php  

   --->  /etc/init.d/httpd  restart

   2、在haproxy的配置文件中修改访问动态页面和静态页面

   --->  vim  /etc/haproxy/haproxy.cfg               # 在之前的基础上做如下修改

   3)在浏览器中进行测试

   # 动态访问server3的index.php界面

   # 静态访问的server2中的发布文件

   (二)修改haproxy的日志文件

   1)修改日志服务配置文件从而修改日志存储位置

   --->  vim /etc/rsyslog.conf           # 修改三处

   --->  /etc/init.d/rsyslog   restart      # 重启日志服务

   2)启动haproxy服务,生成日志,并查看

   --->  /etc/init.d/haproxy  restart

   --->  cat  /var/log/haproxy.log          # 查看日志

   (三)访问控制

   1)修改配置文件,添加访问控制的主机

   --->  vim /etc/haproxy/haproxy.conf      # 添加黑名单,在blacklist中的主机均不可以访问(可写ip亦可写网段)

   --->  /etc/init.d/haproxy  restart

   2)在浏览器中测试情况如下:

   3)重定向(当250访问时,重定向到server1中)

   --->  vim  /etc/haproxy/haproxy.conf        # 打开httpd服务

   --->  /etc/init.d/haproxy   reload

   --->  /etc/init.d/httpd  start

   4)测试结果如下
  

   (四)读写分离

   1)在server1中编写配置文件

   --->  vim  /etc/haproxy.haproxy.conf            # 当进行上传操作,转到server3

   --->  /etc/init.d/haproxy  reload

   2)在server2和server3中安装php,把上传脚本放在http默认发布目录,在server3中建立load目录,存放上传图片。(要设置权限)

   3)上传图片(注意图片的格式)

   # 上传成功,在upload目录中查看:

四、corosync+pacemaker实现haproxy的高可用

   1)首先在server4中安装haproxy服务。操作步骤与server1相同。配置好的结果为:

   2)在server1和server4中,开启corosync服务 (可以关闭haproxy服务)

   --->  /etc/init.d/corosync  start

   3)在crm中添加haproxy服务(首先删除之前的nginx服务和web组)

   # 添加haproxy服务并创建组,把ip和haproxy添加进去

  # 再另一端监控情如下:

   4)当节点server4的corosync关闭时,资源自动切换到server1上。

   # 真机中一直是可以显示的。

   5)当server1的主机挂掉的时候,由于fence服务是启动的,所以,server1可以自动开启,并加入可用节点中。

Haproxy的负载均衡和高可用配置的更多相关文章

  1. 本文介绍如何使用 Docker Swarm 来部署 Nebula Graph 集群,并部署客户端负载均衡和高可用

    本文作者系:视野金服工程师 | 吴海胜 首发于 Nebula Graph 论坛:https://discuss.nebula-graph.com.cn/t/topic/1388 一.前言 本文介绍如何 ...

  2. HAProxy+keepalived+MySQL 实现MHA中slave集群负载均衡的高可用

    HAProxy+keepalived+MySQL实现MHA中slave集群的负载均衡的高可用 Ip地址划分: 240    mysql_b2 242    mysql_b1 247    haprox ...

  3. net core 实战之 redis 负载均衡和"高可用"实现

    net core 实战之 redis 负载均衡和"高可用"实现 1.概述 分布式系统缓存已经变得不可或缺,本文主要阐述如何实现redis主从复制集群的负载均衡,以及 redis的& ...

  4. Keepalived+LVS+Nginx负载均衡之高可用

    Keepalived+LVS+Nginx负载均衡之高可用 上一篇写了nginx负载均衡,此篇实现高可用(HA).系统整体设计是采用Nginx做负载均衡,若出现Nginx单机故障,则导致整个系统无法正常 ...

  5. nginx负载均衡+keepalived高可用

    nginx负载均衡+keepalived高可用 环境准备 192.168.88.111:nginx + keepalived   MASTER 192.168.88.112:nginx + keepa ...

  6. dubbo服务层面上的负载均衡和高可用

    dubbo上的服务层可以做集群,来达到负载均衡和高可用,很简单,只需要在不同的服务器节点上向同一个zk(内网环境)注册相同的服务 注意就是,消费者不能在同一个zk做这种集群操作的 转载请注明博客出处: ...

  7. HAProxy+Keepalived+PXC负载均衡和高可用的PXC环境

    HAProxy介绍 反向代理服务器,支持双机热备支持虚拟主机,但其配置简单,拥有非常不错的服务器健康检查功能,当其代理的后端服务器出现故障, HAProxy会自动将该服务器摘除,故障恢复后再自动将该服 ...

  8. asp.net core 实战之 redis 负载均衡和"高可用"实现

    1.概述 分布式系统缓存已经变得不可或缺,本文主要阐述如何实现redis主从复制集群的负载均衡,以及 redis的"高可用"实现, 呵呵双引号的"高可用"并不是 ...

  9. TCP接入层的负载均衡、高可用、扩展性架构

    一.web-server的负载均衡 互联网架构中,web-server接入一般使用nginx来做反向代理,实施负载均衡.整个架构分三层: 上游调用层,一般是browser或者APP 中间反向代理层,n ...

随机推荐

  1. MySQL 储存过程-原理、语法、函数详细说明

    Mysql储存过程是一组为了完成特定功能的SQL语句集,经过编译之后存储在数据库中,当需要使用该组SQL语句时用户只需要通过指定储存过程的名字并给定参数就可以调用执行它了,简而言之就是一组已经写好的命 ...

  2. Flask系列(四)Flask实现简单页面登陆

    from flask import Flask,render_template,request,redirect,session app = Flask(__name__,template_folde ...

  3. vue开发笔记

    1.一定要弄明白什么是数据驱动,以前jQuery操作dom的那种思维模式可以不去考虑,在类似框架中任何一个效果的完成都是由数据驱动来完成的. 2.以.vue作为扩展名的文件,是vue组件,他是一个类, ...

  4. html canvas 圆弧

    contxt.arc(x, y , r, 0 , 弧 1.5*Math.PI PI要注意大小写 , 顺时针=false 逆时针 true) 例如  context.arc(300, 300, 200, ...

  5. Good Bye 2018 Solution

    A. New Year and the Christmas Ornament 签到. #include <bits/stdc++.h> using namespace std; int a ...

  6. IBM究竟是一家怎样的公司

    每次被问到这样的“简单”问题,我都很纠结: 这家公司,从创始至今已经积累了几十万种技术(2015年蝉联专利排行榜23年之久,仅2015年专利数7355项),开发了上万种产品(从银行的交易系统,到航空的 ...

  7. Git: A分支上的commit提交到B分支上

    1. 执行git log -3 --graph A,查看A分支下的commit: 注:commit 后面的hash值代表某个commit,这里把”82f1fb7138c5860cc775b4b5ea7 ...

  8. 解决[Xcodeproj] Unknown object version错误

    错误描述: RuntimeError - [Xcodeproj] Unknown object version. /Library/Ruby/Gems/2.0.0/gems/xcodeproj-0.2 ...

  9. SNMP学习笔记之SNMPWALK 命令

    SNMPWALK是一个通过SNMP GET-NEXT类型PDU,实现对目标AGENT的某指定MIB分支信息进行完整提取输出的命令工作. 命令行: snmpwalk [选项] agent [oid] 选 ...

  10. 20145118 《Java程序设计》 实验报告一

    实验一 JAVA开发环境的熟悉(LINUX + ECLIPSE) 实验内容 1.使用JDK编译.运行简单的Java程序: 2.使用Eclipse 编辑.编译.运行.调试Java程序. 3.统计自己的P ...