-
Notifications
You must be signed in to change notification settings - Fork 444
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Custom configuration is replaced with the default one during package install #378
Comments
Actually you have three options. Use the one suited best for your use case application.conf => reference.confThe easiest solution would be to rename your Read about the standard behavior of typesafe config if you are not sure what's happening. Specify config in etc-defaultThe Typesafe Config provides a way to specify where it should search for the configuration. You can provide a etc-default in -Dconfig.file=/usr/share/${{app_name}}/conf/production.conf
# if you use play, you should specifiy a pid dir as well
-Dpidfile.path=/var/run/${{app_name}}/play.pid Chef now provides a This example uses exclude application.conf from debianThe solution is actually pretty simple. Just don't package your The example is taken from Filter/Remove mappings. Note that this will affect all packaging types (as we filter the universal mappings). mappings in Universal := {
// universalMappings: Seq[(File,String)]
val universalMappings = (mappings in Universal).value
// removing means filtering
universalMappings filter {
case (file, name) => ! name.endsWith("application.conf")
}
} If you want a concise version mappings in Universal := {
(mappings in Universal).value filter {
case (file, name) => ! name.endsWith("application.conf")
}
} The result will be a debian package that doesn't contain an |
@muuki88 that was a great answer, it helped me a lot! Thank you! TLDR; It was necessary to use a mix of 'reference.conf' and 'etc-default' options. More detailed description below. I don't really like the idea of completely excluding configuration from the package (I feel like every good package should have reference configuration file). And also this option would involve slight changes in CI build plan configuration. Not much work, but nevertheless. I was up to "application.conf => reference.conf". It seemed like a good fit allowing me to provide my own production application.conf and also providing a fallback config so CI builds won't go red. However just dropping
I'm not sure why, but init script doesn't signal any errors in this case. It just said:
Is it expected, or I'm just doing something wrong? Since I need
That fixed a problem, and now application starts smoothly. P.S. It feels like we need more detailed docs on Play native packaging and deployment then what we have at the moment. It is not a very complicated stuff, but it is confusing for new people like me when nothing works and you don't know if it is supposed to be so, or you just doing something wrong. |
Thanks for the detailed feedback as well :) The problem that
You did are really good job describing your solution. I'll be happy to merge a pull request :) |
Deal! I could describe deb- and rpm- packaging of Play 2 apps and place it in a section "Packaging Play 2 Applications" under "Advanced Topics". Does it seem reasonable? |
Sounds like a plan :) Looking forward to it |
Hello @muuki88, I think this is more a bug : the debian conffile in target/DEBIAN/conffile gets filled with a /usr/share/{app}/conf//application.log. mappings in Universal ++= { val confDirectoryLen = confDirectory.value.getCanonicalPath.length val pathFinder = confDirectory.value ** ("*" -- "routes") pathFinder.get map { confFile: File => confFile -> ("conf/" + confFile.getCanonicalPath.substring(confDirectoryLen)) } } confDirectory is "/conf" so confFile.getCanonicalPath.substring(confDirectoryLen) is "/application.conf" My workaround is to post process the mappings in build.sbt mappings in Universal := { (mappings in Universal).value map { case (file,name) if name startsWith "conf//" => (file, "conf/" + name.substring(6)) case (file,name) => (file,name) } } But maybe there is a better solution ? |
That's definitely a bug! Adding UPDATE Sorry, I missread. |
Did you open a bug for this on the playframework? cc @jroper |
This is probably fixed in Play, here: |
I'm not sure if what I'm doing is the right way of doing things. If there is a better way, please tell me.
However the problem is that when I install a deb. package with my Play 2 app, I get my custom production application.conf replaced with the default application.conf from sources. The whole story is as follows.
I have a Chef-repo with the description of my production configuration. As a part of provisioning process a custom application.conf with production settings (db, migrations, etc.) is placed at /etc/my_app/application.conf.
When the provisioning of production VM is completed, I continue with the my_app.deb package installation. I expect that after the package is installed, the application would be running with my production config. However during the installation production
/etc/my_app/application.conf
is replaced with default application.conf from the sources. Because of that application server can't start (and I actually get a flapping service with a stream of "can't connect to database[default]" in /var/upstart/my_app.log)The same thing If I install a newer version of a package.
I really want to do the initial VM setup with Chef (including production application.conf generation), and want my production config to be persisted between package install/reinstall, but I don't understand where shall I put my config file and how I shall start a service, so the things would run smoothly.
The text was updated successfully, but these errors were encountered: