###MyCat Release Notes ####1.6-RELEASE ###新功能
- 添加show @@directmemory监控命令
- 新增lock tables 功能
- reload @@config_all支持不影响当前事务
- prepare指令支持blob
- 分片表配置检查
- zk模块重构
###改进和修复
- 修复去库名bug
- 修复group by 结果集错误
- 处理关闭流问题,为日志输出增加堆栈打印
####1.6-BETA ###新功能
- 增加了用户db/table 表级的DML语句权限控制
- 重构原有隔离区,改为firewall
- 添加新路由规则,根据日期查询日志数据 冷热数据分布 ,最近n个月的到实时交易库查询,超过n个月的按照m天分片
###改进和修复
- change load data max column setting
- 修复堆外排序的若干错误等
- 修复durid-1.0.24 版本造成的防火墙BUG
- 修复prepare指令多节点返回错误和单节点返回错误
- 修复后端使用pg原生协议时当查询数据量大时原有读取方式 会出现 nio 的粘包问题.
- 解决数据类型COL_TYPE_LONG和row中列为null时,引起Mycat异常
- 修复后端pg原生协议时类型错误、统计函数错误、bufferpool使用等错误
- 统一定时器时间单位为毫秒
- 初步重构zk配置统一从myid.properties取
- 修复ShareJoin关联右表没执行
- 修复mergeColsMap空指针报错问题
- 修复schema.xml中 配置 checkSQLschema="true" ,sql语句中含schema时,有bug
- 修复查询语句表名中存在【`】符号时无法路由至对应分片
- 按天分片,跨头尾分片BUG修改
- 修复 日志路由规则错误
- 修改对于update语句中set子句包含分片字段更新语句的处理逻辑
####1.6-ALPHA ###新功能
- 非堆内存(Direct Memory)处理跨分片结果集的Merge/order by/group by/limit
- 两种基于zk的全局序列
- 停机扩容缩容工具,支持任意路由规则
- 全局表一致性检测
- server.xml中添加配置项让mycat可以设置要模拟的mysql的版本号
- 缓存池管理支持DirectByteBufferPool和ByteBufferArena切换
- 新的注解方式hint sql支持的格式/** mycat: */
- postgre的native协议支持
- 支持mysql和oracle存储过程,out参数、多结果集返回
- 预编译prepare的支持
- master/slave注解
- 库内分表特性
- 支持自生成ID的batchInsert
- 支持rails的set names 语句
- 新增show @@sql.resultset统计大结果集记录及其系统配置
- TxReadOnly支持
- 兼容PhpAdmin's 控制台管理,支持mysql information_schema 元数据返回
###改进和修复
- navicat stat sql bug
- PartitionByMod算法未考虑引号的问题
- 修复跨分片查询时空指针报错问题
- Allow % in user name, which is used in some cloud MySQL DB.
- 心跳切换的判断不应该判断读写分离的状态
- 当分库字段为uuid时,使用sharding-by-murmur规则配置主子表关系,导致主子表关联数据无法插入到同一个库中
- 监测数据库同步状态,在 switchType=-1或者1的情况下,也需要收集主从同步状态
- 优化SQLStat导致性能下降
- 后端连接切换或者挂掉修复
- 对于ShareJoin的bug修改。
- recieve rollback,but fond backend con is closed or quit
- 按月分片设置起始月份范围从而循环使用,对落此范围外的数据通过计算偏移得到目标分片
- Optimization: handling oom error in NIOReactor and BufferPool class
- Fixbug: a. Mycat hang problem b. SQL error and rollback blocked in
- Fix bug, do not have having clause when route to single node
- fix 遍历map的bug,事务隔离级别的优化,完善 index_to_charset.properties
- fix RouteStrategyFactory 线程安全问题 和 DefaultSqlInterceptor 导致的无法在末尾插入\字符的问题
- fix DefaultSqlInterceptor中为了支持foundationdb parser而进行的字符转换,导致无法插入 \
- 修改 tryExistsCon 函数支持 master/slave注解
- int to long 防止发生越界
- 主从同步切换 show slave status 的情况下, 修复 正常的 read host 不可用问题, 及stat 处的 bug 修正
####1.5-RELEASE ###新功能
- 支持常见mysql gui不填写默认dbname
- 支持navicat的showtable语句
- 支持show full table from
###改进和修复
- 修复 mycat 版本导致应用驱动识别错误无法支持毫秒
- 修复 分片节点 第一个节点不是默认节点时候 desc table 路由到默认节点的bug 表名大写转换
- 修复 去掉分号 bug 结尾-1 不是-2
- 测试:堆栈实现解析表名
- 修复 重新 xml dtd 验证失败问题
- SQL汇总统计 清理参数
####1.5-GA ###新功能
- 高频SQL分析 加user
- xml 转换yaml命令行工具.
- 新增 SQL / HIGH / SLOW / TABLE 指令 clear 参数 true表示清除cache, 如: show @@sql true; show @@sql.high false;
- 配合mycat eye SQL监控持久化,获取数据后清理
- SHOW @@White ip白名单
###改进和修复
- 修复 wapper 日志无用输出
- 修复hint sql type 引擎的问题
- 修复重写xml dtd丢失问题
- 白名单 写回文件
- ip类型写错
- 修复 注解SQL的 sqlType 与 实际SQL的 sqlType 不一致问题
- 根据用户的反馈, 修复 QueryResult 在高并发的情况下 endTime 时间有延迟的问题, sql/high/slow/table 新增 clear 参数
- fix bug for multi-tenancy using /!mycat:schema=DB1/ select * from table (oracle)
- 为MyCat 的 SERVER VERSION 增加了注释, 增加了一个 dump ,可供调试时输出内容
- Change version info
- 增加 SET IGNORE UTIL
- 实际使用中PHP用户经常会操作多个SET指令组成一个Stmt , 所以该指令检测功能独立出来
- 增加 reload @@sqlstat=open/close 指令到 help
- fix带物理库名路由到随机节点的bug
- 更换License
- fix sharejoin bug
####MyCat 1.5-ALPHA ###新功能
- 新增支持 joinkey 为varchar 类型的sharejoin
- 增加控制指令,可关闭或打开实时统计分析的功能
- 忽略部分 SET 指令, 避免WARN 不断的刷日志
- 默认mycat 统计分析模块为打开状态
- 可通过如下指令设置关闭或打开 实时统计分析模块
- reload @@sqlstat=close;
- reload @@sqlstat=open;
- 增加 SQL 条件的分析,用于 列值/访问次数 的实时统计
- 支持设置规则 reload @@query_cf=表名&字段
- 支持清除规则 reload @@query_cf=NULL
- 支持 show @@sql.condition
- 新增setnodes方法
- xml to yaml tool
###改进和修复
- 修改 isInit 需要声明为 volatile
- fix: HintHandlerFactory 线程安全问题和多次重复初始化的问题
- -close connection,reason:program err:java.lang.IndexOutOfBoundsException
- 问题load大文件出现临文件dn1.txt找不到,load大文件出现空指针的异常,load出现路由错误的问题from berylgreen
- fix gen zkurl bug
- 修复reload_all的bug
- zk-create 文件有问题
- 修复:客户端字符集同步不一致.
- 后端链接在同步完毕之后才回调修改当前后端链接的字符集,导致第一条发送出去的字符是使用后端链接的字符集进行编码的,而不是真正前端链接的字符集,导致编码出错.
- 添加insert误判的单元测试
- 非彻底解决insert 语句误判问题
- 修复explain insert 执行的bug
- done load configration from zookeeper
- 修复 sql 统计列表 里面看到好多非业务sql问题,可能的慢sql 里面 sql执行时间不太对
- 添加默认不使用zookeeper进行加载.
- done load configration from zookeeper
- wrapper.ping.timeout
- 修复在注解方式批量导入时,自增字段不能正确获取的问题(以本地时间算法的自增方式)
- 解决mycat内部统计的druid sql parse类型转换错误
####MyCat 1.4-RELEASE ###新功能
- 添加常见编码默认值防止用户未配置文件
- 字符集索引改成动态可配置
- 加上SequoiaDB JDBC配置
- ER子表的自增主键的支持
- 增加 ddl 支持 ,默认发送到所有请求
- 修改读操作获取负载节点的逻辑,将负载类型为1、2、3的逻辑合并为一个方法
- 支持后端jdbc事务隔离级别设置
###改进和修复
- 添加跳过对null的reason处理。
- 修改rollback日志级别
- 修复主从切换慢和重新加载数据源慢的问题
- 修复心跳启动立马切换主从 bug
- 默认节点 null bug修复
- fix高并发npe和排序问题
- 优化去掉eof等待和去掉一次线程切换
- 修复nextProcessor数组越界问题
- 全局表or语句路由错误,并增加单元测试
- fix心跳bug
- 修复主从状态监控和读写分离
- remove CancelledKeyException
- fix jdbc驱动5.1.36的bug
- 合并BALANCE_ALL_READ
- 事务中只有select时,释放时rollback
- 添加reload命令行说明
####MyCat 1.4-RC ###新功能
- 增加日期范围hash分片算法
- RELOAD @@CONFIG只reload基本配置,不重新加载数据源,RELOAD @@CONFIG_ALL重加载所有配置
- 支持SequoiaDB
- 增加mycat私有仓库
- 添加having 支持。目前只支持 =,>,<,!=,>=,<=
###改进和修复
- Update BufferPool.java
- 修改只考虑可见性,未考虑同步的newCreated变量
- 缓存正则表达式
- 修复mongodb的acceptsURL
- jdbc 驱动 bug
- 防止拿到连接后,执行sql时。连接被后端检查给关闭掉
- 修改心跳检查bug
- 修复between and 字段带别名时路由错误的bug
- Join Key 不在Select 的第一个字段的bug
- 解决客户端JDBC连接到管理接口报 unsupported statement 错误。
- ShareJoin bug
####MyCat 1.4-beta ###新功能
- 支持start transaction与begin命令开启事务
- 支持多层嵌套or语句,并增加单元测试
- 范围取模分片配置文件
- 增加范围取模分片配置
- 在分片规则中添加JCH分片配置
- 添加跳增一致性哈希分片的测试类
- 增加跳增一致性哈希分片算法(分片思想源自Google在2014年公开的论文,该算法几乎不占内存只需几个寄存器用于计算,速度比一致性哈希更快,横向扩展时数据迁移量大大减少。)
- 支持范围求模算法的between路由
- 支持DESCRIBE和DESC
- 表名支持引号[`]
###改进和修复
- 优化重复代码逻辑
- 增加对自增序列的非空判断,如果没有配置,则抛出配置异常,提示没有序列的定义,避免直接抛出空指针异常。
- 修复distinct的带别名出错的bug
- 去掉WhereUnit中的parent,没用到
- Downgrade JDK from 8 to 7
- Update PartitionByJumpConsistentHash.java
- 去除不必要的cast
- 进一步改进英语表达
- 数据库Sequnce 异常的时候返回客户端具体错误信息,如存储过程不存在
- 修改jdbc的心跳数据,show @@heartbeat
- 修复aio在高并发时出现的bug
- 修复关于JDBC方式连接后端连接占满数据库的问题 #312 中的2,3问题
- 去掉不必要的sysout
- 修改jdbc连接心跳检查active计算错误,show @@backend没有算jdbc连接,
- select sum(a-b) from c where id=100语句没有查到返回null时候,合并数据的时候报nullpointexception错误
- 修复自增id的insert里面的值被强制转大写的bug
- 修复insert序列解析错误和序列next value for的大小写与空格支持
- 修复desc语句导致单元测试卡死bug
- 修复jdbc心跳bug导致不断创建连接的bug
- 修复druidmanager引起的jdbc连接失败问题
- 新增,删除 修改全局表 返回受影响的行不对(应该只计算一个节点的)
- 修复在hibernate生成的sql中group by语句中的字段和select语句中的字段的别名不一致(但是同一字段)时报错
- 修复null被当做空串的bug
- fix a bug, which resulted in RW seperation is unavailable
- 文件清理,增加versions.java自动生成的功能,修正show @@versions的输出。
- add TestCase:delete of global table route to every datanode defined
- 全局表的delete和update紧急Bug
####MyCat 1.4-alpha ###新功能
- 增加时间戳的全局唯一序列
- 使用jdbc 方式连接 , 引入 druid数据源与数据库监控
- 增加对or条件的路由支持
- 引入load data
- 完整实现mysql压缩协议的支持
- 增加压缩协议的配置选项
- 支持跨分片的avg函数以及avg与group by组合
- catlet支持jar
- 支持schema内,未配置的表走默认dataNode,已配置的走分片规则
- 支持批量插入sequence生成
- 修改:
- MyCATSequnceProcessor.executeSeq 方法中获取sequence 由FoundationDB方式改为Druid方式实现。
- 增加一个catlet,BatchInsertSequence支持批量插入语法自动生成sequence ID。
- schema.xml中的Table上的DataNode支持数据库均匀分布,如
dataNode="distribute(dn1$0-372,dn11$0-372)" rule="latest-month-calldate"
/>```
+ limit自动转换原生分页
###改进和修复
+ 修改reload为非阻塞
+ 修复 自增主键,表写错大小写导致mycat无限循环获取
+ 修复DataMergeService跨线程时的异常处理
+ 增强SingleNodeHander的异常处理
+ 升级druid和univocity-parsers版本
+ 修改E-R为非阻塞
+ fixed a bug for StringUtil.getTableName(String)
+ add two test case for StringUtil.getTableName
+ fix a bug, if 'insert into' was following a '\r' or '\n'.
edit StringUtil.getTableName(String), change "==' '" to "<=' '"
+ 避免insert判断时是非空格字符
+ 修复multi insert not provided误判
+ 修正后端jdbc方式时,delete语句解析出错的情况
+ fix a bug when 'sequence conf not found'
+ modify charset index 45 for utf8mb4
+ 解决空串被当做null的bug
+ 修复load data 默认节点时的npe异常
+ 修改心跳检查Bug,没有判断数据库切换类型
+ fix order by语句中带'符号时报错找不到字段问题。java.lang.IllegalArgumentException: all columns in order by clause should be in the selected column list!`create_time`
+ entry.getKey().toUpperCase() 不用 Upper了,容易引起误解,以为大小写的问题
+ 去掉中文提示信息改成all columns in order by clause should be in the selected column list!
+ fix a bug on reloading sequence_db_conf.properties
+ order by别名的一种场景语句解析bug,如语句SELECT c.name as cname, Count(*) AS col_1_0_
from customer c group by c.name
+ 父子表场景,子表select语句路由到多个节点报错。对应测试用例DruidMysqlRouteStrategyTest.testERRouteMutiNode
+ 带计算表达式的order by语句,select fee-3 as fee3,id from travelrecord order by fee-3
+ 增强jdbc和multiNodeQueryHandler的异常处理
+ Mycat JDBC连postgresql不能支持事务提交和回滚
+ 修改releaseConnection方法
+ 修改显示版本为1.4,升级依赖的jar为最新release版
+ 重构HeatBeat逻辑和代码,引入MySQL主从状态监控的心跳和切换逻辑
+ fix a bug on crossing sharding with 'in clause' sql
+ fix a bug on executing reload @@config, which would not reload sequence_db_conf.properties. this commit has fixed it.
+ removed bucketMapPath from PartitionByMurmurHash.java
+ MycatPrivileges单实例化 及 StringUtil增强
+ MYCAT_HOME未设置时,默认设置为当前路径。
+ 提交assembly
+ 修复encose的空指针异常
+ SONAR问题修复
+ 优化去除AIOOutputWriter
+ 解决AIO的writePendingException
+ 支持未压缩的小包粘连
+ 删除几个fdb遗留无用代码
+ 移除fdbParse相关的包,代码
+ 修复单节点ok包packid多加一次的bug
+ 实现load功能
* 重构部分代码
* 优化load data infile的性能
* 优化load data性能
* 优化load data数据包得识别,避免误认2.优化load data全局表,避免路由查找3.修复了一个在同一个连接上执行load data几百次会出错的bug
* 修复load data 超大文件时的bug
* 支持load data的自定义列分割符换行符引号等,增强了load data handler的异常处理,优化去掉aiooutputwriter的多余部分
* 优化load data 的clear调用
* 支持load data的自定义列分割符换行符引号等,增强了load data handler的异常处理
* 优化去掉部分load data日志
+ fix 引用类的问题
+ 修改jdbc的resultset转换RowDataPacket的方式,可以提高30%的性能
+ 修改jdbc的sql执行为多线程执行,避免jdbc跨多个节点时性能成倍消耗
####MyCat 1.3.0.3-release
+ JDBC方式, 字段有别名,报错 java.lang.IllegalArgumentException: group by
+ session移除已关闭的连接
+ 增加LockTable和UnlockTables语句支持
####MyCat 1.3.0.3-alpha
+ order by 带函数的 的bug,如 order by date_format(traveldate, '%y-%m-%d')
+ 1.3.0.1修改order by ,group by 别名的bug
+ 增加pluginManage,修正eclipse导入lifeCycle错误
+ 修正多节点merge排序结果不正确bug
+ 修正skip过慢问题
+ 排序优化
+ 注解增加/*#mycat:格式;where condition1 or 1=1之类的永真条件路由错误问题
+ 修正最大堆排序结果不正确bug
+ between语句范围路由的支持
+ 修正druid group by 语句字段带表名提示字段找不到的问题
+ 解决druid主键in查询只匹配一个条件的问题
+ fixed:#87;mycat注释兼容mysql注释
+ 解决druid解析器order by字段名称与select语句字段名称不一制问题
+ 解决group by order by问题;解决select for update问题;修改错误提示信息
+ 解决druid解析器count语句问题
+ 修正Druid解析器添加分片字段错误
####MyCat 1.3.0.1
>git:
Fix bug:
1. 数据报文在某些特殊情况下没有实时写入Socket导致时延(重要)
2. Druid解析器的一些空指针、Limit处理、以及单引号的Bug
#####存在的缺陷
1. 目前还没有发现新的Bug
---
####MyCat 1.3
>git:e3111dfdee64163bd15aa6022171ad34c3aad455
特性:
1. 一致性hash分片支持
2. 默认Druid解析器提升性能
3. 人工智能Catlet 编程实现跨分片Join ,143行Demo代码可供参考
4. 性能大幅提升,相对1.2 插入性能提升100%,查询性能提升50%
Fix bug:
1. checkWriteBuffer可能分配不够的空间,存在潜在Bug()
2. Mysql 连接同步优化,以及修改Timeout 超时的问题
3. 主键缓存优化
4. 后端连接事件优化
#####存在的缺陷
- 比较重要的一个缺陷是数据报文在某些特殊情况下没有及时写入Socket导致时延,已经在1.3.0.1修复
| Author | | | |
| :-------- | :--------------- | :----------------------- |:--------------------------- |
|姓名 |群名片|QQ|任务|
| Marshy | ||负责任务跟踪,提供了机器供Mycat官网使用,是Mycat美女大总管|
| |成都研发 ||分片排序优化模块 |
|王灯武 |武 | 15297449|引入新的Druid解析器 |
| 吴京润|一坨 |744142084| 一致性Hash分片和工具 |
| 海王星 | 负责github和版本发布,持续化构建 |||
| 石头狮子 | 写文档、实现了HA Datasource工具等 |||
| 冰风影 | 修复JDBC连接缺陷,开始NoSQL模块开发 |||
| .Jagger | 自增长主键实现和性能测试、参与性能优化过程|||
| 非非想 |Mycat官网第一版 |||
| 一觉醒来 |协助数据库调优 |||
| 赵闪|Cheris |694050364 |提供了性能测试报告 |||
|詹益峰|哈哈|758297924|Mycat in action文档汉译英|
|刘晓栋|晓栋|67814134|翻译Mycat in action|
|陈秀升|xiuson|443697052|Mycat in action翻译和Mycat-server readme.md中英文两部分|
| 其他友情客串者 |酱油师、xiuson、哈哈、BEN、Mr.ZHU、超仔、深海、广州-UFO、等很多同学 ||||
---
####MyCat 1.2
>MyCat 1.2 (svn:r515)
特性:
1. 增加了SQL拦截器的功能,默认的实现将Mysql转义字符进行了处理
Fix bug:
1. 事务隔离问题
| Author | |
| :-------- | :--------------- |
| 新加入 林志强、林晁、齐朗晔、杨创、何智峰等(一些遗漏了真名的同学,可以来信) | 全面系统测试,协助发现和解决了一些重要缺陷|
|孙娟(酱油师)|全局序列号更新 |
| (opencloudber) | 排序归并的一些缺陷发现并修复 |
| 王金成(永不言败) | 发现和修复一些缺陷 |
| 蒋常春(CC) | 性能测试 |
| 白磊(first level ) | 性能测试 |
| 李翔远(光电=ω=鼠标 ) | 时间范围分片函数以及between支持 |
| 黄进兵(疯鱼) | 贡献字符串分片函数|
| 高权(IT坨坨) |测试以及缺陷反馈|
| 吴志辉(Leader) |MyCat-server |
| rainbow 团队 |协助数据库调优 |
|Qing|MyCat-cluster|
|提婆谭(暂定)|MyCat-Balance|
|[email protected]|MyCat-server|
|无影|MyCat-server|
|shenzhw|性能测试|
|小鱼|测试|
|阿德|排序算法|
|面朝大海|修复BUG|
|木糖醇患者|修复BUG|
#####很多志愿者在努力研发中,后期版本陆续列出贡献者信息
---