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、读取时,则随意从一个节点读取
相关文章推荐
- mycat全局表实战应用简析(下):多节点自增字段的处理
- 高并发之 - 全局有序唯一id Snowflake 应用实战
- Mycat学习实战-Mycat全局主键
- Mycat学习实战-Mycat全局主键
- (android实战)应用在线版本更新
- Redis实战应用举例
- 心勃勃的NoSQL新贵 MongoDB应用实战
- 聊聊xp和scrum在实战中的应用问题
- 移动应用实战(移动OA)之三_客户端与服务端数据通讯
- 【AJAX】——实战应用,完整Demo
- 使用Fragment完成Tab选项卡-Android Fragment应用实战
- 应用集成实战系列:服务总线中的服务补偿机制
- 微信小程序开发记账应用实战服务端之用户注册与登录-基于Yii2描述
- android联系人应用简析
- Servlet程序应用和实例之使用Cookie简析
- 全局热键在Delphi中的应用实例
- OpenDaylight与Mininet应用实战之 基本环境搭建
- 20170705L07-09-03老男孩Linux运维实战培训-Sersync实时同步软件实战应用指南06
- C#连接MongoDB数据库应用实战