zoukankan      html  css  js  c++  java
  • 数据库集群之路二 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代理工具吧

  • 相关阅读:
    P4363 [九省联考2018]一双木棋chess 状压DP
    P5290 [十二省联考2019] 春节十二响 贪心
    P3747 [六省联考2017]相逢是问候 欧拉公式
    P5443 [APIO2019]桥梁 操作分块+可撤销并查集
    P4146 序列终结者 FHQ_TREAP
    108. Convert Sorted Array to Binary Search Tree
    神经网络中Epoch、Iteration、Batchsize相关理解
    905. Sort Array By Parity
    100. Same Tree
    538. Convert BST to Greater Tree
  • 原文地址:https://www.cnblogs.com/rjjs/p/7458502.html
Copyright © 2011-2022 走看看