1、项目场景
Mycat
是一个基于Java开发的开源的分布式数据库中间件。它可以在逻辑上将多个MySQL数据库组合成一个大的逻辑数据库,同时提供读写分离、分库分表、水平扩展、高可用等功能,并且对 MySQL 的复制、故障切换、数据一致性等操作进行了优化和增强。
作者在启动Mycat时,使用
bin/mycat start
开启mycat
之后,出现 2 字节的 UTF-8 序列的字节 2 无效。
2、问题描述
在开启后,为了确认mycat是否开启,使用
tail -60 logs/wrapper.log
查看mycat
日志
关键错误展示:
Caused by: io.mycat.config.util.ConfigException: com.sun.org.apache.xerces.internal.impl.io.MalformedByteSequenceException: 2 字节的 UTF-8 序列的字节 2 无效。
INFO | jvm 1 | 2022/05/05 15:54:59 | Caused by: io.mycat.config.util.ConfigException: com.sun.org.apache.xerces.internal.impl.io.MalformedByteSequenceException: 2 字节的 UTF-8 序列的字节 2 无效。
INFO | jvm 1 | 2022/05/05 15:54:59 | at io.mycat.config.loader.xml.XMLSchemaLoader.load(XMLSchemaLoader.java:121)
INFO | jvm 1 | 2022/05/05 15:54:59 | at io.mycat.config.loader.xml.XMLSchemaLoader.<init>(XMLSchemaLoader.java:78)
INFO | jvm 1 | 2022/05/05 15:54:59 | at io.mycat.config.loader.xml.XMLSchemaLoader.<init>(XMLSchemaLoader.java:82)
INFO | jvm 1 | 2022/05/05 15:54:59 | at io.mycat.config.ConfigInitializer.<init>(ConfigInitializer.java:76)
INFO | jvm 1 | 2022/05/05 15:54:59 | at io.mycat.config.MycatConfig.<init>(MycatConfig.java:72)
INFO | jvm 1 | 2022/05/05 15:54:59 | at io.mycat.MycatServer.<init>(MycatServer.java:166)
INFO | jvm 1 | 2022/05/05 15:54:59 | at io.mycat.MycatServer.<clinit>(MycatServer.java:109)
INFO | jvm 1 | 2022/05/05 15:54:59 | ... 7 more
INFO | jvm 1 | 2022/05/05 15:54:59 | Caused by: com.sun.org.apache.xerces.internal.impl.io.MalformedByteSequenceException: 2 字节的 UTF-8 序列的字节 2 无效。
INFO | jvm 1 | 2022/05/05 15:54:59 | at com.sun.org.apache.xerces.internal.impl.io.UTF8Reader.invalidByte(UTF8Reader.java:701)
3、原因分析
提示是 UTF-8 序列的问题,原因:在schema.xml
的配置文件中,出现了中文,即使是注释也会出现错误。
4、解决方案
即使是注释也存在问题,将配置文件中的中文注释删除即可。
再次开启,当出现successfully
表示mycat开启成功。