Connect to remote MySQL database through SSH using Java

Alex picture Alex · Dec 28, 2009 · Viewed 69.4k times · Source

How can I connect to remote MySQL database through SSH from java application? Small code example is helpful for me and I'd appreciate this.

Answer

Pascal Thivent picture Pascal Thivent · Dec 28, 2009

My understanding is that you want to access a mysql server running on a remote machine and listening on let's say port 3306 through a SSH tunnel.

To create such a tunnel from port 1234 on your local machine to port 3306 on a remote machine using the command line ssh client, you would type the following command from your local machine:

ssh -L 1234:localhost:3306 mysql.server.remote

To do the same thing from Java, you could use JSch, a Java implementation of SSH2. From its website:

JSch allows you to connect to an sshd server and use port forwarding, X11 forwarding, file transfer, etc., and you can integrate its functionality into your own Java programs. JSch is licensed under BSD style license.

For an example, have a look at PortForwardingL.java. Once the session connected, create your JDBC connection to MySQL using something like jdbc:mysql://localhost:1234/[database] as connection URL.