我正在尝试配置部署到 Wildfly 23 的应用程序以使用托管身份连接到 Azure SQL,但很难想象它的工作原理。 互联网上有大量关于如何使用无密码连接连接到 Azure 托管数据库的文章和操作方法。其中大多数需要将 azure-identity.jar 包含到类路径中,并在 jdbc 连接字符串中使用 authentication=ActiveDirectoryMSI 选项。 但是,我的应用程序使用疯狂配置的连接池,因此将 azure-identity.jar 添加到我的应用程序将无济于事。根据我的理解,我需要使 azure-identity.jar 可用于 wildfly,但我不知道该怎么做。一个想法是将其注册为模块,我还没有尝试过,因为我需要以某种方式管理 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 身份验证的 MSAL4J Java 库
任何提示/帮助表示赞赏。
添加MSAL4J,包括类路径上的所有依赖项