ICode9

精准搜索请尝试: 精确搜索
首页 > 数据库> 文章详细

Tigase8.x 搭配Mysql8及以上启动时报错(Nodes redirection table: tig_cluster_nodes doesn't exits)的解决方法

2021-03-02 19:01:44  阅读:224  来源: 互联网

标签:slashes exits Tigase8 db doesn break split table schema


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

  

 

标签:slashes,exits,Tigase8,db,doesn,break,split,table,schema
来源: https://www.cnblogs.com/eyecool/p/14470651.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有