Estoy tratando de crear una conexión a mi base de datos, cuando puse a prueba mi código usando el método principal, funciona a la perfección. Sin embargo, cuando intenta acceder a través de Tomcat 7, falla con el error:Cómo solucionar: "No se encontró un controlador adecuado para el error jdbc: mysql: // localhost/dbname" cuando se usan pools?
No suitable driver found for jdbc:mysql://localhost/dbname.
Estoy usando la agrupación. Puse en bibliotecas mysql connector (5.1.15), dbcp (1.4) y pool (1.4.5) en WEB-INF/lib y en .classpath también. Estoy usando Eclipse IDE. Mi código para el controlador de base de datos es:
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;
import org.apache.tomcat.dbcp.dbcp.ConnectionFactory;
import org.apache.tomcat.dbcp.dbcp.DriverManagerConnectionFactory;
import org.apache.tomcat.dbcp.dbcp.PoolableConnectionFactory;
import org.apache.tomcat.dbcp.dbcp.PoolingDriver;
import org.apache.tomcat.dbcp.pool.impl.GenericObjectPool;
public class DatabaseConnector {
public static String DB_URI = "jdbc:mysql://localhost/dbname";
public static String DB_USER = "test";
public static String DB_PASS = "password";
// Singleton instance
protected static DatabaseConnector _instance;
protected String _uri;
protected String _username;
protected String _password;
/**
* Singleton, so no public constructor
*/
protected DatabaseConnector(String uri, String username, String password) {
_uri = uri;
_username = username;
_password = password;
GenericObjectPool connectionPool = new GenericObjectPool(null);
ConnectionFactory connectionFactory = new DriverManagerConnectionFactory(
_uri, _username, _password);
PoolableConnectionFactory poolableConnectionFactory =
new PoolableConnectionFactory(connectionFactory, connectionPool,
null, null, false, true);
PoolingDriver driver = new PoolingDriver();
driver.registerPool("test", connectionPool);
}
/**
* Returns the singleton instance
*/
public static DatabaseConnector getInstance() {
if (_instance == null) {
_instance = new DatabaseConnector(DB_URI, DB_USER, DB_PASS);
}
return _instance;
}
/**
* Returns a connection to the database
*/
public Connection getConnection() {
Connection con = null;
try {
con = DriverManager.getConnection("jdbc:apache:commons:dbcp:test");
} catch (SQLException e) {
throw new RuntimeException(e);
}
return con;
}
}
inicio de mi seguimiento de la pila:
Apr 5, 2011 9:49:14 PM org.apache.catalina.core.StandardWrapperValve invoke
SEVERE: Servlet.service() for servlet [Login] in context with path [/Project]
threw exception
java.lang.RuntimeException: java.sql.SQLException:
No suitable driver found for jdbc:mysql://localhost/dbname
lo que está causando este error?
Tenga en cuenta que esto definitivamente no es el enfoque correcto para utilizar las instalaciones de conexión de agrupación de Tomcat. – BalusC
Otra cosa a tener en cuenta es la sintaxis de la url de conexión. Tuve 'jdbc: mysql // localhost: 3306' en lugar de' jdbc: mysql: // localhost: 3306' –