Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/mozilla/docker-sbt

Dockerfile for sbt (Scala build tool)
https://github.com/mozilla/docker-sbt

Last synced: 3 months ago
JSON representation

Dockerfile for sbt (Scala build tool)

Awesome Lists containing this project

README

        

# docker-sbt
Dockerfile for sbt (Scala build tool)

This is built on top of the
[openjdk](https://hub.docker.com/_/openjdk/) image
and takes inspiration from
[hseeberger/scala-sbt](https://github.com/hseeberger/scala-sbt).

## Usage

Install [Docker](https://www.docker.com/) and pull the image
([mozilla/sbt](https://hub.docker.com/r/mozilla/sbt/) on DockerHub):

docker pull mozilla/sbt

You can then run `sbt` inside docker to compile code like:

docker run -it --rm mozilla/sbt sbt shell

If you want to execute sbt commands on a project on your local
filesystem, you may want to mount the current directory and various
local caches as volumes and set the working directory as well:

docker run -it --rm -v ~/.ivy2:/root/.ivy2 -v ~/.sbt:/root/.sbt -v $PWD:/app -w /app mozilla/sbt sbt shell

## Building

To build, you need to specify the desired openjdk and sbt versions via
`--build-arg` parameters:

docker build --build-arg OPENJDK_TAG=11.0.13 --build-arg SBT_VERSION=1.6.2 .

## Pushing a new tag to DockerHub

To push and tag a new image with updated versions of openjdk and sbt,
you'll need to have a DockerHub account that's a member of the appropriate
Mozilla organization and be logged in to DockerHub:

docker login --username=mydockerhubusername

Then use the following recipe to build and push:

```bash
OPENJDK_TAG=11.0.13
SBT_VERSION=1.6.2

docker build \
--build-arg OPENJDK_TAG=$OPENJDK_TAG \
--build-arg SBT_VERSION=$SBT_VERSION \
--tag mozilla/sbt:${OPENJDK_TAG}_${SBT_VERSION} \
--tag mozilla/sbt:latest \
.

docker push mozilla/sbt:${OPENJDK_TAG}_${SBT_VERSION}
docker push mozilla/sbt:latest
```