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ポートの解放。
回答1件
あなたの回答
tips
プレビュー