-
Notifications
You must be signed in to change notification settings - Fork 121
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
Dockerfile for playground #178
base: master
Are you sure you want to change the base?
Conversation
igor-starostenko
commented
Feb 10, 2021
- Created Dockerfile for playground
- Fixed /jslt POST request
- Added docs
Feature/docker playground
…-readme Added readme for docker
Moved Dockerfile to root directory
This is an interesting idea, but I wonder a little about the value of it. I can see the value of using Docker for complicated tools consisting of several different processes and so on. But here we're just spinning up a jar file and connecting to a port. I do think there is value in putting all the pieces together as concisely as this, though, because it really lowers the bar for anyone who wants to run the playground locally. Even if they must have docker, which not everyone does. But, I wonder, could we not simply do this with a shell script? |
@larsga There are several reasons dockerizing the playground server can be beneficial.
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I think this is a good addition to the project. Personally, I already run JDK/JRE inside docker in my laptop, but it's nice if these images can be published automatically on releases to make it easier to play with the language.
Given that it's now possible to publish docker containers directly to GitHub, integrating this with GitHub Actions to do so could also be a nice addition.
|
||
COPY . . | ||
|
||
RUN ./gradlew :playground:shadowJar |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I suggest switching to a multi-stage build, so that the final docker container has only the JSLT jar on top of a slimmer JRE image. As it stands the final container will contain the full JDK plus any intermediate build artifacts.
Another alternative would be to build the jar outside docker and then package it in a vanilla JRE image directly. This has the downside that the Dockerfile and a running docker setup are no longer self-sufficient for bootstrapping.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This sounds very reasonable to me.
The number of dependencies is very low. Perhaps we could just get them from Maven Central with wget
or something?
+--- project :core
| \--- com.fasterxml.jackson.core:jackson-databind:2.12.0
| +--- com.fasterxml.jackson.core:jackson-annotations:2.12.0
| \--- com.fasterxml.jackson.core:jackson-core:2.12.0
\--- org.eclipse.jetty:jetty-server:9.4.29.v20200521
+--- javax.servlet:javax.servlet-api:3.1.0
+--- org.eclipse.jetty:jetty-http:9.4.29.v20200521
| +--- org.eclipse.jetty:jetty-util:9.4.29.v20200521
| \--- org.eclipse.jetty:jetty-io:9.4.29.v20200521
| \--- org.eclipse.jetty:jetty-util:9.4.29.v20200521
\--- org.eclipse.jetty:jetty-io:9.4.29.v20200521 (*)
We could also host the shadowJar as a github release or something, but this seems maybe simpler and more straightforward?
I think @igor-starostenko's rationale makes sense, and if more people are interested then I think we should just do it. I'm not using Docker, so I'm not the person to do it. Could you take it on, @biochimia? |