Tigase 启动时报如下错误:
===================== Could not initialize bean default (class: class tigase.server.xmppclient.SeeOtherHostDualIP$DualIPRepositoryWrapper$DualIPRepositoryWrapperConfigBean), skipping injection of this bean RootCause: -> java.lang.RuntimeException: Repository initialization failed [tigase.server.xmppclient.SeeOtherHostDualIPSQLRepository.setDataSource(SeeOtherHostDualIPSQLRepository.java:61)] -> java.sql.SQLException: Nodes redirection table: tig_cluster_nodes doesn't exits! [tigase.server.xmppclient.SeeOtherHostDualIPSQLRepository.checkDB(SeeOtherHostDualIPSQLRepository.java:103)] =====================
项目中数据库链接的配置:
uri = 'jdbc:mysql://localhost/tig8_db?user=root&password=123456&useUnicode=true&characterEncoding=utf-8&serverTimezone=Asia/Shanghai'
1、分析问题: 通过定位发现此为Tigase的兼容BUG,导致问题源代码处:
tigase.db.jdbc.DataRepositoryImpl if (db_conn != null) { switch (database) { case jtds: case sqlserver: table_schema = "dbo"; break; case postgresql: table_schema = "public"; break; default: String[] slashes = db_conn.split("/"); table_schema = slashes[slashes.length - 1].split("\\?")[0]; break; } log.log(Level.INFO, "Table schema found: {0}, database type: {1}, database driver: {2}", new Object[]{table_schema, database.toString(), driverClass}); }
2、定位到问题点: 如果使用的是Mysql8及以上,URL需要配置时区 :serverTimezone=Asia/Shanghai',则以下代码切割出来的table_schema 为Shanghai,导致取不正确的值tig8_db,从而报错!
String[] slashes = db_conn.split("/"); table_schema = slashes[slashes.length - 1].split("\\?")[0]; // error ==> Shanghai
3、解决问题: 在官方还没修复之前,通过以下方式可以修复:
String[] slashes = db_conn.split("/"); for (String slash : slashes) { if (slash != null && slash.contains("?")) { table_schema = slash.split("\\?")[0]; break; } }