Реализация сокета UNIX для Java?

Я понимаю, что, поскольку сокеты UNIX специфичны для платформы, должен быть какой-то не-Java-код. В частности, мы заинтересованы в использовании JDBC для подключения к экземпляру MySQL, в котором включены только сокеты домена UNIX.

не похоже, что это поддерживается, но из того, что я прочитал, должно быть по крайней мере возможно написать SocketFactory для JDBC на основе сокетов UNIX Если мы можем найти достойную реализацию сокетов UNIX для Java.

кто-нибудь пробовал это? Кто-нибудь знает о такой реализации?

7 ответов


проверка библиотеки JUDS. Это библиотека сокетов домена Java Unix...

https://github.com/mcfunley/juds


вы можете использовать junixsocket:https://github.com/kohlschutter/junixsocket

Он уже предоставляет код для подключения к MySQL из Java (Connector / J) через сокеты Unix.

одно большое преимущество по сравнению с другими реализациями заключается в том, что junixsocket использует стандартный API сокетов Java.


как оригинал kohlschutter/junixsocket, упомянутый в другом ответе, кажется, мертв, вы можете проверить его вилки.

особенно fiken/junixsocket выглядит многообещающе. Его автор добавил поддержку подключения к PostgreSQL с помощью сокета unix через pgjdbc, например.


Проверьте библиотеку JNA. Это промежуточный дом между чистым Java и родным кодом JNI

https://github.com/twall/jna/


на драйвер 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

написание фабрики сокетов должно быть достаточно простым. Как только вы это сделаете, вы можете передать его своему водителю так.(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);
        }
    }
}