==== Hogyan futtatható Docker környezetben egy Maven projekt? ====
Használjuk a docker playground-ot: http://docker.iit.uni-miskolc.hu
Klónozzuk a //Wildfly// alkalmazás szerver példáit:
git clone https://github.com/wildfly/quickstart.git
cd quickstart/helloworld
Docker segítségével lefordíthatunk egy tetszőleges példát:
docker run -it --rm --name helloworld -v "$(pwd)":/usr/src/helloworld -w /usr/src/helloworld maven:3.8.7-openjdk-18-slim mvn clean install
A parancs magyarázata az alábbi:
* **docker run**: Ez a parancs futtatja a Docker konténert.
* **-it**: Ez a kapcsoló lehetővé teszi az interaktív módot és csatlakoztatja a terminált a konténerhez, hogy kommunikálni lehessen vele.
* **--rm**: Ez a kapcsoló jelzi a Dockernek, hogy törölje a konténert, mielőtt újraindítjuk. Ezzel elérhetjük, hogy a próbálgatások során újra létrejön a tároló újra és nem mentődik el az előző állapot.
* **--name helloworld**: Ez a kapcsoló nevet ad a konténernek. Ebben az esetben a konténer neve "helloworld" lesz.
* **-v "$(pwd)":/usr/src/helloworld**: Ez a kapcsoló köti össze a jelenlegi munkakönyvtárat (ahol a Docker parancsot futtatják) a konténerben lévő /usr/src/helloworld mappával. Ez azt jelenti, hogy a jelenlegi munkakönyvtár tartalma elérhető lesz a konténerben.
* **-w /usr/src/helloworld**: Ez a kapcsoló beállítja a munkakönyvtárat a konténerben a /usr/src/helloworld mappára. Ez azt jelenti, hogy a következő parancs a konténerben ebben a mappában fog végrehajtódni.
* **maven:3.8.7-openjdk-18-slim**: Ez a Docker image, amelyet a konténer alapként használ. Itt a maven:3.8.7-openjdk-18-slim image-t használja, amely tartalmazza a Maven-t és az OpenJDK 18-at.
* **mvn clean install**: Ez a parancs futtatódik a konténerben. Itt a Maven-t indítja el a konténerben a "clean install" céllal. Ez a Maven parancs kitörli az előző fordítási eredményeket, majd újrafordítja és telepíti a projektet.
Hozzunk létre egy másik Dockerfile-t a ./target könyvtárban:
FROM quay.io/wildfly/wildfly
ADD helloworld.war /opt/jboss/wildfly/standalone/deployments
Indítsuk el az alábbi két parancsot:
Az első létrehozza a kontainert, a második pedig elindítja.
docker build -t quay.io/wildfly/wildfly .
docker run -p 8080:8080 quay.io/wildfly/wildfly
"Open port" gomb megnyomása után a 8080-as portot kérjük megnyitni, majd az url.hez írjuk hozzá: /helloworld/
==== Ugyanez a feladat hogyan oldható meg docker-compose.yml használatával? ====
Ha egy új konténert is indítunk, akkor a //git clone//-ról se feledkezzünk meg:
git clone https://github.com/wildfly/quickstart.git
cd quickstart
A docker-compose.yml rugalmasabb megoldást ad, mert nem kell több parancsot megjegyezni, hanem egy fájlban kezelhetjük a beállításokat.
Tehát a //quickstart// könyvtárban hozzuk létre az alábbi //docker-compose.yml//-t:
version: '3'
services:
compiler:
image: maven:3.8.7-openjdk-18-slim
volumes:
- ./helloworld:/usr/src/helloworld
working_dir: /usr/src/helloworld
command: mvn clean install
A fenti megoldás sem eléggé rugalmas, mert a helloword-on kívül más példát is el szeretnénk indítani. Menjünk vissza a //quickstart// könyvtárba és hozzunk létre egy //.env// fájlt és tároljuk el környezeti változóként az elérési utat:
Az .env állományt a beépített editor nem listázza így vi-al is tudjuk szerkeszteni.
EXAMPLE_FOLDER=helloworld
Készítsünk egy Dockerfile-t az alábbi tartalommal:
FROM quay.io/wildfly/wildfly
ADD ./$EXAMPLE_FOLDER/target/$EXAMPLE_FOLDER.war /opt/jboss/wildfly/standalone/deployments
A //docker-compose.yml// az alábbi lesz:
version: '3'
services:
compiler:
image: maven:3.8.7-openjdk-18-slim
volumes:
- ./${EXAMPLE_FOLDER}:/usr/src/${EXAMPLE_FOLDER}
working_dir: /usr/src/${EXAMPLE_FOLDER}
command: mvn clean install
wildfly:
build: .
environment:
- "EXAMPLE_FOLDER=helloworld"
ports:
- 8080:8080
depends_on:
- compiler
Indítsuk el a //docker-compose up// paranncsal.
**Megjegyzés:**
Ha magunk hozzuk létre a //Dockerfile//-t vagy //docker-compose.yml//-t akkor óhatatlanul is elronthatjuk, ilyenkor a következő paranccsal lehet újrafordítani:
docker-compose build --no-cache