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;
    }
}

  

 

posted on 2021-03-02 19:00  llooperliang  阅读(178)  评论(0编辑  收藏  举报