Реализация сокета UNIX для Java?
Я понимаю, что, поскольку сокеты UNIX специфичны для платформы, должен быть какой-то не-Java-код. В частности, мы заинтересованы в использовании JDBC для подключения к экземпляру MySQL, в котором включены только сокеты домена UNIX.
не похоже, что это поддерживается, но из того, что я прочитал, должно быть по крайней мере возможно написать SocketFactory для JDBC на основе сокетов UNIX Если мы можем найти достойную реализацию сокетов UNIX для Java.
кто-нибудь пробовал это? Кто-нибудь знает о такой реализации?
7 ответов
вы можете использовать junixsocket:https://github.com/kohlschutter/junixsocket
Он уже предоставляет код для подключения к MySQL из Java (Connector / J) через сокеты Unix.
одно большое преимущество по сравнению с другими реализациями заключается в том, что junixsocket использует стандартный API сокетов Java.
как оригинал kohlschutter/junixsocket, упомянутый в другом ответе, кажется, мертв, вы можете проверить его вилки.
особенно fiken/junixsocket выглядит многообещающе. Его автор добавил поддержку подключения к PostgreSQL с помощью сокета unix через pgjdbc, например.
на драйвер MariaDB JDBC теперь поддерживает это и совместим с драйвером JDBC MySQL.
используйте url JDBC, например:
jdbc:mariadb://localhost:3306/revmgt?localSocket=/var/run/mysqld/mysqld.sock
стоит отметить, что эта библиотека требует включения библиотеки JNA, поскольку она использует JNA для доступа к собственным сокетам домена unix. Она работает довольно хорошо в моем тестировании. Я видел улучшения скорости на связанных с процессором java-процессах от разгрузки до собственного кода.
на проект JNR (что является свободной основой для проект Панама), имеет сокет unix реализация.
некоторый поиск в интернете обнаружил следующую полезную библиотеку:
http://www.nfrese.net/software/gnu_net_local/overview.html
написание фабрики сокетов должно быть достаточно простым. Как только вы это сделаете, вы можете передать его своему водителю так.(Wayback Link).
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.Statement;
import com.mysql.management.driverlaunched.ServerLauncherSocketFactory;
public class ConnectorMXJTestExample {
public static void main(String[] args) throws Exception {
String hostColonPort = "localhost:3336";
String driver = com.mysql.jdbc.Driver.class.getName();
String url = "jdbc:mysql://" + hostColonPort + "/" + "?"
+ "socketFactory="
+ ServerLauncherSocketFactory.class.getName();
String userName = "root";
String password = "";
Class.forName(driver);
Connection conn = null;
try {
conn = DriverManager.getConnection(url, userName, password);
Statement stmt = conn.createStatement();
ResultSet rs = stmt.executeQuery("SELECT VERSION()");
rs.next();
String version = rs.getString(1);
rs.close();
stmt.close();
System.out.println("------------------------");
System.out.println(version);
System.out.println("------------------------");
} finally {
try {
conn.close();
} catch (Exception e) {
e.printStackTrace();
}
ServerLauncherSocketFactory.shutdown(hostColonPort);
}
}
}