Akka配置覆盖

时间:2013-09-27 11:13:15

标签: configuration akka maven-assembly-plugin

我正在尝试在我的应用程序中覆盖Akka配置。我为应用程序创建了额外的lib,它还有application.conf文件,因为它使用了Akka。所以我有两个:

application.conf in my lib: 
my-conf {
 something = 1
}

application.conf in my app, which uses the lib:
something-else = "foo"
my-conf {
 something = 1000
}

当我从Intellij Idea运行应用程序时,一切都很好,并且正在覆盖lib配置。要在我的应用中加载配置,我使用简单的ConfigFactory.load()操作。 但是当我使用mvn clean compile assembly:single创建我的应用程序的jar并尝试使用此命令运行它时:java -Xmx4048m -XX:MaxPermSize=512M -Xss256K -classpath myApp.jar com.myapp.example.MyMain我收到错误:

Caused by: com.typesafe.config.ConfigException$Missing: No configuration setting found for key 'something-else'

所以我决定在我的应用程序中重命名conf文件,并以这种方式加载它:

  val defConfig = ConfigFactory load
  val myConfig = ConfigFactory load "myconf"
  val combined = myConfig.withFallback(defConfig)
  val config = ConfigFactory load combined

它找到了丢失的设置,但遗憾的是我的应用程序中的配置不会覆盖我的lib中的配置。 在我的lib中,我以默认方式加载配置:val settings = ConfigFactory load 此外,“my-conf.something”是一个重要的设置,我想从我的应用程序覆盖它。

我做错了什么?提前谢谢!

另外,我认为如何创建jar可能存在问题:

<plugin>
            <artifactId>maven-assembly-plugin</artifactId>
            <version>2.4</version>
            <configuration>
                <archive>
                    <manifest>
                        <mainClass>com.myapp.example.MyMain</mainClass>
                    </manifest>
                </archive>
                <finalName>loadtest</finalName>
                <appendAssemblyId>false</appendAssemblyId>
                <descriptorRefs>
                    <descriptorRef>jar-with-dependencies</descriptorRef>
                </descriptorRefs>
            </configuration>
            <executions>
                <execution>
                    <id>dist-assembly</id>
                    <phase>package</phase>
                    <goals>
                        <goal>assembly</goal>
                    </goals>
                </execution>
            </executions>
        </plugin>

3 个答案:

答案 0 :(得分:6)

直接来自akka文档:

如果您使用Maven打包应用程序,您还可以使用Apache Maven Shade Plugin支持资源转换器将构建类路径上的所有reference.conf合并为一个。< / p>

这解决了我的问题。

 <transformers>
  <transformer
   implementation="org.apache.maven.plugins.shade.resource.AppendingTransformer">
   <resource>reference.conf</resource>
  </transformer>
  <transformer
   implementation="org.apache.maven.plugins.shade.resource.ManifestResourceTransformer">
   <manifestEntries>
    <Main-Class>akka.Main</Main-Class>
   </manifestEntries>
  </transformer>
</transformers>

答案 1 :(得分:2)

据我了解,您的库应该创建名为reference.conf的文件。根据{{​​3}}:

  

库应该使用应用提供的Config实例,如果有的话,   如果没有提供特殊的配置,请使用ConfigFactory.load()。   库应将其默认值设置为reference.conf   类路径。

所以,我建议先将reference.conf放入您的库中,以明确它是默认配置,并且您不需要withFallback - typesafe-config将处理它对你而言。

更新:我不记得maven-assembly-plugin是如何工作的 - 它可能会将所有jar文件和资源合并到一个文件中,这意味着lib/src/main/resources/application.conf将被覆盖在您的情况下app/src/main/resources/application.conf - 这是使用reference.conf的其他原因。

答案 2 :(得分:1)

那是对的!只是为了添加更多与该reference.conf相关的信息,我会说你应该去: Akka文档:http://akka.io/docs/?_ga=1.90177882.150089464.1402497958 ,选择您正在使用的版本,并在其中查找General-&gt; Configuration 在该页面内部查找&#39;参考配置列表,这是该reference.conf可能需要的所有内容。在我的情况下,我只是复制了它。

希望有时节省一些!