分类目录归档:MySQL

使用HAProxy实现MySQL的负载均衡


使用HAProxy实现MySQL的负载均衡

是通过HAProxy的TCP层(四层)负载均衡能力,将客户端的数据库连接请求分发到多个后端MySQL节点,从而分散压力、提高可用性。以下是详细的实现思路、配置方法及注意事项:

一、核心原理与架构

HAProxy支持TCP(四层)和HTTP(七层)协议。MySQL基于TCP协议通信,因此HAProxy通过四层负载均衡实现MySQL的请求分发。

典型架构

  • 前端:HAProxy监听指定端口(如3306,与MySQL默认端口一致),接收客户端连接。
  • 后端:多个MySQL节点(通常为从库,用于读负载均衡;主库单独处理写操作)。
  • 核心目标:分散读请求到多...

Read more

MySQL高可用之MHA


MHA简介

MHA(Master High Availability)是一套针对MySQL的高可用解决方案,能实现自动故障检测与主从切换,有效减少MySQL故障恢复时间,提高服务可用性。

image-20250815153327732

其核心特点包括:

  1. 自动故障检测与切换:通过定期监控主库状态,当主库出现故障(如宕机、网络中断等)时,能自动识别并在从库中选择最合适的节点提升为新主库,整个过程无需人工干预。

  2. 数据一致性保障:在切换过程中,会尽量复制主库未同步到从库的binlog日志,最大程度减少数据丢失;支持GTID(全局事务标识),简化binlog定位与同步流程。

  3. 灵活的候选主库选择:可通过配置指定优先成为新主库的候选节...

Read more

MySQL配置文件优化


MySQL配置文件优化

MySQL配置文件(通常是my.cnfmy.ini)的优化是提升数据库性能的关键环节,合理的参数设置能最大化利用硬件资源并避免性能瓶颈。以下是针对不同场景的核心配置优化建议,涵盖InnoDB引擎、连接管理、查询优化等关键维度。

一、核心配置文件结构

MySQL配置文件通常分为多个模块,核心模块包括:

[mysqld]          # 服务器核心配置
[mysqld_safe]     # 安全相关配置(如日志、内存限制)
[mysql]           # 客户端配置

调优主要集中在[mysqld]模块,以下是关键参数详解。

二、InnoDB引...

Read more

MyCAT2 入门到实战(四)


10. 【掌握】MyCAT2分库分表

10.1 分库分表的原理

一个数据库由很多表构造成,每个表对应不同的业务,垂直切分是指按业务将表进行分类,分布到不同的数据库上面,这样也就将数据或者说压力分担到不同的库上面。

10.1.1 垂直切分

基于表或字段划分,表结构不同。我们有单库的分表,也有多库的分表,如下图所示

img

注意:有紧密关联关系的表应该在一个库里,相互没有关联关系的表可以分到不同的库里面

换句话说:就是我们很多库合在一起组成一个完整的数据库系统(这个不同到集群哦)。

10.1.2 水平切分

基于数据划分,表结构相同,数据不同,也有同库的水平切分和多库的切分。

当我们的客户表数量已经...

Read more

MyCAT2 入门到实战(三)


6. 【熟悉】MySQL主从搭建

因为MyCAT只能路由、分发,不能把多个数据库里面的数据进行同步,所以要数据同步必须还要使用MySQL的读写分离,主从复制。

img

6.1 概述主从介绍

MySQL主从又叫Replication、AB复制。简单讲就是A与B两台机器做主从后,在A上写数据,另外一台B也会跟着写数据,实现数据实时同步。有这样几个关键点:

1)MySQL主从是基于binlog,主上需开启binlog才能进行主从;

2)主从过程大概有3个步骤;

3)主将更改操作记录到binlog里;

4)从将主的binlog事件(SQL语句) 同步本机上并记录在relaylog里;

5)从根据re...

Read more

MyCAT2 入门到实战(二)


4. 【掌握】MyCAT2配置文件介绍

4.1 用户(user)

配置文件位置/usr/local/mycat/conf/users/{用户名}.user.json。这个配置文件主要是用来配置MyCAT的登录用户的,也就是我们连接8066这个端口的用户信息。

{
    "dialect": "mysql",
    "ip": null,
    "password": "123456",
    "transactionType": "proxy"...

Read more

MyCAT读写分离


MyCat读写分离

一、读写分离配置

前面我们已经介绍过了mysql的主从同步和mycat的安装及相关配置文件的介绍,现在我们来配置下具体的读写分离操作。

1.1 创建物理表

我们现在master库中创建一张t_user表,因为主从的关系,slave中也会同步创建该表。

img

1.1 schema.xml配置

<?xml version="1.0"?>
<!DOCTYPE mycat:schema SYSTEM "schema.dtd">
<mycat:schema xmlns:mycat="http://io....

Read more

MyCat全局主键自增长


面我们介绍了MyCat的分库分表操作,那么同一张表中的数据会被保存在不同的数据库中,那么这就涉及到了主键维护的问题,此时肯定不能使用单个数据库中id自增的方式来处理了,这时我们就可以通过MyCat中提供的几种增长的方式来实现。

全局主键自增

一、本地文件自增方式

首先我们来看下第一种方式,也就是本地文件自增方式

1. 修改分片策略

我们原来配置的分片策略crc32slot是不支持主键自增的,所以我们需要修改为auto-sharding-long

img

2. 修改server.xml文件

server.xml文件中的sequnceHandlerType是用来配置主键生成类型的

sequn...

Read more

MyCAT 2分库分表


分库分表

一、分片规则介绍

rule.xml中定义了各种myCat支持的分片规则。

  1. 取模mod-long
  2. 自然月分片 sharding-by-month
  3. 按日期(天)分片sharding-by-date
  4. 按单月小时拆分sharding-by-hour
  5. 范围约定,提前规划好分片字段某个范围属于哪个分片,auto-sharding-long
  6. 范围求模分片
  7. 取模范围约束sharding-by-pattern
  8. 分片枚举sharding-by-intfile
  9. 固定分片hash算法
  10. 截取数字hash解析sharding-by-stringhash
  11. 一致性hash
  12. 日期范围hash分片rang...

Read more

MySQL编程进阶


MySQL流程控制的语法

存储过程

语法:

创建存储过程

drop procedure if exists [存储过程名] ;

delimiter [结束标记]
create procedure [存储过程名]([参数1], [参数2] ...)
begin
    [存储过程体(一组合法的sql语句)]
end [结束标记]

delimiter ;

参数,其格式为 [in|out|inout] parameter_name type

in #表示输入参数;
out #表示输出参数;
inout #表示此参数既可以输入也可以输出;
param_name #表示参数名称;
type...

Read more