背景知识:
我有一个运行在Tomcat 7上的Java 1.6 web应用程序。数据库为MySQL 5.5。之前,我使用Mysql JDBC驱动程序5.1.23连接到DB。一切工作。我最近升级到Mysql JDBC驱动程序5.1.33。升级后,Tomcat在启动应用程序时会抛出这个错误。
WARNING: Unexpected exception resolving reference
java.sql.SQLException: The server timezone value 'UTC' is unrecognized or represents
more than one timezone. You must configure either the server or JDBC driver (via
the serverTimezone configuration property) to use a more specifc timezone value if
you want to utilize timezone support.
为什么会这样?
连接字符串为我工作这个
jdbc: mysql: / / localhost / < yourDbName > ?useUnicode = true&useJDBCCompliantTimezoneShift = true&useLegacyDatetimeCode = false&serverTimezone = UTC
我使用Gradle我的构建。Gradle文件是这样的
dependencies {
// https://mvnrepository.com/artifact/mysql/mysql-connector-java
implementation group: 'mysql', name: 'mysql-connector-java', version: '8.0.17'
testCompile group: 'junit', name: 'junit', version: '4.12'
}
这是mysql-connector-java从5.1.33到5.1.37版本的一个错误。
我已经在这里报告了:http://bugs.mysql.com/bug.php?id=79343
编辑:
这已经从mysql-connector-java 5.1.39修正
这是在loadtimezonemapping方法中的TimeUtil类中出现的一个拼写错误,该方法会引发NPE定位/com/mysql/jdbc/TimeZoneMapping。属性文件。如果你看一下代码,文件应该位于TimeUtil类装入器中,而不是TimeZone:
TimeUtil.class.getResourceAsStream(TIME_ZONE_MAPPINGS_RESOURCE);
参数useLegacyDatetimeCode允许在使用日期时自动纠正客户端和服务器时区之间的差异。因此,它帮助您精确地不必在每个部分指定时区。虽然使用serverTimeZone参数是一种变通方法,并且在发布补丁的同时,您可以像我一样尝试自己更正代码。
如果它是一个独立的应用程序,您可以尝试简单地添加
纠正com/mysql/jdbc/TimeUtil类到你的代码,要小心
与罐子装载顺序。这可以帮助:
https://owenou.com/2010/07/20/patching-with-class-shadowing-and-maven.html
如果它是一个web应用程序,更简单的解决方案是创建自己的应用程序
Mysql-connector-java-5.1.37-patched.jar,直接替换。class
放进原来的罐子里。
Connection con = DriverManager.getConnection("jdbc:mysql://localhost:3306/resultout? useUnicode=true&useJDBCCompliantTimezoneShift=true&useLegacyDatetimeCode=false&serverTimezone=UTC","root",""))
这实际上是这个问题的解决方案,但不要只是复制粘贴到您的程序中。如果你只看这一行,你会发现'resultout',这是我的数据库的名称,你必须写下你的。
有三个字符串组件,第一个是url,第二个是用户名,第三个是密码。在上述段落中,我们清除了,url。第二个和第三个字符串组件,你的用户名和密码,你必须相应地改变。
谢谢
我在[mysqld]部分添加了mysql配置文件
default_time_zone = ' + 03:00 '
重启mysql服务器:
Sudo服务mysql重启
其中+03:00我的UTC时区。
在我的操作系统ubuntu 16.04上配置文件的路径:
/etc/mysql/mysql.conf.d/mysqld.cnf
警告:如果你所在的时区有夏季和冬季时间。如果要更改时间,必须在配置中更改utc。一年两次(通常)或用sudo设置crontab。
我的url jdbc连接
"jdbc:mysql://localhost/java"