|
| 1 | +{ |
| 2 | + // Devcontainer-Sicherheitsmodell: Push aus Container ist hart geblockt (DEVCONTAINER=true + pre-push-Hook). |
| 3 | + // Keine Credentials im Image, kein SSH-Agent-Forwarding, keine Cred-Mounts. |
| 4 | + // Quelle: ~/.claude/vault/concepts/devcontainer-architektur.md |
| 5 | + "name": "java-properties", |
| 6 | + |
| 7 | + // 2026-05-13: JDK 25 LTS zum Zeitpunkt dieser Vorlage. Verfuegbarkeit pruefen mit: |
| 8 | + // docker manifest inspect mcr.microsoft.com/devcontainers/java:25-bookworm |
| 9 | + // Fallback falls 25er-Tag noch nicht verfuegbar: java:21-bookworm. |
| 10 | + // Microsoft-Java-Bookworm bringt JDK mit, **kein Maven** — wird im post-create per apt installiert. |
| 11 | + "image": "mcr.microsoft.com/devcontainers/java:25-bookworm", |
| 12 | + |
| 13 | + // Features: |
| 14 | + // - docker-outside-of-docker: docker-CLI im Container + Sock-Permissions/Group fuer nonroot-User. |
| 15 | + // Voraussetzung fuer Testcontainers, jib, ko, Buildpacks (alles was Sibling-Container startet). |
| 16 | + // Maven wird absichtlich NICHT ueber `features/java:1` installiert: das SDKMAN-Feature scheitert |
| 17 | + // in manchen buildx-Sandbox-Netzen am Internet-Healthcheck. apt im post-create ist robust und |
| 18 | + // liefert Maven 3.8.7 (Debian Bookworm). Wer ein anderes Maven braucht: Apache-Tarball im |
| 19 | + // post-create unpacken oder eigenen Layer im Dockerfile. |
| 20 | + "features": { |
| 21 | + "ghcr.io/devcontainers/features/docker-outside-of-docker:1": {} |
| 22 | + }, |
| 23 | + |
| 24 | + // Sicherheitsmarker: Hook .githooks/pre-push prueft diesen Wert und blockt bei "true". |
| 25 | + // JDWP-Opts: agent listet auf 5005 fuer Remote-Debugging. suspend=n -> Build startet sofort. |
| 26 | + // TESTCONTAINERS_HOST_OVERRIDE: Sibling-Container (Ryuk, Test-DB) sind ueber Host-Gateway |
| 27 | + // erreichbar, nicht ueber default-bridge `172.17.0.1`. runArgs unten haengt `host.docker.internal` |
| 28 | + // an /etc/hosts (Linux-Equivalent zum Mac/Win-Default). Wenn das Repo keinen Testcontainers-Pfad |
| 29 | + // hat (kein jOOQ-Generate o.ae.), kann der Override entfernt werden — schadet aber nicht. |
| 30 | + // JAVA_HOME: Eclipse Temurin (Adoptium) statt Microsoft OpenJDK. post-create.sh installiert |
| 31 | + // Temurin parallel zum Microsoft-JDK aus dem Image. Begruendung: Distributions-Konsistenz mit |
| 32 | + // CI (setup-java distribution=temurin) und Toolchains, die das Temurin-JDK-Layout erwarten |
| 33 | + // (z.B. JAVA_HOME/Packages). Microsoft-OpenJDK liegt ungenutzt parallel — IDE-Indexing nimmt JAVA_HOME. |
| 34 | + "containerEnv": { |
| 35 | + "DEVCONTAINER": "true", |
| 36 | + "MAVEN_OPTS": "-agentlib:jdwp=transport=dt_socket,server=y,suspend=n,address=*:5005", |
| 37 | + "TESTCONTAINERS_HOST_OVERRIDE": "host.docker.internal", |
| 38 | + "JAVA_HOME": "/usr/lib/jvm/temurin-25-jdk-amd64" |
| 39 | + }, |
| 40 | + |
| 41 | + // - --add-host: Linux-Equivalent zu Mac/Win `host.docker.internal`. Fuer Testcontainers. |
| 42 | + // - --name: fester Container-Name (`devcontainer-<basename>`) — verbessert `docker ps`-Lesbarkeit. |
| 43 | + // Konflikte handhabt devcontainer-CLI via --remove-existing-container. |
| 44 | + // Unterstuetzt `./dev down` (siehe dev-skripte.md). |
| 45 | + "runArgs": [ |
| 46 | + "--add-host=host.docker.internal:host-gateway", |
| 47 | + "--name", "devcontainer-${localWorkspaceFolderBasename}" |
| 48 | + ], |
| 49 | + |
| 50 | + // 5005 = JDWP (Remote JVM Debug, IntelliJ/VS Code). App-Port hier ergaenzen, z.B. 8080. |
| 51 | + "forwardPorts": [5005], |
| 52 | + |
| 53 | + // Mounts: |
| 54 | + // - docker.sock: Daemon-Zugriff fuer Testcontainers + Build-Tools mit Container-Targets. |
| 55 | + // Trade-off + Anti-Pattern (NIE im Production-Image): vault/concepts/devcontainer-architektur.md "Docker-Zugriff im Container". |
| 56 | + // - m2 Named Volume: persistenter Maven-Cache. Permissions im post-create gechownt |
| 57 | + // (Docker-Named-Volumes sind root:root by default; vscode-User braucht Schreibzugriff). |
| 58 | + // - target/ NICHT als Root-Volume bei Multi-Module-Repos (jedes Sub-Modul hat eigenes target/). |
| 59 | + "mounts": [ |
| 60 | + "source=/var/run/docker.sock,target=/var/run/docker.sock,type=bind", |
| 61 | + "source=devcontainer-${localWorkspaceFolderBasename}-m2,target=/home/vscode/.m2,type=volume" |
| 62 | + ], |
| 63 | + |
| 64 | + // Maven via apt + Volume-chown + Push-Block-Hook. Script erlaubt sauberes Fehler-Handling. |
| 65 | + "postCreateCommand": ".devcontainer/post-create.sh", |
| 66 | + |
| 67 | + "customizations": { |
| 68 | + "vscode": { |
| 69 | + "extensions": [ |
| 70 | + "vscjava.vscode-java-pack", |
| 71 | + "vscjava.vscode-maven" |
| 72 | + ] |
| 73 | + } |
| 74 | + } |
| 75 | +} |
0 commit comments