如何配置 Hibernate ORM 数据库属性以使用 Docker

How to configure Hibernate ORM database properties to work with Docker

为了连接到数据库,我使用了一个网络套接字,它在我的 hibernate.cfg.xml 中指定为:

<property name="connection.url">jdbc:postgresql://localhost:PORT/DBNAME</property>

连同用户名、密码:

    <property name="connection.username">user</property>
    <property name="connection.password">pass</property>

我想使用 docker 进行部署。

我的问题是目前我必须更改源代码(例如 hibernate.cfg.xml),并重新生成一个新的 .war 文件,每次我想重新部署。

有没有办法避免这种情况?我可以使用相同的 .war 文件和 link 动态地从 docker 到数据库吗?

我想我可以有一个包含数据库凭据的配置文件(类似于 .env),并让 java 和 docker 读取它,但我现在不配置docker 这样做

我相信你有以下选择:

  • <property name="connection.username">${db.user}</property>
  • 一样在 XML 中使用系统属性
  • 使用 Maven 配置文件和过滤器维护不同的 hibernate.cfg.xml 文件,以便为每个环境选择正确的文件
  • 使用编程配置和系统属性或环境变量

系统属性的问题在于,要使用它们,您必须在应用服务器中设置它们,使用属性文件或通过命令行传递它们,如 -Ddb.user=foo 中所示。要在应用程序服务器中设置它们,您必须让容器使用 CLI、REST API,或者可能是另一个配置文件(这次是服务器)来设置它。这将取决于您将 .war 部署到什么。通过命令行传递这些属性存在数据库凭据以纯文本形式存在于任何可以列出该进程的人的问题。

维护多个配置文件或使用属性文件也很痛苦,它会增加构建过程的开销,我认为没有必要,至少不需要设置简单的凭据。

我相信你最好的选择是使用 programmatic configuration。然后你所要做的就是在容器内设置正确的环境变量。在您的应用程序中,这只是一个问题:

Configuration cfg = new Configuration()
    .setProperty("connection.username", System.getenv("DB_USER"))
    // ...