我需要从配置文件中读取一些属性。我不想将属性文件存储在该位置内。什么是最佳实践
例如,如果执行如下
java -jar payara-micro.jar --deploy demo.jar
我想将参数文件保存在payara-micro.jar所在的位置。我需要读取war文件中的属性文件。如何实现它。
谢谢。
答案 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
答案 2 :(得分:0)
您可以传递domain.xml文件中配置的系统属性。这将覆盖默认的domain.xml。
java -jar payara-micro.jar --domainConfig domain.xml --deploy app.war
您可以从payara-micro.jar
获取默认的domain.xml