proxySQL是MySQL的中间件产品,是灵活强大的代理层,实现读写分离,支持Query路由功能,支持动态指定某个SQL进行缓存,支持动态加载配置,故障切换和一些SQL

过滤功能

环境:

192.168.139.152  proxy SQL中间件   server-id=1

192.168.139.153  master mysql         server-id=2

192.168.139.154 slave mysql            server-id=3

proxy SQL更多信息可以访问 https://github.com/sysown/proxysql/wiki

MYSQL安装(all node)

要点:所有节点都安装MySQL并修改/etc/my.cnf 中的server-id

更新root密码123qweASD!

修改配置文件/etc/my.cnf

[mysqld]

server-id=1

mysql主从部署(master-slave)

从节点read_only=on

PROXYSQL安装(proxysql node)

安装依赖包:

yum install -y perl-DBD-MySQL  perl-DBI  perl-Time-HiRes perl-IO-Socket-SSL

创建repo文件

cat <<EOF | tee /etc/yum.repos.d/proxysql.repo
[proxysql_repo]
name= ProxySQL YUM repository
baseurl=http://repo.proxysql.com/ProxySQL/proxysql-1.4.x/centos/\$releasever
gpgcheck=1
gpgkey=http://repo.proxysql.com/ProxySQL/repo_pub_key
EOF 安装proxy SQL
yum install -y proxysql proxysql配置文件的路径为 /etc/proxysql.cnf 启动proxy SQL
service proxysql start 查看proxysql版本:
proxy SQL--version proxy SQL 默认用户名/密码 admin/admin proxysql 管理端口6032 对外服务端口6033
登陆proxysql :
mysql -u admin -padmin -h 127.0.0.1 -P 6032
MySQL>show databases; 显示5个数据库 main disk stats monitor stats_history
main 内存配置数据库,即MEMORY ,表里存放后端db实例,用户验证,路由规则等信息
  主要表:mysql_servers 后端可以连接MySQL服务器的列表
      mysql_users 配置后端数据库的账户和监控账户
     mysql_query_rules 指定Query路由到后端不同服务器的规则列表
注:runtime 开头的表,表示当前运行的配置,不可修改;其余表修改后,LOAD使其生效,SAVE使其存到硬盘以供下次重启加载 master 节点创建proxy SQL监控账户:
create user 'monitor'@'192.168.139.%' identified by '123qweASD!';
grant all privileges on *.* to 'monitor'@'192.168.139.%' with grant option; master节点创建对外访问账户:
mysql> create user 'zs'@'192.168.139.%' identified by '123qweASD!';
mysql> grant all privileges on *.* to 'zs'@'192.168.139.%' with grant option; proxy SQL节点:添加主服务器列表 将主从MySQL加进去,自己不加
mysql -uadmin -padmin -h 127.0.0.1 -P 6032
mysql>insert into mysql_servers(hostgroup_id,hostname,port) values(10,'192.168.139.153',3306);
mysql>insert into mysql_servers(hostgroup_id,hostname,port) values(10,'192.168.139.154',3306);
mysql>load mysql servers to runtime;
mysql>save mysql servers to disk;

机器的状态都是online状态

proxysql配置监控账号
mysql> set mysql-monitor_username='monitor';
mysql> set mysql-monitor_password='123qweASD!'; ===》 /etc/proxysql.cnf 中的monitor_password也要修改 配置proxy SQL主从分组
mysql> insert into  mysql_replication_hostgroups values(10,20,'proxy');
mysql> load mysql servers to runtime;
mysql> save mysql servers to disk;

配置对外访问账号,默认指定库,并对该用户开启事务持久化保护

mysql> insert into mysql_users(username,password,default_hostgroup) values('zs','123qweASD!',10);
mysql> update mysql_users set transaction_persistent=1 where username='zs';
mysql> load mysql users to runtime;
mysql> save mysql users to disk; 验证登陆服务器就:
是主库
读写分离策略配置

mysql> insert into mysql_query_rules(active,match_pattern,destination_hostgroup,apply) values(1,'^SELECT.*FOR UPDATE$',10,1);  ===》写
mysql> insert into mysql_query_rules(active,match_pattern,destination_hostgroup,apply) values(1,'^SELECT',20,1); ===》读
mysql> load mysql query rules to runtime;
mysql> save mysql query rules to disk; 读写分离测试: mysql -u zs -p123qweASD! -h 192.168.139.152 -P 6033 登陆proxysql所在机器登陆数据库
mysql> select * from mysql.user; 读操作
mysql> create database zhangyu ; 写操作 登陆proxysql管理账户

10 是写库组 20是读库组

调整权重,让某个机器承受更多读操作

mysql> update mysql_servers set weight=10 where hostname='192.168.139.154';

mysql> load mysql servers to runtime;

mysql> save mysql servers to disk;

												

ProxySQL(读写分离)部署的更多相关文章

  1. mysqlfailover高可用与proxysql读写分离配置

    proxysql官方推荐两种高可用方案: 1.MHA+proxysql 2.mysqlrpladmin+proxysql MySQLfailover工具包含在mysqlrpladmin工具中,所以两者 ...

  2. MySQL ProxySQL读写分离实践

    目的 在上一篇文章MySQL ProxySQL读写分离使用初探里初步介绍了ProxySQL的使用,本文继续介绍它的一些特点和DBProxy的性能差异.深入一些去了解ProxySQL,通过测试来说明Pr ...

  3. 001.Amoeba读写分离部署

    一 Amoeba简介 Amoeba(变形虫)项目,该开源框架于2008年 开始发布一款 Amoeba forMysql软件.这个软件致力于MySQL的分布式数据库前端代理层,它主要在应用层访问MySQ ...

  4. MHA+ProxySQL 读写分离高可用

    文档结构如下: 1.ProxySQL说明 ProxySQL是mysql的一款中间件的产品,是灵活的mysql代理层,可以实现读写分离,支持query路由器的功能,支持动态指定sql进行缓存,支持动态加 ...

  5. windows下Redis 主从读写分离部署

    原文:windows下Redis 主从读写分离部署 1.可直接下载window下的运行文件(下面这个链接) 也可以浏览github 查看相应的版本说明文档 https://github.com/Ser ...

  6. ProxySQL实现Mysql读写分离 - 部署手册

    ProxySQL是一个高性能的MySQL中间件,拥有强大的规则引擎.ProxySQL是用C++语言开发的,也是percona推的一款中间件,虽然也是一个轻量级产品,但性能很好(据测试,能处理千亿级的数 ...

  7. MySQL ProxySQL读写分离使用初探

    目的 在美团点评DBProxy读写分离使用说明文章中已经说明了使用目的,本文介绍ProxySQL的使用方法以及和DBProxy的性能差异.具体的介绍可以看官网的相关说明,并且这个中间件也是percon ...

  8. ProxySQL读写分离

    我们首先看一下自己的环境: MHA已经搭建: master: slave: slave: MHA manager在172.16.16.34,配置文件如下: [root@localhost bin]# ...

  9. ProxySQL 读写分离实践

    前言 ProxySQL是一个高性能的MySQL中间件,拥有强大的规则引擎.具有以下特性: 连接池,而且是 multiplexing 主机和用户的最大连接数限制 自动下线后端DB 延迟超过阀值 ping ...

  10. Proxysql读写分离配置

    ProxySQL是Percona主推的读写分离中间件,下载地址为: https://www.percona.com/downloads/proxysql/ 一.安装 1:下载 wget https:/ ...

随机推荐

  1. 从一条巨慢SQL看基于Oracle的SQL优化(重磅彩蛋+PPT)

    本文根据DBAplus社群第110期线上分享整理而成,文末还有好书送哦~ 讲师介绍 丁俊 新炬网络首席性能优化专家 SQL审核产品经理 DBAplus社群联合发起人.<剑破冰山-Oracle开发 ...

  2. event.stopPropagation(),event.preventDefault()和return false的区别

    event.stopPropagation(),event.preventDefault()和return false的区别 1.event.stopPropagation()方法 这是阻止事件的冒泡 ...

  3. plsql developer 安装

    PLSQL Developer 安装分以下几步: 一.下载Oracle客户端 PLSQL Developer是通过oracle client连上Oracle server的. http://www.o ...

  4. SQL复制数据表 (select * into 与 insert into)

    select * into 目标表名 from 源表名 insert into 目标表名(fld1, fld2) select fld1, 5 from 源表名 以上两句都是将 源表 的数据插入到 目 ...

  5. Runtime Services

    Python Runtime Services — Python 3.7.2 documentation https://docs.python.org/3/library/python.html

  6. Mysql undo redo 总结

  7. python fabric实现远程操作和部署示例

    https://www.jb51.net/article/48434.htm 近期接手越来越多的东西,发布和运维的工作相当机械,加上频率还蛮高,导致时间浪费还是优点多.修复bug什么的,测试,提交版本 ...

  8. BTree和B+Tree详解

    https://www.cnblogs.com/vianzhang/p/7922426.html B+树索引是B+树在数据库中的一种实现,是最常见也是数据库中使用最为频繁的一种索引.B+树中的B代表平 ...

  9. DBGridEh表尾显示合计 .....

    设置如下就可以了..... FooterRowCount  : 1 SumList--------Active:=true 双击 DBGridEh  加入所需要的列....然后在 需要合计的..... ...

  10. 关于ADC采集

    对于ADC采集,想问的一些问题 1.如何初始化? 需要初始化 2.哪里可以看到是多少位采集? 3.8位ADC采集的误差是多少? 4.基准电压从哪里取?