Подтвердить что ты не робот

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

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

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

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

4b9b3361

Ответ 1

Оформить заказ в библиотеке JUDS. Это библиотека Java Socket Socket Java...

https://github.com/mcfunley/juds

Ответ 2

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

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

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

Ответ 3

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

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

Ответ 4

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

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

Ответ 5

Драйвер MariaDB JDBC теперь поддерживает это и совместим с драйвером JDBC MySQL.

Используйте URL-адрес JDBC, например:

jdbc:mariadb://localhost:3306/revmgt?localSocket=/var/run/mysqld/mysqld.sock

Стоит отметить, что в эту библиотеку требуется включить библиотеку JNA, поскольку она использует JNA для доступа к родным сокетам домена unix. Это очень хорошо работает в моем тестировании. Я видел улучшения скорости на процессорах, связанных с java-процессами от разгрузки до собственного кода.

Ответ 6

В некоторых поисках в Интернете обнаружена следующая полезная библиотека:

http://www.nfrese.net/software/gnu_net_local/overview.html

Wayback Link

Написание сокета 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);
        }
    }
}