2016-09-01 4 views
-1

私は(とりわけ)リモートデータベースに問い合わせるJavaアプリケーションを開発しています。データベースへの接続に問題があります。 私のコードは次のとおりです。JavaでリモートMySQLデータベースに接続するにはどうすればよいですか?

com.mysql.jdbc.exceptions.jdbc4.CommunicationsException: 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. 
    at sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method) 
    at sun.reflect.NativeConstructorAccessorImpl.newInstance(Unknown Source) 
    at sun.reflect.DelegatingConstructorAccessorImpl.newInstance(Unknown Source) 
    at java.lang.reflect.Constructor.newInstance(Unknown Source) 
    at com.mysql.jdbc.Util.handleNewInstance(Util.java:404) 
    at com.mysql.jdbc.SQLError.createCommunicationsException(SQLError.java:988) 
    at com.mysql.jdbc.MysqlIO.<init>(MysqlIO.java:341) 
    at com.mysql.jdbc.ConnectionImpl.coreConnect(ConnectionImpl.java:2251) 
    at com.mysql.jdbc.ConnectionImpl.connectOneTryOnly(ConnectionImpl.java:2284) 
    at com.mysql.jdbc.ConnectionImpl.createNewIO(ConnectionImpl.java:2083) 
    at com.mysql.jdbc.ConnectionImpl.<init>(ConnectionImpl.java:806) 
    at com.mysql.jdbc.JDBC4Connection.<init>(JDBC4Connection.java:47) 
    at sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method) 
    at sun.reflect.NativeConstructorAccessorImpl.newInstance(Unknown Source) 
    at sun.reflect.DelegatingConstructorAccessorImpl.newInstance(Unknown Source) 
    at java.lang.reflect.Constructor.newInstance(Unknown Source) 
    at com.mysql.jdbc.Util.handleNewInstance(Util.java:404) 
    at com.mysql.jdbc.ConnectionImpl.getInstance(ConnectionImpl.java:410) 
    at com.mysql.jdbc.NonRegisteringDriver.connect(NonRegisteringDriver.java:328) 
    at java.sql.DriverManager.getConnection(Unknown Source) 
    at java.sql.DriverManager.getConnection(Unknown Source) 
    at com.joshuaevanslowell.IO.<clinit>(IO.java:41) 
    at com.joshuaevanslowell.Speculator.<init>(Speculator.java:46) 
    at com.joshuaevanslowell.Speculator.main(Speculator.java:32) 
Caused by: java.net.ConnectException: Connection timed out: connect 
    at java.net.DualStackPlainSocketImpl.connect0(Native Method) 
    at java.net.DualStackPlainSocketImpl.socketConnect(Unknown Source) 
    at java.net.AbstractPlainSocketImpl.doConnect(Unknown Source) 
    at java.net.AbstractPlainSocketImpl.connectToAddress(Unknown Source) 
    at java.net.AbstractPlainSocketImpl.connect(Unknown Source) 
    at java.net.PlainSocketImpl.connect(Unknown Source) 
    at java.net.SocksSocketImpl.connect(Unknown Source) 
    at java.net.Socket.connect(Unknown Source) 
    at com.mysql.jdbc.StandardSocketFactory.connect(StandardSocketFactory.java:211) 
    at com.mysql.jdbc.MysqlIO.<init>(MysqlIO.java:300) 
    ... 17 more 

が、私はこれに対処他のいくつかの質問を見てきましたが、彼らは一般的に、データベースがローカルホスト、鉱山ISNであることを前提としています

private static String MYSQL_URL = "jdbc:mysql://db644874220.db.1and1.com"; 
private static String DB_NAME = "db644874220"; 
private static Connection CONNECTION; 
static { 
    String dbUrl = MYSQL_URL + "/" + DB_NAME; 
    try { 
     Class.forName("com.mysql.jdbc.Driver"); 
     CONNECTION = DriverManager.getConnection(dbUrl, MYSQL_USERNAME, MYSQL_PASSWORD); 
    } catch (SQLException | ClassNotFoundException e) { 
     e.printStackTrace(); 
    } 
} 

私が手にエラーがあります't。私は1 & 1ウェブホスティングを使用しています。私は、phpMyAdminを通して私のブラウザを通してデータベースで作業することができます。 - 5.5.50-0 + deb7u2ログ:db644874220.db.1and1.com

  • TCP/IP経由でサーバーの種類::MySQLの
  • Serverのバージョンは、サーバーに関する情報が与え

    • Serverです(Debianの)
    • プロトコルバージョン:10
    • ユーザー:[email protected]
    • サーバの文字セット:UTF-8のUnicode(UTF8)

    私はひどく間違ったことをしているように感じ、私はちょうどこれの頭や尾を作ることができません。

  • +0

    他のツールを使用して接続できますか?このリモートDBへのMySQL Workbench? –

    +0

    無料のホスティングを提供するWebサイトは、リモートデータベース接続を許可していません。独自のサーバーでホストされているスクリプトを使用してアクセスする必要があります。 –

    +0

    1and1は無料ではありません。ヘルプページやカスタマーサポートを確認してください。あなたがそれらを – Drew

    答えて

    -1

    私の推測では、db644874220.db.1and1.comホストは、あなたのJavaコードは、Javaコードまたはtelnet db644874220.db.1and1.com 3306を実行するマシンからping db644874220.db.1and1.comを行うには

    試みを実行した場所から知られていないということです。いずれも結果を返さない場合、そのマシンにその名前でアクセスする手段がないことを意味します。

    どちらかあなたはそれを知っている代わりに、場合IPを使用するか、telnetクライアントクライアントは、3306は、MySQLのポートであると仮定するとインストールしている場合は、あなたのホストが

    [IP address] db644874220.db.1and1.com 
    
    +0

    本当に支払う理由は、これはそれを引き起こす可能性がある多くの問題のほんの1つです。 –

    0

    をファイルに行を追加し、

    telnet ipaddress 3306してみてください。

    私はあなたがmysqlサーバに直接接続していない可能性があります。これを有効にするには、同様の質問で回答があるように設定を編集する必要があります。

    また、DB接続を閉じるか、接続プールを使用してください。開いている接続が多すぎると(設定された制限を超えている)、同様の問題が発生する可能性があります。

    関連する問題