前提・実現したいこと
MySQLにJDBC接続したい。
Linux環境でMySQLにJDBCドライバを使用して接続しようとするとエラーが発生しました。
発生している問題・エラーメッセージ
Details: com.mysql.cj.jdbc.exceptions.CommunicationsException: Communications link failure
The last packet sent successfully to the server was 0 milliseconds ago. The driver has not received any packets from the server.
試したこと
JDBC接続でなく、mysql -h ホスト名 -P ポート -u ユーザ名 -pパスワード
で実施すると接続できます。
同じホスト名・ポート・ユーザ名・パスワードを使用しているので、違うところはJDBCドライバを使用しているところ
だけなので、JDBCドライバを疑っております。
JDBCドライバに対して何か必要なのでしょうか。もしくは他に何か考えられますでしょうか。
環境変数のCLASSPATHにJDBCドライバのありかを指定しております。
<追記>
ありがとうございます。情報追記します。
MySQLのバージョンは5.6.10
MySQLのJDBCドライバはmysql-connector-java-8.0.19.jarです。
他は以下です。
IBM WebSphere Application Server 8.5.5
IBM MobileFirst Platform Foundation 7.1
IBM JDK 8.0
MobileFirst Platform Foundationのantタスクを使用して
データベース作成する際にエラーになりました。
「mysql "The driver has not received any packets from the server."」
では検索してみているのですが、うまく見つけられませんでした。
https://qiita.com/syoki/items/3d82ef00300868353572にある
8.x以前:「com.mysql.jdbc.Driver」
8.x:「com.mysql.cj.jdbc.Driver」
ですが、ログ上に
「Loading class com.mysql.jdbc.Driver'. This is deprecated. The new driver class is
com.mysql.cj.jdbc.Driver'.
The driver is automatically registered via the SPI and manual loading of the driver class is generally unnecessary.」
と出ているので、怪しそうですが「com.mysql.jdbc.Driver」の設定を探しているのですが、どこにあるか見つけられてません。
<追記>
MySQL自体はAuroraなので、そちら側でエラー出ていないか確認しましたがエラーは出てませんでした。
MySQLクライアントとしてmariaDBが入っていたので削除してMySQL Communityを入れてみたのですが、結果変わらずでした。
mysql-community-client-5.6.38-2.el6.x86_64
mysql-community-common-5.6.38-2.el6.x86_64
mysql-community-libs-5.6.38-2.el6.x86_64
<追記>
MySQLのバージョンが5.6の場合MySQLのJDBCドライバは最新の8.0系でなく5.1系でも大丈夫なことが分かったので、
5.1に落としたらうまくいきました。
https://dev.mysql.com/downloads/connector/j/5.1.html
ネットでmysql connector/j ダウンロードと検索すると以下のページが出て8.0しか出てこないのでで何とかする方法を
探してしまいましたが、5.1でもいけないか確認すべきでした。ヒントくださったかたありがとうございました。
https://www.mysql.com/jp/products/connector/
回答1件
あなたの回答
tips
プレビュー