java 在Wildfly中配置无密码Azure SQL

jvlzgdj9  于 2023-09-29  发布在  Java
关注(0)|答案(2)|浏览(82)

我正在尝试配置部署到Wildfly 23的应用程序,以使用托管身份连接到Azure SQL,并努力想象它应该如何工作。互联网上有大量关于如何使用无密码连接连接到Azure托管数据库的文章和操作方法。大多数都需要在类路径中包含azure-identity.jar,并在jdbc连接字符串中使用 authentication=ActiveDirectoryMSI 选项。但是,我的应用程序使用了在中配置的连接池,因此将azure-identity.jar添加到我的应用程序不会有帮助。据我所知,我需要让wildfly可以使用azure-identity.jar,但我不确定如何做到这一点。一个想法是将其注册为一个模块,我还没有尝试过,因为我需要以某种方式管理jar的依赖关系。
到目前为止,我将独立文件更改为包含数据源

<datasource jndi-name="java:/jdbc/passwordless" pool-name="pwls-ds" enabled="true">
                    <connection-url>jdbc:sqlserver://xxxxx.database.windows.net:1433;database=aaa;encrypt=true;trustServerCertificate=false;hostNameInCertificate=*.database.windows.net;authentication=ActiveDirectoryMSI</connection-url>
                    <driver-class>com.microsoft.sqlserver.jdbc.SQLServerDriver</driver-class>
                    <driver>mssql-jdbc-12.4.1.jre11.jar</driver>
                    <transaction-isolation>TRANSACTION_READ_COMMITTED</transaction-isolation>
                    <pool>
                        <min-pool-size>2</min-pool-size>
                        <initial-pool-size>5</initial-pool-size>
                        <max-pool-size>20</max-pool-size>
                    </pool>
                </datasource>

当尝试测试连接时,我得到以下异常
com.microsoft.sqlserver.jdbc.SQLServerException:无法加载用于执行ActiveDirectoryManagedIdentity身份验证的MSAL 4J Java库
任何提示/帮助都很感激。

kadbb459

kadbb4591#

添加MSAL4J,包括类路径上的所有依赖项

pkln4tw6

pkln4tw62#

为了使它工作,我创建了一个自定义的fat jar,它结合了azure-identity和mssql-jdbc驱动程序,然后我以与普通驱动程序相同的方式部署它。对于引用pom文件来实现:

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
     xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
     xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>com.XXX.driver.sql</groupId>
<artifactId>XXX-sql-driver</artifactId>
<version>1.0-SNAPSHOT</version>
<properties>
    <maven.compiler.source>11</maven.compiler.source>
    <maven.compiler.target>11</maven.compiler.target>
    <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
</properties>
<dependencies>
    <dependency>
        <groupId>com.azure</groupId>
        <artifactId>azure-identity</artifactId>
        <version>1.8.1</version>
    </dependency>
    <dependency>
        <groupId>com.microsoft.sqlserver</groupId>
        <artifactId>mssql-jdbc</artifactId>
        <version>12.2.0.jre11</version>
    </dependency>
</dependencies>
<build>
    <plugins>
        <plugin>
            <groupId>org.apache.maven.plugins</groupId>
            <artifactId>maven-compiler-plugin</artifactId>
            <version>3.11.0</version>
            <configuration>
                <source>11</source>
                <target>11</target>
            </configuration>
        </plugin>

        <plugin>
            <groupId>org.apache.maven.plugins</groupId>
            <artifactId>maven-assembly-plugin</artifactId>
            <version>3.6.0</version>

            <configuration>
                <descriptorRefs>
                    <descriptorRef>jar-with-dependencies</descriptorRef>
                </descriptorRefs>
            </configuration>
            <executions>
                <execution>
                    <id>make-assembly</id>
                    <phase>package</phase>
                    <goals>
                        <goal>single</goal>
                    </goals>
                </execution>
            </executions>
        </plugin>
    </plugins>
</build>

我怀疑这是最好的解决方案它看起来更像是一个变通办法,所以仍在寻找。

相关问题