数据库集群之路二 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数据库集群进行正确配置,我前两天在相关网站 ...
随机推荐
- python学习之文件读写入门(文件读的几种方式比较)
1.文件读写简单实例:(以w写的方式打开一个文件,以r读一个文件) # Author : xiajinqi # 文件读写的几种方式 # 文件读写 f = open("D://test.txt ...
- 从零开始一个http服务器(二)-请求request解析
从零开始一个http服务器 (二) 代码地址 : https://github.com/flamedancer/cserver git checkout step2 解析http request 观察 ...
- LeetCode初级算法的Python实现--动态规划
动态规划的本质是递归:所以做题之前一定要会递归:递归式就是状态转移方程:这里将会介绍使用动态规划做题的思维方式. 统一的做题步骤: 1.用递归的方式写出代码:(此方法写的代码在leetcode中一定会 ...
- 使用 Vim 搭建 JavaScript 开发环境
原文链接: https://spacevim.org/cn/use-vim-as-a-javascript-ide/ SpaceVim 是一个模块化的 Vim IDE,针对 JavaScript 这一 ...
- [BZOJ3563&3569]DZY Loves Chinese
bzoj 加强版 sol 其实前一题还有一种解法的,具体方法请见bzoj讨论版. 以下是正解(?) 建一棵生成树. 考虑什么时候图会不连通:当且仅当存在一条树边被删除,同时所有覆盖了他的非树边也被删除 ...
- spring源码-bean之增强初始化-3
一.ApplicationContext的中文意思是“应用上下文”,它继承自BeanFactory接口,除了包含BeanFactory的所有功能之外,在国际化支持.资源访问(如URL和文件).事件传播 ...
- CentOS 5/6上安装EPEL源
转自:http://www.vckai.com/p/25 EPEL 是什么? EPEL (Extra Packages for Enterprise Linux,企业版Linux的额外软件包) 是Fe ...
- Ruby 基础教程1-4
1.对象 数值对象 字符串对象 数组对象,散列对象 正则表达式对象 时间对象 文件对象 符号对象 2.类 Numeric String Array Hash Regexp File Symbol 3. ...
- Linux命令大全(非常全,史上最全)
最近学习Linux,最大的体验就是它的很多东西都需要由命令来进行控制,下面是我总结的一些命令,供大家参考: 系统信息 arch 显示机器的处理器架构 uname -m 显示机器的处理器架构 una ...
- [Clr via C#读书笔记]Cp6类型和成员基础
Cp6类型和成员基础 成员 常量:字段(静态字段和实例字段):实例构造器:类型构造器(用于静态字段的构造):方法(静态方法和实例方法):操作符重载(本质是一个方法):转换操作符:属性(本质还是方法): ...