2017-05-16 14 views
1

我有一个连接到mysql服务器的Java客户端应用程序。客户端和服务器都在Docker容器中运行。重新引入“未知的初始字符集索引”错误?

我注意到,MySQL官方泊坞窗图像最近更新MySQL服务运行Version: '8.0.1-dmr'

由于这种变化,我的Java客户端应用程序无法连接到MySQL实例;它失败,出现以下错误:

Caused by: java.sql.SQLException: Unknown initial character set index '255' received from server. Initial client character set can be forced via the 'characterEncoding' property. 
    at com.mysql.jdbc.SQLError.createSQLException(SQLError.java:910) ~[mysql-connector-java-5.0.8-bin.jar:na] 
    at com.mysql.jdbc.Connection.configureClientCharacterSet(Connection.java:2412) ~[mysql-connector-java-5.0.8-bin.jar:na] 
    at com.mysql.jdbc.Connection.initializePropsFromServer(Connection.java:4139) ~[mysql-connector-java-5.0.8-bin.jar:na] 
    at com.mysql.jdbc.Connection.createNewIO(Connection.java:2789) ~[mysql-connector-java-5.0.8-bin.jar:na] 
    at com.mysql.jdbc.Connection.<init>(Connection.java:1555) ~[mysql-connector-java-5.0.8-bin.jar:na] 
    at com.mysql.jdbc.NonRegisteringDriver.connect(NonRegisteringDriver.java:285) ~[mysql-connector-java-5.0.8-bin.jar:na] 
    at org.apache.tomcat.jdbc.pool.PooledConnection.connectUsingDriver(PooledConnection.java:307) ~[tomcat-jdbc-8.0.20.jar:na] 
    at org.apache.tomcat.jdbc.pool.PooledConnection.connect(PooledConnection.java:200) ~[tomcat-jdbc-8.0.20.jar:na] 
    at org.apache.tomcat.jdbc.pool.ConnectionPool.createConnection(ConnectionPool.java:699) ~[tomcat-jdbc-8.0.20.jar:na] 
    at org.apache.tomcat.jdbc.pool.ConnectionPool.borrowConnection(ConnectionPool.java:633) ~[tomcat-jdbc-8.0.20.jar:na] 
    at org.apache.tomcat.jdbc.pool.ConnectionPool.getConnection(ConnectionPool.java:186) ~[tomcat-jdbc-8.0.20.jar:na] 
    at org.apache.tomcat.jdbc.pool.DataSourceProxy.getConnection(DataSourceProxy.java:126) ~[tomcat-jdbc-8.0.20.jar:na] 

我不拥有Java客户端应用程序的源代码,所以我不能轻松地升级它使用JDBC驱动程序(这是mysql-connector-java-5.0.8-bin.jar)。

这是与正在运行的mysqld Version: '8.0.0-dmr'

有任何解决方法这个问题不涉及更新JDBC驱动程序以前mysqldb:8泊坞窗图像的工作?这是在mysqld回归?

回答

1

This约自8.0 一个已上市,供你参考的点已经发生了变化谈判是这样的:

Character Set Support

Important Change: The default character set has changed from latin1 to utf8mb4. These system variables are affected:

The default value of the character_set_server and character_set_database system variables has changed from latin1 to utf8mb4.

The default value of the collation_server and collation_database system variables has changed from latin1_swedish_ci to utf8mb4_0900_ai_ci.

其结果是,默认的字符集和归类为新对象与以前不同,除非指定了明确的字符集和归类。这包括其中的数据库和对象,如表,视图和存储程序。保留以前的默认


一种方法是先从这些线路的服务器my.cnf文件:

[mysqld] 
character_set_server=latin1 
collation_server=latin1_swedish_ci 

另一种选择,因为你正在运行的泊坞窗,是指定这些配置选项命令docker run命令行参数。例如:

docker run -d \ 
--network my-net \ 
-h mysqldb \ 
--name mysqldb \ 
-p 3306:3306 \ 
-e MYSQL_RANDOM_ROOT_PASSWORD=yes \ 
-e MYSQL_DATABASE=mydb \ 
-e MYSQL_USER=admin \ 
-e "MYSQL_PASSWORD=admin" \ 
mysql:8 --character-set-server=latin1 --collation-server=latin1_swedish_ci 

在客户端,如果你想做出改变 - 希望这些就足够了:

要使用4个字节的UTF-8字符集与连接器/ J,配置具有character_set_server=utf8mb4的MySQL服务器,并将characterEncoding留在Connector/J连接字符串之外。

连接器/ J便会自动侦测UTF-8设置

希望这有助于!

+0

完美,固定它。我选择使用命令行选项'--character-set-server = latin1 --collat​​ion-server = latin1_swedish_ci'来代替,因为我不想创建配置文件并将其装载到docker容器。 – FGreg

+0

乐意帮忙@FGreg –

相关问题