单机三pxc节点集群,+docker-haproxy2.0负载均衡实现

一.下载

https://www.haproxy.org/download/2.0/src/haproxy-2.0.5.tar.gz

或者在这里下载(下面需要的各个配置文件都有):

https://download.csdn.net/download/cyw8998/89170129

二.编写文件,制作docker镜像

1.Dockerfile:

FROM centos:7
#将同级目录下的文件haproxy-2.0.5.tar.gz拷贝到该目录下
ADD haproxy-2.0.5.tar.gz /usr/local/etc/
## 安装编译工具,开始安装编译haproxy
RUN yum install -y gcc gcc-c++ glibc glibc-devel pcre \pcre-devel openssl openssl-devel systemd-devel \net-tools vim iotop bc zip unzip zlib-devel lrzsz \tree screen lsof tcpdump wget ntpdate –y \&& cd /usr/local/etc/haproxy-2.0.5 \&& make ARCH=x86_64 TARGET=linux-glibc \USE_PCRE=1 USE_OPENSSL=1 USE_ZLIB=1 \USE_SYSTEMD=1 USE_CPU_AFFINITY=1 \PREFIX=/usr/local/haproxy \&& make install PREFIX=/usr/local/haproxy \&& cp haproxy /usr/sbin/ \&& mkdir /usr/local/haproxy/run
# 将Dockerfile同级目录下的haproxy.cfg配置文件拷贝到镜像的该目录下
ADD haproxy.cfg /etc/haproxy/
ADD haproxy.cfg /usr/local/etc/haproxy-2.0.5/
# 将 run_haproxy.sh 启动脚本文件拷贝到镜像的该目录下
ADD run_haproxy.sh /usr/bin
# 赋予 run_haproxy.sh 运行权限
RUN chmod +x /usr/bin/run_haproxy.sh
# 向外暴露 80 和 8888 端口
EXPOSE 80 8888
#执行 run_haproxy.sh 脚本
CMD ["/usr/bin/run_haproxy.sh"]

2.haproxy.cfg:

global#工作目录chroot /usr/local/etc/haproxy-2.0.5#日志文件,使用rsyslog服务中local5日志设备(/var/log/local5),等级infolog 127.0.0.1 local5 info#守护进程运行daemondefaultslog	globalmode	http#日志格式option	httplog#日志中不记录负载均衡的心跳检测记录option	dontlognull#连接超时(毫秒)timeout connect 5000#客户端超时(毫秒)timeout client  50000#服务器超时(毫秒)timeout server  50000#监控界面	
listen  admin_stats#监控界面的访问的IP和端口bind  0.0.0.0:8888#访问协议mode        http#URI相对地址stats uri   /dbs#统计报告格式stats realm     Global\ statistics#登陆帐户信息stats auth  admin:admin
#数据库负载均衡
listen  proxy-mysql#访问的IP和端口bind  0.0.0.0:3306  #网络协议mode  tcp#负载均衡算法(轮询算法)#轮询算法:roundrobin#权重算法:static-rr#最少连接算法:leastconn#请求源IP算法:source balance  roundrobin#日志格式option  tcplog#在MySQL中创建一个没有权限的haproxy用户,密码为空。Haproxy使用这个账户对MySQL数据库心跳检测option  mysql-check user haproxyserver  pxc_node1 170.19.0.11:3306 check weight 1 maxconn 2000  server  pxc_node2 170.19.0.12:3306 check weight 1 maxconn 2000server  pxc_node3 170.19.0.13:3306 check weight 1 maxconn 2000#使用keepalive检测死链option  tcpka  

3.run_haproxy.sh


#!/bin/bash
haproxy -f /etc/haproxy/haproxy.cfg
tail -f /etc/hosts

4.制作镜像

docker build -t mars/haproxy .

三.启动pxc和harproxy

1.dock-compose制作镜像并启动pxc,见上一篇文章,pxc8证书制作也略

version : '3.7'
services:db1:container_name: db1image: percona/percona-xtradb-cluster:8.0privileged: truenetworks:my-pxc:ipv4_address: 170.19.0.11environment:- "CLUSTER_NAME=JWSPXC"- "XTRABACKUP_PASSWORD=123456"- "MYSQL_ROOT_PASSWORD=123456"- "TZ=Asia/Shanghai"ports:- "13306:3306"volumes:- v301:/var/lib/mysql- ~/pxc-docker-test/cert:/cert- ~/pxc-docker-test/config:/etc/percona-xtradb-cluster.conf.ddb2:container_name: db2image: percona/percona-xtradb-cluster:8.0privileged: truenetworks:my-pxc:ipv4_address: 170.19.0.12environment:- "CLUSTER_NAME=JWSPXC"- "XTRABACKUP_PASSWORD=123456"- "TZ=Asia/Shanghai"- "CLUSTER_JOIN=db1"ports:- "23306:3306"volumes:- v302:/var/lib/mysql- ~/pxc-docker-test/cert:/cert- ~/pxc-docker-test/config:/etc/percona-xtradb-cluster.conf.drestart: always #on-failuredepends_on:- db1db3:container_name: db2image: percona/percona-xtradb-cluster:8.0privileged: truenetworks:my-pxc:ipv4_address: 170.19.0.12environment:- "CLUSTER_NAME=JWSPXC"- "XTRABACKUP_PASSWORD=123456"- "TZ=Asia/Shanghai"- "CLUSTER_JOIN=db1"ports:- "33306:3306"volumes:- v303:/var/lib/mysql- ~/pxc-docker-test/cert:/cert- ~/pxc-docker-test/config:/etc/percona-xtradb-cluster.conf.drestart: always #on-failuredepends_on:- db1volumes:v301:v302:v303:
networks:my-pxc:driver: bridgeipam:driver: defaultconfig:- subnet: 170.19.0.0/24

#docker-compose up -d db1  先检测第一个主点,成功后再执行下一句

#docker-compose up -d db2  检测第2个点是否成功,成功后再执行下一句

#docker-compose up -d db3

注意:docker-compose定义的卷标名和network名,在生成docker后,查看network和volume名都带着前缀d-compose_取决于文件夹名_

5.启动一下haproxy

docker run -d -p 80:80 -p 8888:8888 mars/haproxy
因为已经配置了haproxy.cfg,所以容器启动后会自动代理pxc集群

6.访问一下haproxy2.0控制台

192.168.xx.xxx:8888/dbs

发现负载的两台目标机器是DOWN状态

在 pxc集群中创建一个用户给 haproxy使用
CREATE USER 'haproxy'@'%' IDENTIFIED BY '';

运行


 

docker run -d -p 80:80 -p 8888:8888 -p 13301:3306 --name haproxy --privileged --net=d-compose_my-pxc --ip 170.19.0.10 mars/haproxy

再访问控制台

192.168.xx.xxx:8888/dbs

发现负载的两台目标机器是up状态

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/827015.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

四款一键智能改写工具,为你轻松改出爆款文章

四款一键智能改写工具,为你轻松改出爆款文章!当今,虽然内容创作变得非常重要。但是,有时候创作灵感可能枯竭,或者需要对已有内容进行改写以增加独特性。这时候,一键智能改写工具成为了创作中的一种强大的辅…

LeetCode 课程表二(拓扑排序+Python)

使用桶排序算法中的kahn(卡恩)算法,也可以使用dfs。 这里使用卡恩算法,主要维护一个列表cnt,cnt【i】表示能到达节点i的边,比如说:a到c有一条边,b到c有一条边,那么cnt【…

信息流广告大行其是,微博回望“原生”的初心

摘要:有流量的地方,就当有原生信息流广告 信息流广告,自2006年Facebook推出后就迅速火遍全球数字营销界,被誉为实现了广告主、用户、媒体平台三赢。特别是随着OCPM/OCPX大放异彩,信息流广告几乎成为广告主的必选项&…

Print Conductor 文档批量打印工具 v9.0.2312

网盘下载 Print Conductor 是 Windows 上一款功能强大的文档批量打印工具,通过该软件可以快速的帮用户批量处理打印PDF文件、协议、文档、图纸、演示文稿、文本文件等,完美的支持PDF、DOC、JPG、PNG、SNP、PSD、MSG、WRI、WPS、RTF、TXT、XLS、PPT、PPS、…

在Linux系统中,禁止有线以太网使用NTP服务器进行时间校准的几种方法

目录标题 方法 1:修改NTP配置以禁止所有同步方法 2:通过网络配置禁用NTP同步方法 3:禁用NTP服务 在Linux系统中,如果想要禁止有线以太网使用NTP服务器进行时间校准,可以通过以下几种方法之一来实现: 方法 …

Java中的对象

什么是类和对象 在Java中类是物以类聚,分类的思维模式,思考问题首先会解决问题需要哪些分类,然后对这些类进行单独思考,最后才是对某分类下的细节进行单独思考 面向对象适合处理复杂问题适合处理需要多人协作的问题 在Java中面向…

【状态机dp 动态规划】100290. 使矩阵满足条件的最少操作次数

本文涉及知识点 动态规划汇总 状态机dp LeetCode100290. 使矩阵满足条件的最少操作次数 给你一个大小为 m x n 的二维矩形 grid 。每次 操作 中,你可以将 任一 格子的值修改为 任意 非负整数。完成所有操作后,你需要确保每个格子 grid[i][j] 的值满足…

【Qt 学习笔记】Qt常用控件 | 显示类控件 | Label的使用及说明

博客主页:Duck Bro 博客主页系列专栏:Qt 专栏关注博主,后期持续更新系列文章如果有错误感谢请大家批评指出,及时修改感谢大家点赞👍收藏⭐评论✍ Qt常用控件 | 显示类控件 | Label的使用及说明 文章编号:Q…

Opencv Python图像处理笔记一:图像、窗口基本操作

文章目录 前言一、输入输出1.1 图片读取显示保存1.2 视频读取保存1.3 文件读取保存 二、GUI2.1 窗口2.2 轨迹条2.3 画图2.4 鼠标回调 三、图像入门操作3.1 颜色空间转化3.2 通道分离合并3.3 添加边框3.4 算数操作 四、二值化4.1 普通4.2 自适应4.3 Otsu 参考 前言 随着人工智能…

mysql基础3——创建和修改数据表

创建数据表 创建一个表(importtype有默认值1)并插入一条数据(importtype字段没有指定值) 约束 默认约束(把设置的默认值自动赋值给字段) create table demo.importhead(listnum int,supplied int,stock…

C++进修——C++基础入门

初识C 书写HelloWorld #include <iostream> using namespace std;int main() {cout << "HelloWorldd" << endl;system("pause");return 0; }注释 作用&#xff1a;在代码中加一些说明和解释&#xff0c;方便自己或其他程序员阅读代码…

docker打包部署自己的应用

docker部署应用 当谈及使用 Docker 进行容器化部署应用时&#xff0c;可以想象它是一个能够将整个应用程序及其所有依赖项打包成一个独立、可移植的容器的工具。这个容器不仅包含了应用代码&#xff0c;还包括了操作系统、运行时环境以及所有依赖的库和组件。这样一来&#xf…

双工结构(duplex construction)

参考文献&#xff1a; [BDPV11] Bertoni G, Daemen J, Peeters M, et al. Duplexing the sponge: single-pass authenticated encryption and other applications[C]//Selected Areas in Cryptography: 18th International Workshop, SAC 2011, Toronto, ON, Canada, August 1…

mybatis创建入门流程体验

mysql数据库中建表 drop table if exists tb_user;create table tb_user(id int primary key auto_increment,username varchar(20),password varchar(20),gender char(1),addr varchar(30) );INSERT INTO tb_user VALUES (1, zhangsan, 123, 男, 北京); INSERT INTO tb_user …

星域社区原版APP源码/社区交友App源码/动态圈子群聊php源码

简介 初始版本是由RuleAPP规则之树开发的&#xff0c;而星域社区则是在此基础上进行了二次开发和美化。作者花了近一年的时间来打磨它&#xff0c;现在即将推出Pro版。如果你只想免费使用的话&#xff0c;可以使用原始的RuleAPP版本。但是&#xff0c;如果你想要获得更好的美观…

【YOLOv9】实战二:手把手教你使用TensorRT实现YOLOv9实时目标检测(含源码)

‍‍&#x1f3e1;博客主页&#xff1a; virobotics(仪酷智能)&#xff1a;LabVIEW深度学习、人工智能博主 &#x1f384;所属专栏&#xff1a;『LabVIEW深度学习实战』 &#x1f4d1;上期文章&#xff1a;『【YOLOv9】实战一&#xff1a;在 Windows 上使用LabVIEW OpenVINO工具…

CTF工具处理(2)--HackBar报错

来源&#xff1a;HackBar插件绕许可_hackbar许可证-CSDN博客 报错页面&#xff1a; 工具报错原因&#xff1a; 版本升级&#xff0c;需要收费。 破解&#xff1a; 1.下载文件&#xff08;去网上找破解HackBar&#xff09; 2.添加附件&#xff1a; 3.重启&#xff1a; 按F12就…

引领4G拾音新时代:DuDuTalk双定向拾音设备上市,助力现场管理步入智能化

近日&#xff0c;继DuDuTalk的4G智能拾音工牌&#xff08;挂牌和胸牌&#xff09;之后&#xff0c;赛思云科技在线下沟通场景智能语音采集方案领域的又一突破性产品4G双定向桌面拾音终端全新上市。 该产品是面向营业网点、市政大厅、医疗诊室、售票窗口、贵宾室等环境的柜台服…

【工具-pip】

工具-pip ■ pip-工具■ pip-安装■ pip-卸载■ pip-帮助■ pip- 批量安装库■ 批量卸载库■ 提高pip下载速度 ■ pip-工具 pip 是 Python 标准库中的一个包&#xff0c;这个包是用来管理 Python 第三方库。 通用的 Python 包管理工具。提供了对 Python 包的查找、下载、安装、…

cesium 动态线效果

一、扩展材质 function PolylineTrailMaterial(options) {options Cesium.defaultValue(options, Cesium.defaultValue.EMPTY_OBJECT);this._definitionChanged new Cesium.Event();// 变量初始化this.color Cesium.defaultValue(options.color && new Cesium.Colo…