MyCat入门

1 环境准备

      (1)下载解压后可直接使用

      (2)配置文件的修改 首先打开server.xml文件,将其里面的user修改为:外部访问的用户和密码设置。

<user name="root" defaultAccount="true">
		<property name="password">123456</property>
		<property name="schemas">test</property>
		<property name="defaultSchema">test</property>
		<!--No MyCAT Database selected 错误前会尝试使用该schema作为schema,不设置则为null,报错 -->
		
		<!-- 表级 DML 权限设置 -->
		<!-- 		
		<privileges check="false">
			<schema name="test" dml="0110" >
				<table name="tb01" dml="0000"></table>
				<table name="tb02" dml="1111"></table>
			</schema>
		</privileges>		
		 -->
	</user>

(3)修改 schema.xml 文件 主要配置数据源

这里test就是我们对外声称的我们有数据库的名称  必须和server.xml中的用户指定的数据库名称一致

<schema name="test" checkSQLschema="true" sqlMaxLimit="100" randomDataNode="dn1">
		<!-- auto sharding by id (long) -->
		<!--splitTableNames 启用<table name 属性使用逗号分割配置多个表,即多个表使用这个配置-->
		<table name="user" dataNode="dn1,dn2,dn3" rule="auto-sharding-long" splitTableNames ="true"/>
		<!-- <table name="oc_call" primaryKey="ID" dataNode="dn1$0-743" rule="latest-month-calldate"
			/> -->
	</schema>
	<!-- <dataNode name="dn1$0-743" dataHost="localhost1" database="db$0-743"
		/> -->
	<dataNode name="dn1" dataHost="localhost1" database="test" />
	<dataNode name="dn2" dataHost="localhost2" database="test" />
	<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="0"
			  writeType="0" dbType="mysql" dbDriver="jdbc" switchType="1"  slaveThreshold="100">
		<heartbeat>select user()</heartbeat>
		<!-- can have multi write hosts -->
		<writeHost host="hostM1" url="localhost:3306" user="root"
				   password="1234">
		</writeHost>
		<!-- <writeHost host="hostM2" url="localhost:3316" user="root" password="123456"/> -->
	</dataHost>
<dataHost name="localhost2" maxCon="1000" minCon="10" balance="0"
			  writeType="0" dbType="mysql" dbDriver="jdbc" switchType="1"  slaveThreshold="100">
		<heartbeat>select user()</heartbeat>
		<!-- can have multi write hosts -->
		<writeHost host="hostM1" url="10.10.10.10:3306" user="oscp"
				   password="123456">
		</writeHost>
		<!-- <writeHost host="hostM2" url="localhost:3316" user="root" password="123456"/> -->
	</dataHost>

这里配置了两个数据源: localhost1  跟localhost2。基本配置完成

2  数据源的准备

本地准备一个mysql的数据库,并建立表user,插入相应的数据,同时在服务器环境上同时建立相同的数据库,且数据库表名字跟字段跟本地的保持一致。

本地 表:

服务器 上表:

3 mycta的启动和停止

(1)停止

(2)启动

进入到bin目录下: 执行 mycat start 脚本

若启动失败,需要去log目录下查看启动失败原因,大部分原因是配置出错。

3   连接mycat

4 Mycat 是如何是做字段的分片的

     (1)首先java应用传入一个sql语句,mycat会对sql进行拦截,例如 insert  user (id ,name)  values(1,'x')

     (2) 判断插入的表配置了分片字段与分片方法,例如id按照奇偶,奇插入数据库1,偶数插入数据库2,然后读数据的时候,根据分片字段去相应的数据库中读。

     5 架构图与其他产品的对比

 

6 mycat 不适用的场景

非分片字段查询

MyCAT中的路由结果是通过分片字段和分片方法来确定的,如果查询条件是分片字段,查询将路由到某个具体的分片上;如果查询条件没有分片字段,MyCAT无法计算路由,便发送到所有节点,随着节点的增多,会消耗更多的数据库资源;

分页排序问题:消耗大量的计算资源;

无法实现任意表join,必须确保相关联的表的关联字段具有相同的分布;

MyCat无法实现事务强一直性;

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值