Problemas com conexão com banco mysql

6 respostas
marcusluiz83

Boa tarde!

Pessoal, de uma hora para outra, não consigo mais testar meus programas com conexão ao banco MySQL, online e local em meu computador de casa. Tenho uma classe para testar a conexão, que não me retorna erro. O erro é apenas quando executo o programa.

Detalhes: meu firewall está desativado, não uso antivírus, já tentei com Window$ e Ubuntu, desliguei o roteador, testei apenas o MySQL que está em minha máquina, atualizei o Netbeans, e sempre paro no mesmo erro:

com.mysql.jdbc.exceptions.jdbc4.CommunicationsException: Communications link failure

Last packet sent to the server was 0 ms ago.
	at sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method)
	at sun.reflect.NativeConstructorAccessorImpl.newInstance(NativeConstructorAccessorImpl.java:39)
	at sun.reflect.DelegatingConstructorAccessorImpl.newInstance(DelegatingConstructorAccessorImpl.java:27)
	at java.lang.reflect.Constructor.newInstance(Constructor.java:513)
	at com.mysql.jdbc.Util.handleNewInstance(Util.java:406)
	at com.mysql.jdbc.SQLError.createCommunicationsException(SQLError.java:1074)
	at com.mysql.jdbc.ConnectionImpl.createNewIO(ConnectionImpl.java:2103)
	at com.mysql.jdbc.ConnectionImpl.<init>(ConnectionImpl.java:718)
	at com.mysql.jdbc.JDBC4Connection.<init>(JDBC4Connection.java:46)
	at sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method)
	at sun.reflect.NativeConstructorAccessorImpl.newInstance(NativeConstructorAccessorImpl.java:39)
	at sun.reflect.DelegatingConstructorAccessorImpl.newInstance(DelegatingConstructorAccessorImpl.java:27)
	at java.lang.reflect.Constructor.newInstance(Constructor.java:513)
	at com.mysql.jdbc.Util.handleNewInstance(Util.java:406)
	at com.mysql.jdbc.ConnectionImpl.getInstance(ConnectionImpl.java:302)
	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 br.com.larasoft.conexao.CriaConexaoConsys.getConexao(CriaConexaoConsys.java:21)
	at br.com.larasoft.dao.RequisicaoDAO.<init>(RequisicaoDAO.java:28)
	at br.com.larasoft.forms.loja.Login.loginE(Login.java:205)
	at br.com.larasoft.forms.loja.Login.btAcessarActionPerformed(Login.java:136)
	at br.com.larasoft.forms.loja.Login.access$100(Login.java:28)
	at br.com.larasoft.forms.loja.Login$2.actionPerformed(Login.java:77)
	at javax.swing.AbstractButton.fireActionPerformed(AbstractButton.java:1995)
	at javax.swing.AbstractButton$Handler.actionPerformed(AbstractButton.java:2318)
	at javax.swing.DefaultButtonModel.fireActionPerformed(DefaultButtonModel.java:387)
	at javax.swing.DefaultButtonModel.setPressed(DefaultButtonModel.java:242)
	at javax.swing.plaf.basic.BasicButtonListener.mouseReleased(BasicButtonListener.java:236)
	at java.awt.Component.processMouseEvent(Component.java:6267)
	at javax.swing.JComponent.processMouseEvent(JComponent.java:3267)
	at java.awt.Component.processEvent(Component.java:6032)
	at java.awt.Container.processEvent(Container.java:2041)
	at java.awt.Component.dispatchEventImpl(Component.java:4630)
	at java.awt.Container.dispatchEventImpl(Container.java:2099)
	at java.awt.Component.dispatchEvent(Component.java:4460)
	at java.awt.LightweightDispatcher.retargetMouseEvent(Container.java:4577)
	at java.awt.LightweightDispatcher.processMouseEvent(Container.java:4238)
	at java.awt.LightweightDispatcher.dispatchEvent(Container.java:4168)
	at java.awt.Container.dispatchEventImpl(Container.java:2085)
	at java.awt.Window.dispatchEventImpl(Window.java:2478)
	at java.awt.Component.dispatchEvent(Component.java:4460)
	at java.awt.EventQueue.dispatchEvent(EventQueue.java:599)
	at java.awt.EventDispatchThread.pumpOneEventForFilters(EventDispatchThread.java:269)
	at java.awt.EventDispatchThread.pumpEventsForFilter(EventDispatchThread.java:184)
	at java.awt.EventDispatchThread.pumpEventsForHierarchy(EventDispatchThread.java:174)
	at java.awt.EventDispatchThread.pumpEvents(EventDispatchThread.java:169)
	at java.awt.EventDispatchThread.pumpEvents(EventDispatchThread.java:161)
	at java.awt.EventDispatchThread.run(EventDispatchThread.java:122)
Caused by: java.net.ConnectException: Connection timed out: connect
	at java.net.PlainSocketImpl.socketConnect(Native Method)
	at java.net.PlainSocketImpl.doConnect(PlainSocketImpl.java:333)
	at java.net.PlainSocketImpl.connectToAddress(PlainSocketImpl.java:195)
	at java.net.PlainSocketImpl.connect(PlainSocketImpl.java:182)
	at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:366)
	at java.net.Socket.connect(Socket.java:529)
	at java.net.Socket.connect(Socket.java:478)
	at java.net.Socket.<init>(Socket.java:375)
	at java.net.Socket.<init>(Socket.java:218)
	at com.mysql.jdbc.StandardSocketFactory.connect(StandardSocketFactory.java:253)
	at com.mysql.jdbc.MysqlIO.<init>(MysqlIO.java:280)
	at com.mysql.jdbc.ConnectionImpl.createNewIO(ConnectionImpl.java:2026)
	... 42 more

Minha classe de conexão:

package br.com.larasoft.conexao;

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;

/**
 *
 * @author marcus
 */
public class CriaConexaoLocaweb {

    public static Connection getConexao() throws SQLException {
        try {
            Class.forName("com.mysql.jdbc.Driver");
            System.out.println("Conectando ao banco");
            return DriverManager.getConnection("jdbc:mysql://endereço/schema", "user", "password");
        } catch (ClassNotFoundException e) {
            throw new SQLException(e.getMessage());
        }
    }
}

Minha classe para testar a conexão:

package br.com.larasoft.conexao;


import java.sql.Connection;
import java.sql.SQLException;

/*
 * To change this template, choose Tools | Templates
 * and open the template in the editor.
 */
/**
 *
 * @author marcus
 */
public class TestaConexaoLocaweb {

    public static void main(String[] args) throws SQLException {

        Connection conexao = (Connection) CriaConexaoLocaweb.getConexao();
        conexao.close();
        System.out.println("Desconectado do banco...");

    }
}

Apenas reforçando: utilizo um banco de dados da Locaweb, mas no MySQL que está instalado em meu computador também dá o mesmo erro.

Espero que possam me dar uma força.

Obrigado!

6 Respostas

Hebert_Coelho

Vc está passando a URL correta? jdbc:mysql://endereço/schema

marcusluiz83

Sim, sim. Rsrsrsrs.

Apenas alterei antes de postar aqui.

:lol:

jweibe

Se vc estiver acessando o MySQL por IP, vc deve primeiramente habilitar ele pra receber conexão por IP.
Eu particularmente edito o arquivo my.cnf (Linux = /etc/mysql/my.cnf) altero a linha
bind-address = 127.0.0.1
por
bind-address = 0.0.0.0

marcusluiz83

Nesse caso, seria para acessar o que está instalado em minha máquina, né? Mas eu não utilizo o ip, deixo como localhost. No banco externo, também não utilizo o ip.

O estranho é que até pouco tempo, estava tudo normal. Meus fontes estão arquivados no Dropbox, e no serviço está funcionando perfeitamente, só em casa que dá este erro.

Em minha casa, utilizo o método de testar a conexão, e dá certo, encontra o banco, valida os dados etc.

Sinceramente, não faço ideia do que pode ser.

jweibe

Já verificou se o MySQL Server foi instalado na porta padrão [3306]?

marcusluiz83

Sim! E também não tem nenhum firewall para impedir este acesso.

Criado 28 de janeiro de 2012
Ultima resposta 28 de jan. de 2012
Respostas 6
Participantes 3