在persistence.xml文件中读取环境变量

时间:2012-01-12 14:39:19

标签: java java-ee spring-mvc persistence ejb-3.0

我想读取persistence.xml文件中的环境变量。

想法是我不希望从属性文件中读取我的数据库详细信息,因为获取属性文件覆盖的更改。相反,我想从环境变量中读取详细信息。

有没有办法达到这个标准。

我使用Spring 3,我的独立应用程序将部署在unix机器中。

3 个答案:

答案 0 :(得分:10)

您可以通过提供地图来更新持久性单元中的属性(请参阅this)。

方便地,环境变量可以作为Map检索(参见this)。

将两者放在一起,您可以使用环境变量动态更新持久性单元中的属性。

编辑:简单的例子......

...的persistence.xml

<persistence-unit name="default" transaction-type="RESOURCE_LOCAL">
    <provider>
        oracle.toplink.essentials.PersistenceProvider
    </provider>
    <exclude-unlisted-classes>false</exclude-unlisted-classes>
    <properties>
        <property name="toplink.logging.level" value="INFO"/>
        <property name="toplink.jdbc.driver" value="oracle.jdbc.OracleDriver"/>
        <property name="toplink.jdbc.url" value="jdbc:oracle:thin:@myhost:l521:MYSID"/>
        <property name="toplink.jdbc.password" value="tiger"/>
        <property name="toplink.jdbc.user" value="scott"/>
    </properties>
</persistence-unit>

使用环境变量更新persistence.xml“default”单元的代码...

Map<String, String> env = System.getenv();
Map<String, Object> configOverrides = new HashMap<String, Object>();
for (String envName : env.keySet()) {
    if (envName.contains("DB_USER")) {
        configOverrides.put("toplink.jdbc.user", env.get(envName)));    
    }
    // You can put more code in here to populate configOverrides...
}

EntityManagerFactory emf =
    Persistence.createEntityManagerFactory("default", configOverrides);

答案 1 :(得分:1)

我认为这不会涵盖通过注射创建的EM。更糟糕的是,我认为通过EMF创建的EM只能是EXTENDED(例如,等同于注释@PersistenceContext(type = PersistenceContextType.TRANSACTION),与EXTENDED相对),因此如果需要事务EM,则必须使用注入。

我想知道是否可以在运行时物理重写persistence.xml文件。问题一是,能够重写文件(权限,能够在META-INF等中获取它),其次,在JPA第一次打开之前重写它(我认为这是第一次注入EM时字段实际上由应用程序代码引用

答案 2 :(得分:0)

You could use this working example.

它从PersistenceUnitInfo实例获取persistence.xml中定义的所有属性,该实例是从EntityManagerFactory获得的(通过使用eclipseLink特定实现)。这些属性将替换为环境变量中定义的值。