Развертывание scala-приложения в виде контейнера докеров

Я пытаюсь развернуть это замечательное приложение Scala в качестве контейнера Docker. https://github.com/OlegIlyenko/graphql-toolbox

Он использует систему сборки sbt. Я попытался запустить sbt в контейнере, используя этот Dockerfile. https://gist.github.com/rzachariah/77eb927f650347ef06d0009dc220cd4a

Контейнер создается и запускается, но затем немедленно завершает работу.

Я предполагаю, что sbt run — это интерактивный процесс, а не демонизированный процесс. Вероятно, плохая идея sbt run в контейнере.

Я начал изучать sbt-assembly, чтобы создать толстую банку, которую я мог бы просто выполнить. https://github.com/sbt/sbt-assembly

Я получаю некоторые ошибки, когда делаю sbt assembly.

C:\Users\rzachariah\.ivy2\cache\commons-logging\commons-logging\jars\commons-logging-1.1.1.jar:org/apache/commons/logging/impl/SimpleLog.class at sbtassembly.Assembly$.applyStrategies(Assembly.scala:140) at sbtassembly.Assembly$.x$1$lzycompute$1(Assembly.scala:25) at sbtassembly.Assembly$.x$1$1(Assembly.scala:23) at sbtassembly.Assembly$.stratMapping$lzycompute$1(Assembly.scala:23) at sbtassembly.Assembly$.stratMapping$1(Assembly.scala:23) at sbtassembly.Assembly$.inputs$lzycompute$1(Assembly.scala:67) at sbtassembly.Assembly$.inputs$1(Assembly.scala:57) at sbtassembly.Assembly$.apply(Assembly.scala:83) at sbtassembly.Assembly$$anonfun$assemblyTask$1.apply(Assembly.scala:240) at sbtassembly.Assembly$$anonfun$assemblyTask$1.apply(Assembly.scala:237) at scala.Function1$$anonfun$compose$1.apply(Function1.scala:47) at sbt.$tilde$greater$$anonfun$$u2219$1.apply(TypeFunctions.scala:40) at sbt.std.Transform$$anon$4.work(System.scala:63) at sbt.Execute$$anonfun$submit$1$$anonfun$apply$1.apply(Execute.scala:228) at sbt.Execute$$anonfun$submit$1$$anonfun$apply$1.apply(Execute.scala:228) at sbt.ErrorHandling$.wideConvert(ErrorHandling.scala:17) at sbt.Execute.work(Execute.scala:237) at sbt.Execute$$anonfun$submit$1.apply(Execute.scala:228) at sbt.Execute$$anonfun$submit$1.apply(Execute.scala:228) at sbt.ConcurrentRestrictions$$anon$4$$anonfun$1.apply(ConcurrentRestrictions.scala:159) at sbt.CompletionService$$anon$2.call(CompletionService.scala:28) at java.util.concurrent.FutureTask.run(Unknown Source) at java.util.concurrent.Executors$RunnableAdapter.call(Unknown Source) at java.util.concurrent.FutureTask.run(Unknown Source) at java.util.concurrent.ThreadPoolExecutor.runWorker(Unknown Source) at java.util.concurrent.ThreadPoolExecutor$Worker.run(Unknown Source) at java.lang.Thread.run(Unknown Source) [error] (*:assembly) deduplicate: different file contents found in the following: [error] C:\Users\rzachariah\.ivy2\cache\io.netty\netty-handler\jars\netty-handler-4.0.36.Final.jar:META-INF/io.netty.versions.properties [error] C:\Users\rzachariah\.ivy2\cache\io.netty\netty-buffer\jars\netty-buffer-4.0.36.Final.jar:META-INF/io.netty.versions.properties [error] C:\Users\rzachariah\.ivy2\cache\io.netty\netty-common\jars\netty-common-4.0.36.Final.jar:META-INF/io.netty.versions.properties [error] C:\Users\rzachariah\.ivy2\cache\io.netty\netty-transport\jars\netty-transport-4.0.36.Final.jar:META-INF/io.netty.versions.properties [error] C:\Users\rzachariah\.ivy2\cache\io.netty\netty-codec\jars\netty-codec-4.0.36.Final.jar:META-INF/io.netty.versions.properties [error] C:\Users\rzachariah\.ivy2\cache\io.netty\netty-codec-http\jars\netty-codec-http-4.0.36.Final.jar:META-INF/io.netty.versions.properties [error] C:\Users\rzachariah\.ivy2\cache\io.netty\netty-transport-native-epoll\jars\netty-transport-native-epoll-4.0.36.Final-linux-x86_64.jar:META-INF/io.netty.versions.properties [error] deduplicate: different file contents found in the following: [error] C:\Users\rzachariah\.ivy2\cache\org.slf4j\jcl-over-slf4j\jars\jcl-over-slf4j-1.7.19.jar:org/apache/commons/logging/Log.class [error] C:\Users\rzachariah\.ivy2\cache\commons-logging\commons-logging\jars\commons-logging-1.1.1.jar:org/apache/commons/logging/Log.class [error] deduplicate: different file contents found in the following: [error] C:\Users\rzachariah\.ivy2\cache\org.slf4j\jcl-over-slf4j\jars\jcl-over-slf4j-1.7.19.jar:org/apache/commons/logging/LogConfigurationException.class [error] C:\Users\rzachariah\.ivy2\cache\commons-logging\commons-logging\jars\commons-logging-1.1.1.jar:org/apache/commons/logging/LogConfigurationException.class [error] deduplicate: different file contents found in the following: [error] C:\Users\rzachariah\.ivy2\cache\org.slf4j\jcl-over-slf4j\jars\jcl-over-slf4j-1.7.19.jar:org/apache/commons/logging/LogFactory.class [error] C:\Users\rzachariah\.ivy2\cache\commons-logging\commons-logging\jars\commons-logging-1.1.1.jar:org/apache/commons/logging/LogFactory.class [error] deduplicate: different file contents found in the following: [error] C:\Users\rzachariah\.ivy2\cache\org.slf4j\jcl-over-slf4j\jars\jcl-over-slf4j-1.7.19.jar:org/apache/commons/logging/impl/NoOpLog.class [error] C:\Users\rzachariah\.ivy2\cache\commons-logging\commons-logging\jars\commons-logging-1.1.1.jar:org/apache/commons/logging/impl/NoOpLog.class [error] deduplicate: different file contents found in the following: [error] C:\Users\rzachariah\.ivy2\cache\org.slf4j\jcl-over-slf4j\jars\jcl-over-slf4j-1.7.19.jar:org/apache/commons/logging/impl/SimpleLog$1.class [error] C:\Users\rzachariah\.ivy2\cache\commons-logging\commons-logging\jars\commons-logging-1.1.1.jar:org/apache/commons/logging/impl/SimpleLog$1.class [error] deduplicate: different file contents found in the following: [error] C:\Users\rzachariah\.ivy2\cache\org.slf4j\jcl-over-slf4j\jars\jcl-over-slf4j-1.7.19.jar:org/apache/commons/logging/impl/SimpleLog.class [error] C:\Users\rzachariah\.ivy2\cache\commons-logging\commons-logging\jars\commons-logging-1.1.1.jar:org/apache/commons/logging/impl/SimpleLog.class [error] Total time: 5 s, completed Oct 10, 2016 6:41:44 PM

Я думаю, мне нужно определить стратегию слияния, но я немного не понимаю, как это сделать. Любые указатели? Я полный новичок в Scala.


person Ranj    schedule 10.10.2016    source источник
comment
Я считаю, что это действительно плохая идея запускать производственное приложение с помощью sbt. Я упаковываю свои приложения с помощью этого плагина: scala-sbt.org/sbt-native-packager . Упакуйте его, а затем просто добавьте это жирное приложение в образ докера.   -  person Alexander Kondaurov    schedule 11.10.2016
comment
Вариантов упаковки здесь очень много. scala-sbt.org/sbt-native-packager Это хороший вариант упаковки? github.com/sbt/sbt-assembly Любые советы о том, как добавить стратегию слияния в сборка выглядит вот так? github.com/OlegIlyenko/graphql-toolbox/blob/master/build. sbt Спасибо!   -  person Ranj    schedule 11.10.2016


Ответы (1)


Я узнал, что, поскольку мое scala-приложение использует фреймворк play и встроенный упаковщик, упаковать мое приложение в контейнер очень просто!

sbt docker:publishLocal

http://www.scala-sbt.org/sbt-native-packager/formats/docker.html

person Ranj    schedule 13.10.2016