Tomcat6 не может подключиться к MySql (драйвер не получил пакетов от сервера) - PullRequest
6 голосов
/ 31 января 2010

Я использую Apache Tomcat 6.0.20 / MySQL 5.1.37-lubuntu / sun-java6-jdk / sun-java6-jre / sun-java6-bin на моей локальной машине, используя Ubuntu 9.10 в качестве ОС. Я пытаюсь получить простой пример DB-запроса, работающий в течение 2 дней, но я все еще получаю следующее исключение:

org.apache.jasper.JasperException: javax.servlet.ServletException: javax.servlet.jsp.JspException: Unable to get connection, DataSource invalid: "org.apache.commons.dbcp.SQLNestedException: Cannot create PoolableConnectionFactory (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.)"
 org.apache.jasper.servlet.JspServletWrapper.handleJspException(JspServletWrapper.java:522)
 org.apache.jasper.servlet.JspServletWrapper.service(JspServletWrapper.java:398)
 org.apache.jasper.servlet.JspServlet.serviceJspFile(JspServlet.java:342)
 org.apache.jasper.servlet.JspServlet.service(JspServlet.java:267)
 javax.servlet.http.HttpServlet.service(HttpServlet.java:717)

root cause

javax.servlet.ServletException: javax.servlet.jsp.JspException: Unable to get connection, DataSource invalid: "org.apache.commons.dbcp.SQLNestedException: Cannot create PoolableConnectionFactory (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.)"
 org.apache.jasper.runtime.PageContextImpl.doHandlePageException(PageContextImpl.java:862)
 org.apache.jasper.runtime.PageContextImpl.handlePageException(PageContextImpl.java:791)
 org.apache.jsp.index_jsp._jspService(index_jsp.java:104)
 org.apache.jasper.runtime.HttpJspBase.service(HttpJspBase.java:70)
 javax.servlet.http.HttpServlet.service(HttpServlet.java:717)
 org.apache.jasper.servlet.JspServletWrapper.service(JspServletWrapper.java:374)
 org.apache.jasper.servlet.JspServlet.serviceJspFile(JspServlet.java:342)
 org.apache.jasper.servlet.JspServlet.service(JspServlet.java:267)
 javax.servlet.http.HttpServlet.service(HttpServlet.java:717)

root cause

javax.servlet.jsp.JspException: Unable to get connection, DataSource invalid: "org.apache.commons.dbcp.SQLNestedException: Cannot create PoolableConnectionFactory (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.)"
 org.apache.taglibs.standard.tag.common.sql.QueryTagSupport.getConnection(QueryTagSupport.java:285)
 org.apache.taglibs.standard.tag.common.sql.QueryTagSupport.doStartTag(QueryTagSupport.java:168)
 org.apache.jsp.index_jsp._jspx_meth_sql_005fquery_005f0(index_jsp.java:274)
 org.apache.jsp.index_jsp._jspx_meth_c_005fotherwise_005f0(index_jsp.java:216)
 org.apache.jsp.index_jsp._jspx_meth_c_005fchoose_005f0(index_jsp.java:130)
 org.apache.jsp.index_jsp._jspService(index_jsp.java:93)
 org.apache.jasper.runtime.HttpJspBase.service(HttpJspBase.java:70)
 javax.servlet.http.HttpServlet.service(HttpServlet.java:717)
 org.apache.jasper.servlet.JspServletWrapper.service(JspServletWrapper.java:374)
 org.apache.jasper.servlet.JspServlet.serviceJspFile(JspServlet.java:342)
 org.apache.jasper.servlet.JspServlet.service(JspServlet.java:267)
 javax.servlet.http.HttpServlet.service(HttpServlet.java:717)

мой web.xml выглядит так:

<?xml version="1.0" encoding="utf-8"?>
<web-app xmlns="http://java.sun.com/xml/ns/javaee"
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd"
    version="2.5">
  <resource-ref>
      <description>DB Connection</description>
      <res-ref-name>jdbc/testDB</res-ref-name>
      <res-type>javax.sql.DataSource</res-type>
      <res-auth>Container</res-auth>
  </resource-ref>
</web-app>

context.xml выглядит так:

<?xml version="1.0" encoding="UTF-8"?>
<Context path="/my1stApp" docBase="/var/www/jsp/my1stApp" debug="5" reloadable="true" crossContext="true">
    <Resource name="jdbc/testDB" auth="Container" type="javax.sql.DataSource"
    maxActive="5" maxIdle="5" maxWait="10000"
    username="user" password="password" driverClassName="com.mysql.jdbc.Driver"
    url="jdbc:mysql://localhost:3306/some"/>
</Context>

и файл jsp выглядит так:

<%@ page contentType="text/html" %>

<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>

<%@ taglib prefix="fn" uri="http://java.sun.com/jsp/jstl/functions" %>

<%@ taglib prefix="fmt" uri="http://java.sun.com/jsp/jstl/fmt" %>
<%@ taglib prefix="sql" uri="http://java.sun.com/jsp/jstl/sql" %>


<html>

  <head>

    <title>DroneLootTool</title>

  </head>

  <body bgcolor="white">



 <sql:query var="res" dataSource="jdbc/testDB">
  select name, othername 
  from mytable
 </sql:query>

  <h2>Results</h2>

<c:forEach var="row" items="${res.rows}">
    Name ${row.name}<br/>
    MoreName ${row.othername}<br/><br/>
</c:forEach>


  </body>

</html>
  • читать много сообщений на форуме / пробовал много разных настроек (всегда возвращался к исходным настройкам, когда это не работало)
  • установить TOMCAT6_SECURITY = нет в / etc / default / tomcat6, потому что TOMCAT6_SECURITY = yes тоже вызывало проблемы
  • флаг пропуска сети не установлен для БД (установлен BIND 127.0.0.1)
  • межсетевой экран выключен (отключение sudo ufw)
  • MySQL работает (проверено несколько раз с пользователем, использованным в этом скрипте)
  • telnet localhost 3306 говорит

    Попытка :: 1 ... Попытка 127.0.0.1 ... Подключен к localhost. Escape-символ '^]'. Соединение закрыто внешним хостом.


TestConnection.java выдал следующий вывод:

me @ my-laptop: ~ / Desktop $ java -classpath '/usr/share/java/mysql.jar:./' TestConnection com.mysql.jdbc.Driver jdbc: mysql: // localhost: 3306 / testDB myuser mypassword

com.mysql.jdbc.CommunicationsException: Communications link failure
    Last packet sent to the server was 0 ms ago.
        at com.mysql.jdbc.SQLError.createCommunicationsException(SQLError.java:1070)
        at com.mysql.jdbc.ConnectionImpl.createNewIO(ConnectionImpl.java:2103)
        at com.mysql.jdbc.ConnectionImpl.<init>(ConnectionImpl.java:718)
        at com.mysql.jdbc.ConnectionImpl.getInstance(ConnectionImpl.java:298)
        at com.mysql.jdbc.NonRegisteringDriver.connect(NonRegisteringDriver.java:282)
        at java.sql.DriverManager.getConnection(DriverManager.java:582)
        at java.sql.DriverManager.getConnection(DriverManager.java:185)
        at TestConnection.checkConnection(TestConnection.java:40)
        at TestConnection.main(TestConnection.java:21)
    Caused by: com.mysql.jdbc.CommunicationsException: Communications link failure

    Last packet sent to the server was 0 ms ago.
        at com.mysql.jdbc.SQLError.createCommunicationsException(SQLError.java:1070)
        at com.mysql.jdbc.MysqlIO.readPacket(MysqlIO.java:666)
        at com.mysql.jdbc.MysqlIO.doHandshake(MysqlIO.java:1069)
        at com.mysql.jdbc.ConnectionImpl.createNewIO(ConnectionImpl.java:2031)
        ... 7 more
    Caused by: java.io.EOFException: Can not read response from server. Expected to read 4 bytes, read 0 bytes before connection was unexpectedly lost.
        at com.mysql.jdbc.MysqlIO.readFully(MysqlIO.java:2431)
        at com.mysql.jdbc.MysqlIO.readPacket(MysqlIO.java:590)
        ... 9 more
    Connection failed.

Я не знаю, есть ли разница между тем, как драйвер java подключается к БД, и модулем Perl DBI, но этот сценарий PERL работает

#!/usr/bin/perl -w 

use CGI;
use DBI;
use strict;

print CGI::header();

my $dbh = DBI->connect("dbi:mysql:some:localhost", "user", "password");

my $sSql = "SELECT * from mytable";

my $ppl = $dbh->selectall_arrayref( $sSql );

foreach my $pl (@$ppl)
{
  my @array = @$pl;
  print @array;
}

$dbh->disconnect;

включил --log-warnings на mysql, но я не получил никаких новых предупреждений. Когда я искал в журналах предупреждения, я обнаружил эти сообщения при перезапуске кота, не знаю, поможет ли это найти проблему:

Feb  2 19:50:37 tobias-laptop jsvc.exec[3129]: 02.02.2010 19:50:37 org.apache.catalina.startup.HostConfig checkResources#012INFO: Undeploying context [/myapp]
Feb  2 19:50:37 tobias-laptop jsvc.exec[3129]: 02.02.2010 19:50:37 org.apache.catalina.loader.WebappClassLoader clearReferencesThreads#012SCHWERWIEGEND: A web application appears to have started a thread named [MySQL Statement Cancellation Timer] but has failed to stop it. This is very likely to create a memory leak.
Feb  2 19:50:37 tobias-laptop jsvc.exec[3129]: 02.02.2010 19:50:37 org.apache.catalina.startup.HostConfig deployDescriptor#012INFO: Deploying configuration descriptor myapp.xml

Ответы [ 4 ]

3 голосов
/ 17 января 2013

У меня была такая же проблема.

Оказывается, я испортил сервер, запустив три экземпляра mysqld, поэтому уничтожьте ненужное, решив мою проблему:

me@ubuntu:~$ ps aux | grep mysql
mysql     8149  0.1  0.4 280484 26008 ?        Ssl  13:24   0:00 /usr/sbin/mysqld
me     8256  0.0  0.0   4392   836 pts/3    S+   13:24   0:00 grep --color=auto mysql
root     26569  0.0  0.0   5952  1856 ?        S    10:44   0:00 sudo /usr/sbin/mysqld --skip-grant-tables --skip-networking
mysql    26570  0.1  0.6 323528 41936 ?        Sl   10:44   0:15 /usr/sbin/mysqld --skip-grant-tables --skip-networking

me@ubuntu:~$ sudo kill 26570
3 голосов
/ 14 мая 2010

Я решил эту проблему. Причиной возникновения этой ошибки являются ограничения безопасности tomcat.

Вы должны добавить следующую строку к вашему $TOMCAT-CONFIG/policy.d/04webapps.policy

permission java.net.SocketPermission "127.0.0.1:3306", "connect";

Работает для меня, надеюсь, это будет работать и для вас:)

1 голос
/ 29 марта 2012
Class.forName("com.mysql.jdbc.Driver");
            con=DriverManager.getConnection("jdbc:mysql://localhost:3306/indiadb","root","root");

Проверка:

  1. номер порта должен быть только 3306

  2. Добавьте mysql.jar в lib, если вы используете Tomcat6

0 голосов
/ 02 февраля 2010

Пожалуйста, попробуйте с "официальным" Connector / J 5.1 , т.е. распространяемым MySQL, а не deb (обратите внимание, что я ничего не имею против deb).

Также, пожалуйста, включите --log-warnings на сервере MySQL и посмотрите, появляется ли что-нибудь в ваших журналах ошибок.

...