您的位置:首页 > 其它

mycat中全局表的实战应用简析(上)

2017-09-28 16:53 411 查看
<table name="news" primaryKey="id"  type="global" dataNode="dataNode1" />


name表名称;

primaryKey为该表的主键

type=”global” 是啥?

有几个特性:

1、和具体物理表一一对应

2、多节点配置时出现 新增、修改操作时,则mycat会对所有节点(dataNode),发送该操作。保证所有节点里面的 全局表保持同步。

修改
schema.xml
如下:

<?xml version="1.0"?>
<!DOCTYPE mycat:schema SYSTEM "schema.dtd">
<mycat:schema xmlns:mycat="http://org.opencloudb/">
<schema name="mydbname" checkSQLschema="false" sqlMaxLimit="100">
<!-- type="global" 全局表 -->
<table name="news_class" primaryKey="class_id" autoIncrement="true"  type="global" dataNode="dataNode1" />
</schema>

<!-- 节点配置 -->
<dataNode name="dataNode1" dataHost="dataHost1" database="test" />

<!-- balance="0" -->
<dataHost name="dataHost1" maxCon="1000" minCon="10" balance="0"
writeType="0" dbType="mysql" dbDriver="native" switchType="1"  slaveThreshold="100">
<heartbeat>select user()</heartbeat>
<writeHost host="hostM1" url="10.211.55.13:3306" user="root" password="admin888"> </writeHost>
</dataHost>

</mycat:schema>


我这里只有一个节点(可以多个节点)

修改了配置文件 记得重启mycat服务哦

目前我们还没有配置文件中的
news_class
数据表,我们需要新建这个表。

我这里使用终端进入mycat:

mysql -u mycat1 -p -h 127.0.0.1 -P 8066
#mycat1 这个是用户名是在server.xml中配置的 不要忘记哦




选择数据库:

mysql> use mydbname;
#mydbname schema.xml中配置的 你记得?


创建表:

CREATE TABLE `news_class` (
`class_id` int(11) UNSIGNED NOT NULL AUTO_INCREMENT,
`class_name` char(255),
PRIMARY KEY (`class_id`)
);


做了这些到底在干嘛啊

想一想:刚才我们是连接mycat里创建的
news_class
数据库,可是现在不仅mycat里有该表,我们的
10.211.55.13
这个服务器也有这个表了(如果你配置的多节点,那么就都有)



到这里,差不多就知道 全局表 是个什么东西了。

在实战中

1、不经常产生修改的表,如配置表、类别表以及数据量不是很大的表 才会设置成全局表。

2、全局表修改时,会对所有节点进行同样的修改,保证同步

3、读取时,则随意从一个节点读取
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: