数据库集群之路二 MYCAT
windows下安装配置并使用mycat
参考:http://www.cnblogs.com/parryyang/p/5758087.html
一 下载windows版本
https://github.com/MyCATApache/Mycat-download/tree/master/1.4-RELEASE
1 下载完成,将压缩文件解压到你想要放置的目标盘,比如我放在了d盘
2 配置mycat到环境变量
3 安装java
凡是开发的同学都差不多会安装java吧,至于怎么在环境变量中配置java自己不会就百度吧,因为mycat是java开发的 呵呵你懂的
二 配置mycat
2.1 配置server.xml
在conf文件夹下面找到server.xml并打开,下面是我的配置
<!DOCTYPE mycat:server SYSTEM "server.dtd">
<mycat:server xmlns:mycat="http://org.opencloudb/">
<system>
<property name="defaultSqlParser">druidparser</property>
<property name="charset">utf8mb4</property>
<property name="mutiNodeLimitType">1</property>
<property name="mutiNodePatchSize">100</property>
<property name="processors">32</property>
<property name="processorExecutor">32</property>
<property name="serverPort">8066</property>
<property name="managerPort">9066</property>
<property name="idleTimeout">300000</property>
<property name="bindIp">0.0.0.0</property>
<property name="frontWriteQueueSize">4096</property>
<property name="processors">32</property>
</system>
<user name="test">
<property name="password">test</property>
<property name="schemas">MSSP</property>
</user> <user name="user">
<property name="password">user</property>
<property name="schemas">MSSP</property>
<property name="readOnly">true</property>
</user>
</mycat:server>
server.xml里面就是配置mycat这个服务器的相关参数,比如说user就是配置一下你想要登陆并使用mycat的用户,并且指定这个用户可以操作哪一个逻辑数据库,和权限,这个好理解吧
2.2 读写分离配置
找到schema.xml这个文件并打开,配置一下逻辑数据库,并且这个逻辑数据对应要映射的数据节点,数据节点对应映射真实的物理数据库主机
<?xml version="1.0"?>
<!DOCTYPE mycat:schema SYSTEM "schema.dtd">
<mycat:schema xmlns:mycat="http://org.opencloudb/"> <schema name="MSSP" checkSQLschema="false" sqlMaxLimit="100" dataNode="dn1"> </schema>
<!-- <dataNode name="dn1$0-743" dataHost="localhost1" database="db$0-743"
/> -->
<dataNode name="dn1" dataHost="localhost1" database="xsmart_mssp_basedatacenter" />
<!-- <dataNode name="dn2" dataHost="localhost1" database="db2" />
<dataNode name="dn3" dataHost="localhost1" database="db3" /> -->
<!--<dataNode name="dn4" dataHost="sequoiadb1" database="SAMPLE" />
<dataNode name="jdbc_dn1" dataHost="jdbchost" database="db1" />
<dataNode name="jdbc_dn2" dataHost="jdbchost" database="db2" />
<dataNode name="jdbc_dn3" dataHost="jdbchost" database="db3" /> -->
<dataHost name="localhost1" maxCon="1000" minCon="10" balance="1"
writeType="0" dbType="mysql" dbDriver="native" switchType="1" slaveThreshold="100">
<heartbeat>show slave status</heartbeat>
<!-- can have multi write hosts -->
<writeHost host="hostM1" url="192.168.50.192:5869" user="root"
password="P@$$w0rd">
<!-- can have multi read hosts -->
<readHost host="hostS1" url="192.168.50.148:3306" user="root" password="P@$$w0rd" />
</writeHost>
<!-- <writeHost host="hostM2" url="192.168.50.215:3306" user="root"
password="P@$$w0rd" /> -->
</dataHost>
<!--
<dataHost name="sequoiadb1" maxCon="1000" minCon="1" balance="0" dbType="sequoiadb" dbDriver="jdbc">
<heartbeat> </heartbeat>
<writeHost host="hostM1" url="sequoiadb://1426587161.dbaas.sequoialab.net:11920/SAMPLE" user="jifeng" password="jifeng"></writeHost>
</dataHost> <dataHost name="oracle1" maxCon="1000" minCon="1" balance="0" writeType="0" dbType="oracle" dbDriver="jdbc"> <heartbeat>select 1 from dual</heartbeat>
<connectionInitSql>alter session set nls_date_format='yyyy-mm-dd hh24:mi:ss'</connectionInitSql>
<writeHost host="hostM1" url="jdbc:oracle:thin:@127.0.0.1:1521:nange" user="base" password="123456" > </writeHost> </dataHost> <dataHost name="jdbchost" maxCon="1000" minCon="1" balance="0" writeType="0" dbType="mongodb" dbDriver="jdbc">
<heartbeat>select user()</heartbeat>
<writeHost host="hostM" url="mongodb://192.168.0.99/test" user="admin" password="123456" ></writeHost> </dataHost> <dataHost name="sparksql" maxCon="1000" minCon="1" balance="0" dbType="spark" dbDriver="jdbc">
<heartbeat> </heartbeat>
<writeHost host="hostM1" url="jdbc:hive2://feng01:10000" user="jifeng" password="jifeng"></writeHost> </dataHost> --> <!-- <dataHost name="jdbchost" maxCon="1000" minCon="10" balance="0" dbType="mysql"
dbDriver="jdbc"> <heartbeat>select user()</heartbeat> <writeHost host="hostM1"
url="jdbc:mysql://localhost:3306" user="root" password="123456"> </writeHost>
</dataHost> -->
</mycat:schema>
在datahost这个节点里面配置了读写的主机以及他们的用户和密码,mycat的标配就是两个master(主库)2个从库(slave),他们的实际关系是,主一才是真正的master,而主二作为主一的备胎,在主一正常是他会与主一同步,其他两个从库再与主二同步,如果主一不行了,就切换到主二,主一恢复了他又变成了主二,所以这样尽可能的保证数据库高可用吧,至于读写压力那是负载均衡的事情了
2.3 启动mycat
在有前面的配置过后进入mycat所在目录运行startup_nowrap.bat文件,查看log,查看mycat是否正常启动,如果有xml解析错误请查看自己xml有些地方是不是有语法错误,如果有一些数据库物理主机联不通请看下ip,端口这些配对没有。。。其他就没有了哦
三 主从复制于主从分离
可以说主从复制是主从分离的前提条件,mycat并不做主从复制,主从复制是mysql本身提供的机制,所以说我们需要先将主从复制在mysql之间跑起来,至于主从复制在
http://www.cnblogs.com/rjjs/p/7452766.html有配置作为参考,在主从复制正常过后我们再来启动mycat,经过这个过程我们已经搭建好主从数据库,建立好主从复制
四 验证主从分离
原有的mysql客户端不行了啥,因为mycat不是标准的mysql协议,呵呵我没搞懂为啥不搞成标准,就因为这个不标准搞出来很多蛋疼的事情比如orm用不了了 ~~~,于是你需要下载一个新的客户端navicat for mysql
http://dlsw.baidu.com/sw-search-sp/soft/0f/24312/navicat_trial_11.1.20.0.1449226634.exe,登陆注意登陆的时候就是使用server.xml里面你自己配置的用户名和密码,但是端口是8066专门给客户端使用的端口 哈哈
这个客户端就是作为mycat这个代理服务器的客户端,我们在这个客户端里面与使用mysql客户端基本上一样,比如sql语句随便里搞
可以先查询一下某个表然后去日志里面看,也可以写一条数据然后去看看主从数据库是否同步了,自己验证吧,哈哈 是不是好坑。
五 关于编程
说起编程就蛋疼了,特别是你是一名net程序员哈哈,原有的mysql.data.dll这个ado.net的驱动失效了,前面说过mycat非标准mysql协议 哈哈 蛋疼吧,咋办咋办呢?没有驱动了接口也就没有了 蛋疼不?话说早就已经有人搞了一个驱动 http://www.1234.sh/post/mycat-getting-started-cn,写到这里我们原有的什么nhibernate,什么ef都是基于ado.net这种orm工具基本上是不行了,而人家java领域的hibernate3就原封不动的支持mycat,net程序员是不是又被呵呵了,是的,mycat的研究告一段落,这个mysql代理服务器虽然很强大然而对于net来说实用性不是太高,不能兼容orm就是他的不兼容mysql协议搞得鬼吧,如果要用就得抛弃现有的orm,改动太多了,希望再找到好一点的mysql代理工具吧
数据库集群之路二 MYCAT的更多相关文章
- MyCAT+MySQL 搭建高可用企业级数据库集群——第2章 MyCat入门
2-1 章节综述 2-2 什么是MyCat 2-3 什么是数据库中间层 2-4 MyCat的主要作用 2-5 MyCat基本元素 2-6 MyCat的安装 2-1 章节综述 1.掌握Mycat的基础概 ...
- MyCAT+MySQL 搭建高可用企业级数据库集群——第3章 MyCat核心配置讲解
3-1 章节综述 3-2 常用配置文件间的关系 3-3 server.xml配置详解 3-4 log4j2.xml配置文件 3-5 rule.xml 3-6 常用分片算法(上) 3-7 常用分片算法( ...
- 十四、linux-MySQL的数据库集群读写分离及高可用性、备份等
一.数据库集群及高可用性 二.mysql实现读写分离 mysql实现读写分离有多种方式: 1)代码语言(php\python\java等)层面实现读写分离,找开发进行实现. 2)通过软件工具实现读写分 ...
- mycat数据库集群系列之数据库多实例安装
mycat数据库集群系列之数据库多实例安装 最近在梳理数据库集群的相关操作,现在花点时间整理一下关于mysql数据库集群的操作总结,恰好你又在看这一块,供一份参考.本次系列终结大概包括以下内容:多数据 ...
- mycat数据库集群系列之mysql主从同步设置
最近在梳理数据库集群的相关操作,现在花点时间整理一下关于mysql数据库集群的操作总结,恰好你又在看这一块,供一份参考.本次系列终结大概包括以下内容:多数据库安装.mycat部署安装.数据库之读写分离 ...
- mycat数据库集群系列之mycat读写分离安装配置
最近在梳理数据库集群的相关操作,现在花点时间整理一下关于mysql数据库集群的操作总结,恰好你又在看这一块,供一份参考.本次系列终结大概包括以下内容:多数据库安装.mycat部署安装.数据库之读写分离 ...
- 聊一聊mycat数据库集群系列之双主双重实现
最近在梳理数据库集群的相关操作,现在花点时间整理一下关于mysql数据库集群的操作总结,恰好你又在看这一块,供一份参考.本次系列终结大概包括以下内容:多数据库安装.mycat部署安装.数据库之读写分离 ...
- docker应用-6(mysql+mycat 搭建数据库集群)
上一节,通过使用overlay网络,搭建了跨主机的docker容器集群.下面,在这个跨主机的docker容器集群环境下,搭建mysql 数据库集群. mysql主从自动备份和自动切换 从数据安全性考虑 ...
- MySQL数据库集群进行正确配置步骤
MySQL数据库集群进行正确配置步骤 2010-06-09 10:47 arrowcat 博客园 字号:T | T 我们今天是要和大家一起分享的是对MySQL数据库集群进行正确配置,我前两天在相关网站 ...
随机推荐
- transform Vs Udf
在鞋厂的第一个任务,拆表.需要把订单表按照开始日期和结束日期拆分成多条记录,挺新鲜的~ transform方式,使用到了python. (1)把hive表的数据传入,通过python按照日期循环处理, ...
- 快排(golang实现) 递归方法
递归方法,逻辑简洁清晰.这个算法还是很重要的,需要重点记忆理解,面试经常考手写.据说是与傅里叶变换等并称“20世纪十大算法”.https://blog.csdn.net/v_JULY_v/articl ...
- GeekOS课程设计-project1
参考:https://blog.csdn.net/qq_35008279/article/details/78984561?tdsourcetag=s_pcqq_aiomsg 补充:如果按照参考博客还 ...
- Shell环境变量与特殊变量详解
1)变量类型 1)变量可分为俩类:环境变量(全局变量),和普通变量(局部变量), 环境变量也称为全局变量,可以在创建他们的Shell及其派生出来的任意子进程Shell中使用,环境变量又可以分为自定义环 ...
- 实验1 查看CPU和内存,用机器指令和汇编指令编程
·实验任务 (1)使用Debug,用E命令和A命令以两种方式将指令写入内存 机器码 汇编指令 b8 20 4e mov ax,4e20h 05 16 14 add ax,14 ...
- 20145234黄斐《Java程序设计》第四周学习总结
教材学习内容总结 第六章部分 - 继承与多态 何谓继承 继承面向对象中,子类继承父类,避免重复的行为定义.一般来说,父类的父类也称父类,且同一个子类只允许拥有一个父类,而同一个父类则可以拥有多个子类. ...
- nodejs 实现套接字服务
nodejs实现套接字服务 一 什么是套接字 1.套接字允许一个进程他通过一个IP地址和端口与另一个进程通信,当你实现对运行在同一台服务器上的两个不同进程的进程间通信或访问一个完全不同的服务器 ...
- hdu1421搬寝室(动态规划)
搬寝室 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total Submiss ...
- FastJson - 从HttpEntity到Json
在使用java + httpClient施行API自动化时,不可避免地遇到了如下问题: 1. 用Http Response数据做断言: 2. 用上一个请求的Response内容,作为下一个请求的参数: ...
- 巧用浏览器F12调试器定位系统前后端bug
做测试的小伙伴可能用过httpwatch,firebug,fiddler,charles等抓包(数据包)工具,但实际上除了这些还有一个简单实用并的抓包工具,那就是浏览器的F12调试器. httpwat ...