質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
MySQL

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

データベース

データベースとは、データの集合体を指します。また、そのデータの集合体の共用を可能にするシステムの意味を含めます

VPS

VPS(バーチャル・プライベート・サーバ)は、仮想化されたサーバをレンタルするサービスで、共有サーバでありながら専門サーバと同等の機能を果たします。物理的な専門サーバより安価で提供できるメリットがあります。

Apache Tomcat

Apache TomcatはApache Software Foundation (ASF)で開発されたオープンソースのWebコンテナです。

Q&A

解決済

1回答

3567閲覧

TomcatとMySQLデータベースをつなぐときのエラー

KazuhoAkabane

総合スコア56

MySQL

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

データベース

データベースとは、データの集合体を指します。また、そのデータの集合体の共用を可能にするシステムの意味を含めます

VPS

VPS(バーチャル・プライベート・サーバ)は、仮想化されたサーバをレンタルするサービスで、共有サーバでありながら専門サーバと同等の機能を果たします。物理的な専門サーバより安価で提供できるメリットがあります。

Apache Tomcat

Apache TomcatはApache Software Foundation (ASF)で開発されたオープンソースのWebコンテナです。

0グッド

0クリップ

投稿2021/07/23 18:40

編集2021/07/24 04:42

Tomcatでデータベースと接続しようとすると、ドライバのロードは成功するのですがサーバーからのコネクションがないといわれます。

参考にしているサイト

https://www.javadrive.jp/servlet/database/index5.html

エラー内容:
ドライバのロードに成功しました
SQLException: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. コネクションがありません

java

1package xxxx; 2 3import java.io.*; 4import javax.servlet.*; 5import javax.servlet.http.*; 6import java.sql.*; 7import java.io.IOException; 8import java.io.PrintWriter; 9import javax.servlet.ServletException; 10import javax.servlet.http.HttpServlet; 11import javax.servlet.http.HttpServletRequest; 12import javax.servlet.http.HttpServletResponse; 13import javax.servlet.annotation.WebServlet; 14 15@WebServlet(urlPatterns= {"/xxxx/hello2"}) 16public class Hello2 extends HttpServlet { 17 public void doGet(HttpServletRequest request, HttpServletResponse response) 18 throws IOException, ServletException{ 19 20 response.setContentType("text/html; charset=UTF-8"); 21 PrintWriter out = response.getWriter(); 22 23 out.println("<html>"); 24 out.println("<head>"); 25 out.println("<title>データベーステスト</title>"); 26 out.println("</head>"); 27 out.println("<body>"); 28 29 out.println("<p>"); 30 31 Connection conn = null; 32 String url = "jdbc:mysql://[サーバーのアドレス]/test"; 33 String user = "***"; 34 String password = "***"; 35 36 try { 37 Class.forName("com.mysql.jdbc.Driver").newInstance(); 38 out.println("ドライバのロードに成功しました<br>"); 39 40 conn = DriverManager.getConnection(url, user, password); 41 out.println("データベース接続に成功しました<br>"); 42 }catch (ClassNotFoundException e){ 43 out.println("ClassNotFoundException:" + e.getMessage()); 44 }catch (SQLException e){ 45 out.println("SQLException:" + e.getMessage()); 46 }catch (Exception e){ 47 out.println("Exception:" + e.getMessage()); 48 }finally{ 49 try{ 50 if (conn != null){ 51 conn.close(); 52 out.println("データベース切断に成功しました"); 53 }else{ 54 out.println("コネクションがありません"); 55 } 56 }catch (SQLException e){ 57 out.println("SQLException:" + e.getMessage()); 58 } 59 } 60 61 out.println("</p>"); 62 63 out.println("</body>"); 64 out.println("</html>"); 65 } 66}

試したこと
firewallは一度停止して動作を見ましたが変わりませんでした。
ポートの確認、sakura vpsの3306ポートの解放。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

Noin

2021/07/23 21:01

そのサーバからmysqlコマンド等でmysqlへ接続できますか?
YT0014

2021/07/24 01:12

ポートの解放は、コントロールパネルでのパケットフィルタの設定変更の意味でしょうか? また、TomcatとMySQLは、別のPCで運用されているのでしょうか?
KazuhoAkabane

2021/07/24 02:41 編集

回答ありがとうございます。 >>Noinさん 同じサーバー内なのでmysqlへの接続はできます。 >>YT0014さん ポートの開放はコントロールパネルのパケットフィルタの設定変更の意味です。TomcatとMySQLは同じVPSサーバーで運用しています。
KazuhoAkabane

2021/07/24 02:46 編集

少し気になったのですが、データソースのResourceのname箇所に設定する値は特に気にしなくても大丈夫なのでしょうか。ここは"jdbc/test"にしたほうが良いのでしょうか。(testはデータベース名)
KazuhoAkabane

2021/07/24 04:45 編集

>>Noinさん ソース内に直接書いてデータソーのcontext.xmlを削除してみましたが、エラーコードは変わりませんでした。(すいません...ソースコード内にも記載しておりcontext.xmlはあまり関係なかったみたいです)
Noin

2021/07/24 04:59

うーん???って感じですね。 試しにサーバ名をlocalhostまたは127.0.0.1だとどうなりますか?
KazuhoAkabane

2021/07/24 05:01 編集

以下のURLで言われているWebアプリケーションの置き場というのが気になったのですが、これはどういう意味なのでしょうか。database.xmlの箇所です。 https://www.javadrive.jp/servlet/database/index2.html <Context path="/database" docBase="d:/servlet-sample/database"/> このxmlを作成した場合どこに置くのでしょうか。
KazuhoAkabane

2021/07/24 05:13 編集

localhostで成功しました!! ベストアンサーにしますので「回答をする」でなにかコメントよろしくお願いします!
Noin

2021/07/24 05:13

となると、サーバ名の名前解決ができていなかったようですね。
KazuhoAkabane

2021/07/24 05:14

そうですね。サーバーのIPアドレス入れてました、、
Noin

2021/07/24 05:25

あー、その場合はさくらVPCのスイッチ側の仕様かと思います。 自IPアドレスに接続しにいった場合、loopbackアドレスが返却される為IPアドレスで接続しにいってるのにlocalhostか127.0.0.1に接続しようとする為エラーになるのかと思います。 もしくはVPCとかスイッチ等の設定をすればできるようになるのかもしれません。
guest

回答1

0

ベストアンサー

サーバ名にlocalhostまたは127.0.0.1を記載

質問欄に記載してしまったので、一応回答欄に記入させて頂きますね。

投稿2021/07/24 05:14

Noin

総合スコア188

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問