Mycat出现org.apache.xerces.internal.impl.io.MalformedByteSequenceException:2 字节的 UTF-8 序列的字节 2 无效的解决方案


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开启成功。
在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Le`soleil

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值