-
Notifications
You must be signed in to change notification settings - Fork 360
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
WX-1566 Special Docker build for debugging #7417
Changes from 3 commits
3531c17
7d58cdd
64a3621
9554dbd
f25b506
becd1d0
8101f66
eb7ec2b
f23aadf
84591d2
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -34,4 +34,10 @@ jobs: | |
run: | | ||
set -e | ||
cd cromwell | ||
sbt -Dproject.isSnapshot=false -Dproject.isRelease=false docker | ||
sbt -Dproject.isSnapshot=false docker | ||
# Rarely used but we really want it always working for emergencies | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Thank you for adding this! |
||
- name: Build Cromwell Debug Docker | ||
run: | | ||
set -e | ||
cd cromwell | ||
sbt -Dproject.isDebug=true docker |
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -8,13 +8,6 @@ features or fixes, the following are required to build Cromwell from source: | |
* [AdoptOpenJDK 11 HotSpot](https://adoptopenjdk.net/) | ||
* [Git](https://git-scm.com/) | ||
|
||
You can also use the [development image](https://github.com/broadinstitute/cromwell/tree/develop/scripts/docker-develop), and build a development container to work inside: | ||
|
||
```bash | ||
$ docker build -t cromwell-dev . | ||
$ docker run -it cromwell-dev bash | ||
``` | ||
|
||
Comment on lines
-11
to
-17
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. I have not heard of anyone using this in many years |
||
First start by cloning the Cromwell repository from GitHub: | ||
|
||
```bash | ||
|
@@ -35,15 +28,15 @@ Finally build the Cromwell jar: | |
$ sbt assembly | ||
``` | ||
|
||
NOTE: This command will run for a long time the first time. | ||
NOTE: Compiling will not succeed on directories encrypted with ecryptfs (ubuntu encrypted home dirs for example), due to long file paths. | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. This encryption package has been removed from modern Ubuntu |
||
|
||
`sbt assembly` will build the runnable Cromwell JAR in `server/target/scala-2.13/` with a name like `cromwell-<VERSION>.jar`. It will also build a runnable Womtool JAR in `womtool/target/scala-2.13/` with a name like `womtool-<VERSION>.jar`. | ||
|
||
To build a [Docker](https://www.docker.com/) image, run: | ||
## Docker | ||
|
||
```bash | ||
$ sbt server/docker | ||
``` | ||
The following Docker build configurations are supported. Most users will want Snapshot, resulting in an image like `broadinstitute/cromwell:<VERSION>-SNAP`. | ||
|
||
This will build and tag a Docker image with a name like `broadinstitute/cromwell:<VERSION>-SNAP`. | ||
| Command | Build Type | Debug Tools | Description | | ||
|------------------------------------------------|------------|-------------|--------------------------------------| | ||
| `sbt server/docker` | Snapshot | No | Most common local build | | ||
| `sbt -Dproject.isDebug=true server/docker` | Debug | Yes | Local build with debugging/profiling | | ||
| `sbt -Dproject.isSnapshot=false server/docker` | Standard | No | Reserved for CI: commit on `develop` | | ||
| `sbt -Dproject.isRelease=true server/docker` | Release | No | Reserved for CI: numbered release | |
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,4 +1,4 @@ | ||
import Version.cromwellVersion | ||
import Version.{Debug, Release, Snapshot, Standard, cromwellVersion} | ||
import org.apache.ivy.Ivy | ||
import org.apache.ivy.core.IvyPatternHelper | ||
import org.apache.ivy.core.module.descriptor.{DefaultModuleDescriptor, MDArtifact} | ||
|
@@ -36,20 +36,26 @@ object Publishing { | |
ArrayBuffer(broadinstitute/cromwell:dev, broadinstitute/cromwell:develop) | ||
*/ | ||
dockerTags := { | ||
val versionsCsv = if (Version.isSnapshot) { | ||
// Tag looks like `85-443a6fc-SNAP` | ||
version.value | ||
} else { | ||
if (Version.isRelease) { | ||
// Tags look like `85`, `85-443a6fc` | ||
s"$cromwellVersion,${version.value}" | ||
} else { | ||
// Tag looks like `85-443a6fc`, `latest` | ||
s"${version.value},latest" | ||
} | ||
val tags = Version.buildType match { | ||
case Snapshot => | ||
// Ordinary local build | ||
// Looks like `85-443a6fc-SNAP` | ||
Seq(version.value) | ||
case Release => | ||
// Looks like `85`, `85-443a6fc` | ||
Seq(cromwellVersion, version.value) | ||
case Debug => | ||
// Ordinary local build with debug stuff | ||
// Looks like `85-443a6fc-DEBUG` | ||
Seq(version.value) | ||
case Standard => | ||
// Merge to `develop` | ||
// Looks like `85-443a6fc`, `latest`, `develop` | ||
// TODO: once we automate releases, `latest` should move to `Release` | ||
Seq(version.value, "latest", "develop") | ||
} | ||
|
||
// Travis applies (as of 10/22) the `dev` and `develop` tags on merge to `develop` | ||
val versionsCsv = tags.mkString(",") | ||
sys.env.getOrElse("CROMWELL_SBT_DOCKER_TAGS", versionsCsv).split(",") | ||
}, | ||
docker / imageNames := dockerTags.value map { tag => | ||
|
@@ -68,6 +74,11 @@ object Publishing { | |
add(artifact, artifactTargetPath) | ||
runRaw(s"ln -s $artifactTargetPath /app/$projectName.jar") | ||
|
||
// Extra tools in debug mode only | ||
if (Version.buildType == Debug) { | ||
addInstruction(installDebugFacilities) | ||
} | ||
|
||
/* | ||
If you use the 'exec' form for an entry point, shell processing is not performed and | ||
environment variable substitution does not occur. Thus we have to /bin/bash here | ||
|
@@ -116,6 +127,44 @@ object Publishing { | |
) | ||
) | ||
|
||
/** | ||
* Install packages needed for debugging when shelled in to a running image. | ||
* | ||
* This includes: | ||
* - The JDK, which includes tools like `jstack` not present in the JRE | ||
* - The YourKit Java Profiler | ||
* - Various Linux system & development utilities | ||
* | ||
* @return Instruction to run in the build | ||
*/ | ||
def installDebugFacilities: Instruction = { | ||
import sbtdocker.Instructions | ||
|
||
// It is optimal to use a single `Run` instruction to minimize the number of layers in the image. | ||
// Do not be tempted to install the default in the repositories, it's from Oracle. | ||
// | ||
// Documentation: | ||
// - https://www.yourkit.com/docs/java-profiler/2024.3/help/docker_broker.jsp#setup | ||
// - https://adoptium.net/installation/linux/#_deb_installation_on_debian_or_ubuntu | ||
Instructions.Run( | ||
"""apt-get update -qq && \ | ||
|apt-get install -qq --no-install-recommends file gpg htop less nload unzip vim && \ | ||
|wget -qO - https://packages.adoptium.net/artifactory/api/gpg/key/public | gpg --dearmor | \ | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. maybe also helpful to have There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more.
|
||
| tee /etc/apt/trusted.gpg.d/adoptium.gpg > /dev/null && \ | ||
|echo "deb https://packages.adoptium.net/artifactory/deb $(awk -F= '/^VERSION_CODENAME/{print$2}' /etc/os-release) main" | \ | ||
| tee /etc/apt/sources.list.d/adoptium.list && \ | ||
|apt-get update -qq && \ | ||
|apt-get install -qq temurin-11-jdk && \ | ||
|rm -rf /var/lib/apt/lists/* && \ | ||
|wget -q https://www.yourkit.com/download/docker/YourKit-JavaProfiler-2024.3-docker.zip -P /tmp/docker-build-cache/ && \ | ||
|unzip /tmp/docker-build-cache/YourKit-JavaProfiler-2024.3-docker.zip -d /tmp/docker-build-cache && \ | ||
|mkdir -p /usr/local/YourKit-JavaProfiler-2024.3/bin/ && \ | ||
|cp -R /tmp/docker-build-cache/YourKit-JavaProfiler-2024.3/bin/linux-x86-64/ /usr/local/YourKit-JavaProfiler-2024.3/bin/linux-x86-64/ && \ | ||
|rm -rf /tmp/docker-build-cache | ||
|""".stripMargin | ||
) | ||
} | ||
|
||
def dockerPushSettings(pushEnabled: Boolean): Seq[Setting[_]] = | ||
if (pushEnabled) { | ||
List( | ||
|
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.
Previously we needed both options to get a
Standard
build, it was a real head-scratcher to figure out. I'm still claiming the interface is unchanged because it's backwards compatible 😄