百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT技术 > 正文

基于mycat+haproxy+keepalived搭建mysql集群(Haproxy篇)

wptr33 2024-11-24 22:27 20 浏览

概述

数据库性能优化普遍采用集群方式,而oracle集群软硬件投入昂贵,下面介绍下mysql数据库集群环境搭建中的haproxy部分,以下为整体的架构图。

运作理解:主机1与主机2上的keepalived会为该服务器抢占vip,抢占到vip后,对该主机的访问可以通过原来的ip访问,也可以直接通过vip访问,当其中一台宕机时,vip会漂移到另一台机器上,当我们访问VIP时haproxy会根据配置将请求分发到两台Mycat上实现负载均衡,并且haproxy会检测mycat是否存活。


haproxy安装(haproxy-1.8.12)

HAProxy 是一款提供高可用性、负载均衡以及基于TCP(第四层)和HTTP(第七层)应用的代理软件,支持虚拟主机,它是免费、快速并且可靠的一种解决方案。 HAProxy特别适用于那些负载特大的web站点,这些站点通常又需要会话保持或七层处理。HAProxy运行在时下的硬件上,完全可以支持数以万计的 并发连接。并且它的运行模式使得它可以很简单安全的整合进您当前的架构中, 同时可以保护你的web服务器不被暴露到网络上。


1、下载haproxy

国内镜像地址:http://pkgs.fedoraproject.org/repo/pkgs/haproxy/

1.1、查看内核版本

uname -r

根据内核版本选择编译参数:

这里内核是3.10的选择 linux2628,安装haproxy

1.2、创建用户及用户组

groupadd haproxy
useradd -g haproxy -m haproxy

1.3、下载haproxy

wget https://src.fedoraproject.org/repo/pkgs/haproxy/haproxy-1.8.12.tar.gz/sha512/2b782a54988cc88d1af0e5f011af062910e8fac28eab13db7e05a58d0d23961f827da47e3871e8d081f5a2d222588480d81dec2e9f14ec9f54a1c3cb5bf3d56a/haproxy-1.8.12.tar.gz

1.4、解压并编译安装

tar -xvf haproxy-1.8.12.tar.gz -C /usr/local
cd /usr/local/haproxy-1.8.12
make TARGET=linux2628 PREFIX=/usr/local/haproxy
make install PREFIX=/usr/local/haproxy

1.5、授权

chown -R haproxy.haproxy /usr/local/haproxy
chmod -R 755 /usr/local/haproxy


1.6、测试

安装成功后,查看版本

/usr/local/haproxy/sbin/haproxy -v

2、配置haproxy

#vim /usr/local/haproxy/haproxy.cfg
=====================================================
global
#设置日志
 log 127.0.0.1 local0
 chroot /usr/local/haproxy
#用户与用户组
 user haproxy
 group haproxy
#定义每个haproxy进程的最大连接数 ,由于每个连接包括一个客户端和一个服务器端,所以单个进程的TCP会话最大数目将是该值的两倍。
 maxconn 4096
# 以守护进程的方式运行
 daemon
defaults
log global
#日志中不记录空连接
option dontlognull
# 定义连接后端服务器的失败重连次数,连接失败次数超过此值后将会将对应后端服务器标记为不可用
retries 3
option redispatch
# 设置成功连接到一台服务器的最长等待时间,默认单位是毫秒
timeout connect 5000
# 设置连接客户端发送数据时的成功连接最长等待时间,默认单位是毫秒
timeout client 50000
# 设置服务器端回应客户度数据发送的最长等待时间,默认单位是毫秒
timeout server 50000
#统计页面
listen admin_stats
 bind 172.26.151.99:48800 
 mode http
#采用http日志格式 
 option httplog
#统计页面自动刷新时间 
 stats refresh 30s
#统计页面url
 stats uri /admin_stats
#统计页面密码框上提示文本
 stats realm Haproxy Manager
#统计页面用户名和密码设置 
 stats auth admin:admin
#隐藏统计页面上HAProxy的版本信息
 stats hide-version
listen mycat_service
# 绑定172.26.151.99:8067端口访问mycat8066端口
bind 172.26.151.99:8067
# 定义为tcp模式
 mode tcp
#采用http日志格式
 option tcplog
# 开启对后端服务器的健康检测
 option httpchk OPTIONS * HTTP/1.1\r\nHost:\ www
# 设置haproxy的调度算法
 balance roundrobin
#根据调度分配到真实的后台地址,参数解释:port 48700:检测端口48700, inter 5s:5秒检测一次,rise 2:检测成功2次表示服务器可用,fall 3:检测失败3次后表示服务器不可用
 server mycat_96 172.26.151.96:8066 check port 48700 inter 5s rise 2 fall 3
 server mycat_97 172.26.151.97:8066 check port 48700 inter 5s rise 2 fall 3
#设置服务器端回应客户度数据发送的最长等待时间,默认单位是毫秒
 timeout server 20000
listen mycat_admin
#绑定172.26.151.99:9067端口访问mycat9066端口
bind 172.26.151.99:9067
mode tcp
option tcplog
option httpchk OPTIONS * HTTP/1.1\r\nHost:\ www
balance roundrobin
server mycat_96 172.26.151.96:8066 check port 48700 inter 5s rise 2 fall 3
server mycat_97 172.26.151.97:8066 check port 48700 inter 5s rise 2 fall 3
timeout server 20000
=====================================================



3、启动和停止haproxy

/usr/local/haproxy/sbin/haproxy -f /usr/local/haproxy/haproxy.cfg #启动
killall haproxy #停止

4、查看日志


部署过程常见报错

报错1:/usr/local/bin/mycat_status: line 9: /usr/local/mycat/bin/mycat: Permission denied

授权后就解决了

报错2:Keepalived_vrrp[2924]: Error exec-ing command '/etc/keepalived/scripts/check_haproxy.sh', error 8: Exec format error

日志提示:

思路:其实就是因为你的haproxy没有得到VIP的原因,而你的配置文件又绑定了VIP地址,所以会提示以上错误

当然,你也要确保你的haproxy服务器做了hearbeat或keepalived,绑定VIP,要不就无法高可用了。

解决:

#vi /etc/sysctl.conf
net.ipv4.ip_nonlocal_bind = 1
net.ipv4.ip_forward = 1
#sysctl -p

net.ipv4.ip_nonlocal_bind=1 意思是启动haproxy的时候,允许忽视VIP的存在


5、配置haproxy记录日志功能

5.1、安装rsyslog服务

默认haproxy是不记录日志的,为了记录日志还需要配置syslog模块,在linux下是rsyslogd服务,需要先安装rsyslog

yum -y install rsyslog


5.2、配置rsyslog服务

#vi /etc/rsyslog.d/haproxy.conf

$ModLoad imudp
$UDPServerRun 514
local0.* /var/log/haproxy.log

#vim /etc/rsyslog.conf

#在#### RULES ####上面一行加入以下内容
#Include all config files in /etc/rsyslog.d/
$IncludeConfig /etc/rsyslog.d/*.conf
#在local7.* /var/log/boot.log下面增加
local0.* /var/log/haproxy.log

5.3、重启rsyslog服务并加入自启动服务

systemctl restart rsyslog.service
systemctl enable rsyslog.service
systemctl status rsyslog.service

觉得有用的朋友多帮忙转发哦!后面会分享更多devops和DBA方面的内容,感兴趣的朋友可以关注下~

相关推荐

【推荐】一款开源免费、美观实用的后台管理系统模版

如果您对源码&技术感兴趣,请点赞+收藏+转发+关注,大家的支持是我分享最大的动力!!!项目介绍...

Android架构组件-App架构指南,你还不收藏嘛

本指南适用于那些已经拥有开发Android应用基础知识的开发人员,现在想了解能够开发出更加健壮、优质的应用程序架构。首先需要说明的是:AndroidArchitectureComponents翻...

高德地图经纬度坐标批量拾取(高德地图批量查询经纬度)

使用方法在桌面上新建一个index.txt文件,把下面的代码复制进去保存,再把文件名改成index.html保存,双击运行打开即可...

flutter系列之:UI layout简介(flutter ui设计)

简介对于一个前端框架来说,除了各个组件之外,最重要的就是将这些组件进行连接的布局了。布局的英文名叫做layout,就是用来描述如何将组件进行摆放的一个约束。...

Android开发基础入门(一):UI与基础控件

Android基础入门前言:...

iOS的布局体系-流式布局MyFlowLayout

iOS布局体系的概览在我的CSDN博客中的几篇文章分别介绍MyLayout布局体系中的视图从一个方向依次排列的线性布局(MyLinearLayout)、视图层叠且停靠于父布局视图某个位置的框架布局(M...

TDesign企业级开源设计系统越发成熟稳定,支持 Vue3 / 小程序

TDesing发展越来越好了,出了好几套组件库,很成熟稳定了,新项目完全可以考虑使用。...

WinForm实现窗体自适应缩放(winform窗口缩放)

众所周知,...

winform项目——仿QQ即时通讯程序03:搭建登录界面

上两篇文章已经对CIM仿QQ即时通讯项目进行了需求分析和数据库设计。winform项目——仿QQ即时通讯程序01:原理及项目分析...

App自动化测试|原生app元素定位方法

元素定位方法介绍及应用Appium方法定位原生app元素...

61.C# TableLayoutPanel控件(c# tabcontrol)

摘要TableLayoutPanel在网格中排列内容,提供类似于HTML元素的功能。TableLayoutPanel控件允许你将控件放在网格布局中,而无需精确指定每个控件的位置。其单元格...

想要深入学习Android性能优化?看完这篇直接让你一步到位

...

12个python数据处理常用内置函数(python 的内置函数)

在python数据分析中,经常需要对字符串进行各种处理,例如拼接字符串、检索字符串等。下面我将对python中常用的内置字符串操作函数进行介绍。1.计算字符串的长度-len()函数str1='我爱py...

如何用Python程序将几十个PDF文件合并成一个PDF?其实只要这四步

假定你有一个很无聊的任务,需要将几十个PDF文件合并成一个PDF文件。每一个文件都有一个封面作为第一页,但你不希望合并后的文件中重复出现这些封面。即使有许多免费的程序可以合并PDF,很多也只是简单的将...

Python入门知识点总结,Python三大数据类型、数据结构、控制流

Python基础的重要性不言而喻,是每一个入门Python学习者所必备的知识点,作为Python入门,这部分知识点显得很庞杂,内容分支很多,大部分同学在刚刚学习时一头雾水。...