Im Bereich von Microservices und verteilten Systemen – aber nicht nur dort – ist es wichtig zu wissen, ob ein Service/System ordnungsgemäß läuft oder gestört ist. Im MicroProfile (https://microprofile.io) ist mit MicroProfile Health ein Teil enthalten, der es in Kombination mit CDI sehr einfach macht, Health Checking in EE-Anwendungen zu integrieren.
Health Check Callbacks
Die Idee von MicroProfile Health ist, dass Anwendungen auf EE-Servern oder auf Basis von MicroProfile-Frameworks ein oder mehrere Methoden zum Prüfen des Gesundheitszustandes enthalten. Der Server sammelt die Zustände bei Bedarf ein und aggregiert daraus einen Gesamtzustand, der auf dem Rest-Endpoint /health
veröffentlicht wird:
GET /health 200 OK { "outcome": "UP", "checks": [{ "name": "Service1", "state": "UP", "data": { "memory": 180672240 } }, { "name": "Service2", "state": "UP" }] }
Die Callback-Methoden heißen – etwas uninspiriert – call
und stammen aus dem Interface org.eclipse.microprofile.health.HealthCheck
. Der Server sucht sich automatisch alle Klassen zusammen, die dieses Interface implementieren und mit dem CDI-Qualifier org.eclipse.microprofile.health.Health
versehen sind:
@ApplicationScoped @Health public class HealthCheck1 implements HealthCheck { @Override public HealthCheckResponse call() { ...
Das Prüfergebnis können die Methoden bequem mittels Builder-Pattern zusammensetzen:
public HealthCheckResponse call() { return HealthCheckResponse .named("Service1") .up() .withData("memory", Runtime.getRuntime().freeMemory()) .build();
Neben up
gibt es auch down
sowie die Methode status
, der der Gesundheitszustand als Parameter übergeben wird.
Gesamtgesundheit
Bei einem GET-Request auf den Pfad /health
werden alle verfügbaren call
-Methoden aus allen Anwendungen des Servers aufgerufen und zu einem Gesamtzustand kombiniert. Liefern alle Checks UP
, ist das Attribut outcome
im Gesamtergebnis ebenfalls UP
und der Response hat den Status 200 OK
. Andernfalls wird der Response mit 503 Service unavailable
ausgeliefert und outcome
ist darin DOWN
.
Plattformen
MicroProfile Health wird u. a. von folgenden JEE-Servern unterstützt:
- OpenLiberty (mit aktiviertem Feature
mpHealth-1.0
). - Payara.
- WildFly (Achtung: WildFly hat unterschiedliche Ports für Applikations- und Management-Zugriffe, im Default
8080
und9990
. Der o. a. REST-Endpoint/health
steht über den Management-Port zur Verfügung).
Die genannten Klassen befinden sich bspw. in der Maven-Dependency org.eclipse.microprofile:microprofile
.
Demo
In https://github.com/GEDOPLAN/health-demo finden Sie ein Beispielprojekt mit zwei Health Checks, deren Ergebnis über eine Webseite beeinflusst werden kann. Die Anwendung kann als WAR-File auf einen der genannten Server deployt werden. Alternativ können über vorkonfigurierte Maven-Profile Docker-Images zum direkten Ausprobieren erstellt werden.
Ausblick
Im Beispiel wird als Zusatzinformation die Menge freien Speichers hinzugefügt, was im Kontext von Health Checking nicht grundsätzlich falsch ist, aber doch eher eine Metrik darstellt. Für deren Veröffentlichung hält MicroProfile eine weitere Teilspezifikation bereit: MicroProfile Metrics. Sie wird Gegenstand eines der nächsten Blog Posts sein – stay tuned!
Bis bald – vielleicht auch in einem unserer Trainings in Berlin, Bielefeld, Köln oder bei Ihnen!
https://gedoplan-it-training.de/
1 Kommentar. Hinterlasse eine Antwort
Danke für den WildFly-Port-Hinweis – ich hab mir einen Wolf gesucht, warum das nicht ging wie in allen Tutorials beschrieben!