Talend Open Studio for ESB (Download) ist eine erweiterte Version des ETL-Werkzeugs Talend Open Studio. Neben der Möglichkeit Daten aus unterschiedlichen Quellen zu extrahieren, diese umzuwandeln und abzugleichen bevor sie anderenorts gespeichert werden, erlaubt es ESB auch auf einfache Weise SOAP- oder REST-Webservices zu entwicklen.
In unserem Blog haben wir schon früher über die Möglichkeit berichtet, so zum Beispiel enaio®-Dashlets auf einfache Weise zu entwerfen.
Nach der Entwicklung müssen diese Strecken im von Talend ESB mitgelieferten Karaf-Container-Runtime deployed werden, um als eigenständiger Service ohne die Entwicklungsumgebung genutzt werden zu können. Diese Laufzeitumgebung kann unter Windows als Service beziehungsweise Linux als Daemon eingerichtet werden.
Flexibel und reproduzierbar lässt sich diese Laufzeitumgebung aber auch in wenigen Handgriffen als Docker-Container erzeugen. Hier ein einfaches Beispiel:
Dockerfile
FROM ubuntu:20.04
RUN apt-get update && apt-get -y install \
openjdk-8-jre-headless \
unzip \
wget \
&& rm -rf /var/lib/apt/lists/*
RUN wget -O /tmp/esb.zip \
"https://freefr.dl.sourceforge.net/project/talendesb/Talend Open Studio for ESB/7.3.1/TOS_ESB-20200219_1130-V7.3.1.zip"
RUN cd /tmp/ \
&& unzip esb.zip Runtime_ESBSE/* -d /opt/ \
&& rm esb.zip \
&& cd /opt/Runtime_ESBSE/ \
&& mv * .. \
&& cd .. \
&& rmdir Runtime_ESBSE
CMD ["/opt/container/bin/trun", "server"]
Sofern die Docker-Umgebung bereits installiert ist, kann diese Datei als Dockerfile
mittels der Standardwerkzeuge gebaut und direkt gestartet werden.
Nutzung
docker build . -t talend-karaf
docker run -d -p 8080:8088 --name=talend-karaf talend-karaf
Je nach Anbindung an den Download-Server und Computer kann der build
-Schritt durchaus einige Minuten in Anspruch nehmen. Danach kann der Container aber beliebig wiederverwendet oder ergänzt werden.
In diesem Beispiel öffnen wir einen Port 8080
am Dockerhost, der auf den Port 8088
des Containers weitergeleitet wird. In unserer Talend ESB-Strecke können wir diesen Port vorsehen/konfigurieren:
Die Talend-Strecke wird beim Übersetzen in der Talend-Umgebung in eine einzelne JAR-Datei zusammengebaut. Diese können wir endwender fix im Dockerfile dem Container hinzufügen (ADD myservice_0.1.jar /opt/container/deploy/myservice.jar
) oder nachträglich in den laufenden Container kopieren:
docker cp \
./myservice_0.1.jar \
talend-karaf:/opt/container/deploy/myservice.jar
Diese Variante erlaubt wahlweise es im Laufe des Containerlebens diverse Versionen des Services zu deployen.