首页 雷火电竞官网正文

全顺,详解mycat+haproxy+keepalived建立mysql集群之布置HAPROXY署理-雷火电竞网站

admin 雷火电竞官网 2019-11-16 224 0

概述

数据库功用优化遍及选用集群方法,而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方面的内容,感兴趣的朋友能够重视下~

雷火电竞版权声明

本文仅代表作者观点,不代表本站立场。
本文系作者授权发表,未经许可,不得转载。

最近发表

    雷火电竞网站_雷火电竞平台_雷火电竞

    http://www.vedicchef.com/

    |

    Powered By

    使用手机软件扫描微信二维码

    关注我们可获取更多热点资讯

    雷火电竞出品