Ответ 1
Оформить заказ в библиотеке JUDS. Это библиотека Java Socket Socket Java...
Я понимаю, что, поскольку сокеты UNIX имеют специфику для платформы, должен быть задействован некоторый не-Java-код. В частности, мы заинтересованы в использовании JDBC для подключения к экземпляру MySQL, в котором включены только сокеты UNIX.
Не похоже, что это поддерживается, но из того, что я прочитал, должно быть, по крайней мере, возможно написать SocketFactory для JDBC на основе сокетов UNIX, если мы сможем найти достойную реализацию UNIX-сокетов для Java.
Кто-нибудь пробовал это? Кто-нибудь знает о такой реализации?
Оформить заказ в библиотеке JUDS. Это библиотека Java Socket Socket Java...
Вы можете использовать junixsocket: https://github.com/kohlschutter/junixsocket
Он уже предоставляет код для подключения к MySQL из Java (Connector/J) через сокеты Unix.
Одним большим преимуществом по сравнению с другими реализациями является то, что junixsocket использует стандартный Java Socket API.
Проверьте библиотеку JNA. Это полпути между чистым Java и собственным кодом JNI
Поскольку исходный 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-процессами от разгрузки до собственного кода.
В некоторых поисках в Интернете обнаружена следующая полезная библиотека:
http://www.nfrese.net/software/gnu_net_local/overview.html
Написание сокета factory должно быть достаточно простым. Как только вы это сделаете, вы можете передать его вашему драйверу THUSLY. (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);
}
}
}
Проект JNR (который является свободной основой для проекта panama) имеет реализацию unix socket.