配置文件

时间:2016-05-09 05:59:48

标签: payara payara-micro

我需要从配置文件中读取一些属性。我不想将属性文件存储在该位置内。什么是最佳实践

例如,如果执行如下

java -jar payara-micro.jar --deploy demo.jar

我想将参数文件保存在payara-micro.jar所在的位置。我需要读取war文件中的属性文件。如何实现它。

谢谢。

3 个答案:

答案 0 :(得分:1)

您可以先使用--rootDir 路径选项启动payara-micro。 Payara将这个目录视为工作,因此它在那里创建了`config'目录。然后根据需要编辑domain.xml文件并再次启动payara-micro。您照常创建的所有资源都可以在您的bean中使用。例如,您可以添加以下属性:

...

<resources>
    <jdbc-resource pool-name="DerbyPool" jndi-name="jdbc/__default" object-type="system-all" />
    <jdbc-connection-pool is-isolation-level-guaranteed="false" name="DerbyPool" datasource-classname="org.apache.derby.jdbc.EmbeddedDataSource" res-type="javax.sql.DataSource">
        <property name="databaseName" value="${com.sun.aas.instanceRoot}/lib/databases/embedded_default" />
        <property name="connectionAttributes" value=";create=true" />
    </jdbc-connection-pool>
    <connector-connection-pool max-pool-size="250" steady-pool-size="1" name="jms/__defaultConnectionFactory-Connection-Pool" resource-adapter-name="jmsra" connection-definition-name="javax.jms.ConnectionFactory"></connector-connection-pool>
    <connector-resource pool-name="jms/__defaultConnectionFactory-Connection-Pool" jndi-name="jms/__defaultConnectionFactory" object-type="system-all-req"></connector-resource>
    <context-service description="context service" jndi-name="concurrent/__defaultContextService" object-type="system-all"></context-service>
    <managed-executor-service maximum-pool-size="200" core-pool-size="1" long-running-tasks="true" keep-alive-seconds="300" hung-after-seconds="300" task-queue-capacity="20000" jndi-name="concurrent/__defaultManagedExecutorService" object-type="system-all"></managed-executor-service>
    <managed-scheduled-executor-service core-pool-size="1" long-running-tasks="true" keep-alive-seconds="300" hung-after-seconds="300" jndi-name="concurrent/__defaultManagedScheduledExecutorService" object-type="system-all"></managed-scheduled-executor-service>
    <managed-thread-factory description="thread factory" jndi-name="concurrent/__defaultManagedThreadFactory" object-type="system-all"></managed-thread-factory>
<custom-resource factory-class="org.glassfish.resources.custom.factory.PropertiesFactory" res-type="java.util.Properties" jndi-name="myconf">
  <property name="some.my.property" value="some.value"></property>
</custom-resource>
</resources>

(请参阅custom-resource标记)

然后将它注入你的bean:

@Resource(type=java.util.Properties.class, name="myconf")
private final Properties parameters;

您也可以指定--domainConfig文件以保持配置。

使用--help查看完整选项列表。

答案 1 :(得分:0)

您可以使用命令行参数将系统属性传递给payara micro,如下所示:

java -jar payara-micro.jar --deploy app.war --systemProperties=sys.properties 

另请查看Payara micro documentation about this option

答案 2 :(得分:0)

您可以传递domain.xml文件中配置的系统属性。这将覆盖默认的domain.xml。

java -jar payara-micro.jar --domainConfig domain.xml --deploy app.war 

您可以从payara-micro.jar

获取默认的domain.xml