功能:
1.具有SQL白名单(防SQL注入)及IP白名单功能的SQL防火墙软件
2.数据库故障切换
3.读写分离
4.分库分表
 
 
一、下载
oneproxy-rhel5-linux64-v6.0.0-ga.tar.gz
 
二、部署
master: 192.168.0.181 hostname:cen01
slave: 192.168.0.182 hostname:cen02
oneproxy: 192.168.0.183 hostname:cen03
系统:全部是centos6.7
需要读写分离的库名称:mydata,表test01 (id int(3),name char(8)); 可不用先建好
 
总结:
1.master与slave安装好MYSQL,已做好主从复制,oneproxy不用安装MYSQL
2.当外来业务访问数据库时,只需直接访问oneproxy机器的:3307端口就行了。它会直接调度master和slave节点。
mysql -uuser01 -puser01 -P3307 -h192.168.0.183
 
1.将软件包解压
tar -xzf oneproxy-rhel5-linux64-v6.0.0-ga.tar.gz -C /usr/local
 
2.配置oneproxy
cd /usr/local/oneproxy
vim ./demo.sh
将ONEPROXY_HOME的路径改为软件部署路径:/usr/local/oneproxy
如下图所示:
 
vim oneproxy.service
将ONEPROXY_HOME的路径改为软件部署的路径:/usr/local/oneproxy
如下图所示:
 
vim conf/proxy.conf
event-threads = 4     //并发线程数,最大允许48个线程。通常可以设为CPU Core数量的两倍
proxy-address = :3307    //设置对外提供访问的端口
mysql-version = 5.6.25    //设置mysql版本
proxy-slave-addresses.1 = 192.168.0.182:3306@server1      //192.168.0.182为slave的IP,server1为服务组名称,任意写
proxy-slave-addresses.2 = 192.168.0.184:3306@server1      //填写第二个slave的IP,如果有的话
proxy-master-addresses.1 = 192.168.0.181:3306@server1      //192.168.0.181为master的IP,server1为服务组名称,任意写
proxy-group-policy = server1:read_slave      //设置策略为:在master写,在slave读
proxy-user-list = user01/1378F6CC3A8E8A43CA388193FBED5405982FBBD3@mydata          //user01为用户名,用于给oneproxy登录后端MYSQL节点/后面的字符串是密码,mydata是要读写分离的数据库名称
repadmin-username = repadmin          //指定复制管理帐号的用户名,后端MYSQL节点都要建
repadmin-password = 1378F6CC3A8E8A43CA388193FBED5405982FBBD3           //指定复制帐号的密码,三台mysql都要有
保存退出
 
 
登录所有后端MYSQL(master/slave节点),执行:
由于已经设置了主从复制,所以只对master添加用户即可,创建用户操作会同步到slave
create user user01;
grant all on mydata.* to user01@'%' identified by 'user01';
create user 'repadmin'@'%' identified by 'user01';           //oneproxy可能通过该帐号在后端MYSQL节点执行:show master/slave status
grant replication slave on *.* to 'repadmin'@'%';        //以便用来取得复制的运行数据
grant replication client on *.* to 'repadmin'@'%';
flush privileges;
退出
 
三、修改系统环境(master/slave/onepxory节点)
echo 1 > /proc/sys/net/ipv4/tcp_tw_reuse
echo 1 > /proc/sys/net/ipv4/tcp_tw_recycle
ulimit -n 65535
 
echo "echo 1 > /proc/sys/net/ipv4/tcp_tw_reuse" >> /etc/profile
echo "echo 1 > /proc/sys/net/ipv4/tcp_tw_recycle" >> /etc/profile
echo "ulimit -n 65535" >> /etc/profile
 
iptables -I INPUT -m state --state NEW -p tcp --dport 3307 -j ACCEPT
iptables -I INPUT -m state --state NEW -p tcp --dport 4041 -j ACCEPT
iptables -I INPUT -m state --state NEW -p tcp --dport 8080 -j ACCEPT
service iptables save
 
四、启动oneproxy
cd /usr/local/oneproxy
chmod 755 demo.sh
./demosh
./oneproxy.service restart
 
五、访问oneproxy管理界面
(oneproxy不必安装web服务)
 
六、读写分离检验
在master或slave或其它任意一台非集群的机器执行:
mysql -utest -ptest -h192.168.0.183 -P3307 -e"select @@hostname;"       //往oneproxy提交查询操作,显示的是slave主机名
 
 
mysql -utest -ptest -h192.168.0.183 -P3307 -e"begin;select @@hostname;commit;"       //往oneproxy提交写操作,显示的是master主机名
 
可以进一步校验:
在master或slave或其它任意一台机,或者其它连接mysql的工具(Navicat),执行如下命令:
mysql -uuser01 -puser01 -P3307 -h192.168.0.183 -e"insert into mydata.test01 values (5,'aaaaa')"
 
在master和slave的数据库中可以查询到以下结果:
 
 
当执行:drop table test01时出现报错:
ERROR 1044 (42000): Access denied due to security policy, DDL disabled or DML restricted!
 
解释:由于OneProxy为了安全起见,默认是禁止DDL语句的。
解决办法:从OneProxy管理端口,运行如下命令:
mysql -uadmin -pOneProxy -P4041 -h192.168.0.183 -e"set gaccess server1 0;"      //0表示允许创建/删除表,1表示不允许创建/删除
此时就可以删除或者创建表了。
 
登录管理界面,可看到有相应记录:
 
 
可见,当往oneproxy写数据时,会自动同步到master上,而master通过主从复制功能将数据同步到slave。
 
检查后端数据库节点状态:
mysql -uadmin -pOneProxy -P4041 -h192.168.0.183 --protocol=TCP       //进入管理端口(默认端口为4041),IP为部署了oneproxy的IP
list help;     //显示帮助
list backend;      //输入此内容,回车
IS_M:表示这台机器是否是一台Master
IS_S:表示是否为一台Slave,
MFile:表示主库上的Binlog位置
DFile:表示备机上IO线程
RFile:SQL线程处理的位置
 
 
部署完成。
如有错误,可查看log/proxy.log日志。

利用oneproxy实现mysql读写分离搭建笔记的更多相关文章

  1. Amoeba mysql读写分离搭建及介绍

    Amoeba mysql读写分离搭建及介绍 推荐: http://blog.chinaunix.net/uid-20639775-id-154600.html

  2. OneProxy实现mysql读写分离

    OneProxy for MySQL可以复用不同应用到后端数据库的连接,有效降低数据库的并发连接数:可以即时踢除不可用的节点,将应用请求转发到其他可用节点,保证业务服务的稳定性. 可透明地将查询语句分 ...

  3. 三十五.MySQL读写分离 MySQL多实例 、MySQL性能调优

    1.实现MySQL读写分离 搭建一主一从结构 配置maxscale代理服务器 测试分离配置   1.1 搭建一主一从结构 192.168.4.51 主 192.168.4.52 从 测试OK   1. ...

  4. 提高性能,MySQL 读写分离环境搭建

    这是松哥之前一个零散的笔记,整理出来分享给大伙! MySQL 读写分离在互联网项目中应该算是一个非常常见的需求了.受困于 Linux 和 MySQL 版本问题,很多人经常会搭建失败,今天松哥就给大伙举 ...

  5. 提高性能,MySQL 读写分离环境搭建(一)

    这是松哥之前一个零散的笔记,整理出来分享给大伙! MySQL 读写分离在互联网项目中应该算是一个非常常见的需求了.受困于 Linux 和 MySQL 版本问题,很多人经常会搭建失败,今天松哥就给大伙举 ...

  6. Mysql多实例安装+主从复制+读写分离 -学习笔记

    Mysql多实例安装+主从复制+读写分离 -学习笔记 .embody{ padding:10px 10px 10px; margin:0 -20px; border-bottom:solid 1px ...

  7. mysql读写分离--一主多从,冗余存储

    转载了https://blog.csdn.net/u013421629/article/details/78793966 https://blog.csdn.net/justdb/article/de ...

  8. amoeba实现MySQL读写分离

    amoeba实现MySQL读写分离 准备环境:主机A和主机B作主从配置,IP地址为192.168.131.129和192.168.131.130,主机C作为中间件,也就是作为代理服务器,IP地址为19 ...

  9. 使用Atlas实现MySQL读写分离+MySQL-(Master-Slave)配置

    参考博文: MySQL-(Master-Slave)配置  本人按照博友北在北方的配置已成功  我使用的是 mysql5.6.27版本. 使用Atlas实现MySQL读写分离 数据切分——Atlas读 ...

随机推荐

  1. sublime编写markdownm

    sublime编写markdownm 以前用有道云笔记,找了半天更改字体大小,结果还找不 到,那个字实在是太小了,像我这种有强迫症的患者,实 在受不了简约风格的有道云,所以上网找了与和诺插件并 受到一 ...

  2. final文案+美工展示

    作业要求:https://edu.cnblogs.com/campus/nenu/SWE2017FALL/homework/1438 团队介绍:thunder 组成员及各位博客地址: 1.王航:htt ...

  3. Visual Studio win平台 AI环境搭建

    内容提要:我觉得难点主要出在下载上,程序跑的都挺流畅的.下载有时会失败. 1.下载安装git.这一步主要为了下载示例和自动安装环境的python代码,直接去github上用网页下载也是一样的,git不 ...

  4. 20162328蔡文琛 大二week01

    教材学习内容总结 算法+程序机构=程序 渐进复杂度称为算法的阶. 算法分析是计算机科学的基础课题. 增长函数显示了与问题大小相关的时间或空间的利用率. 算法的阶由算法增长函数的主项决定. 算法的阶给出 ...

  5. 福大软工 · 第七次作业 - 需求分析报告(404 Note Found队)

    目录 组队后的团队项目的整体计划安排 项目logo及思维导图 项目logo 思维导图 产品思维导图 产品思维导图-引导 产品思维导图-后端数据处理.存储 产品思维导图-短信识别 产品思维导图-智能分析 ...

  6. ADT图及图的实现及图的应用

    图: 图中涉及的定义: 有向图: 顶点之间的相关连接具有方向性: 无向图: 顶点之间相关连接没有方向性: 完全图: 若G是无向图,则顶点数n和边数e满足:0<=e<=n(n-1)/2,当e ...

  7. sql中exists和not exists的用法

    该文转载自:http://www.cnblogs.com/mytechblog/articles/2105785.html sql中exists,not exists的用法 exists : 强调的是 ...

  8. 用windbg检查.NET线程池设置

    比如我们在machine.config中进行了这样的设置(8核CPU): <processModel maxWorkerThreads="100" maxIoThreads= ...

  9. Beta阶段冲刺前的准备

    Beta阶段冲刺前的准备 凡事预则立,在Beta开始前,以小组为单位,在敏捷冲刺前发布一篇博客,描述: 1. 讨论组长是否重选的议题和结论 经过我们小组在周二下午的会议中有重新认真的考虑了是否要更换组 ...

  10. [转帖]“剖开” LinuxONE 和 Exadata,架构专家解读里面到底有什么

    “剖开” LinuxONE 和 Exadata,架构专家解读里面到底有什么 http://server.zhiding.cn/server/2018/0914/3111044.shtml    说起I ...