我正在尝试配置部署到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库
任何提示/帮助都很感激。
2条答案
按热度按时间kadbb4591#
添加MSAL4J,包括类路径上的所有依赖项
pkln4tw62#
为了使它工作,我创建了一个自定义的fat jar,它结合了azure-identity和mssql-jdbc驱动程序,然后我以与普通驱动程序相同的方式部署它。对于引用pom文件来实现:
我怀疑这是最好的解决方案它看起来更像是一个变通办法,所以仍在寻找。