基于proxy实现的mysql的读写分离

本文介绍了MySQL读写分离的基本原理和重要性,并详细阐述了如何通过proxy实现主从复制和读写分离。在环境部署中,master、slave和proxy分别位于不同的服务器上。配置包括安装mysql-proxy、用户授权以及使用lsof进行监控。通过proxy,即使连接到slave,也能确保写操作在master上执行,从而实现真正的读写分离。
摘要由CSDN通过智能技术生成

什么是读写分离?

读写分离,基本的原理是让主数据库处理事务性增、改、删操作(INSERT、UPDATE、DELETE),而从数据库处理SELECT查询操作。数据库复制被用来把事务性操作导致的变更同步到集群中的从数据库。
为什么要实现读写分离?

因为数据库的“写”(写10000条数据到oracle可能要3分钟)操作是比较耗时的。
但是数据库的“读”(从oracle读10000条数据可能只要5秒钟)。
所以读写分离,解决的是,数据库的写入,影响了查询的效率。
什么时候要读写分离?
数据库不一定要读写分离,如果程序使用数据库较多时,而更新少,查询多的情况下会考虑使用,利用数据库 主从同步 。可以减少数据库压力,提高性能。当然,数据库也有其它优化方案。memcache 或是 表折分,或是搜索引擎。都是解决方法。
主从复制和读写分离的原理:

环境部署:
Master——->server1:172.25.30.1
Slave———>server2:172.25.30.2
Proxy———>server3:172.25.30.3

一:实现mysql的主从复制:


安装mysql-proxy:

[root@server3 ~]# tar zxvf mysql-proxy-0.8.5-linux-glibc2.3-x86-64bit.tar.gz
[root@server3 ~]# cd /usr/local/mysql-proxy/
[root@server3 mysql-proxy]#mv mysql-proxy-0.8.5-linux-glibc2.3-x86-64bit /usr/local/mysql-proxy
[root@server3 mysql-proxy]# useradd -r mysql-proxy
[root@server3 mysql-proxy]# id mysql-proxy
uid=498(mysql-proxy) gid=498(mysql-proxy) groups=498(mysql-proxy)
[root@server3 mysql-proxy]# mkdir etc
[root@server3 mysql-proxy]# mkdir logs
[root
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值