In diesem Lab zeigen wir auf, wie Templates ganze Infrastrukturen beschreiben und entsprechend mit einem Befehl instanziert werden können.
Wie Sie in den vorangegangenen Labs gesehen haben, können einfach über die Eingabe unterschiedlicher Befehle Applikationen, Datenbanken, Services und deren Konfiguration erstellt und deployt werden.
Dies ist fehleranfällig und eignet sich schlecht zum Automatisieren.
OpenShift bietet dafür das Konzept von Templates, in welchen man eine Liste von Resourcen beschreiben kann, die parametrisiert werden können. Sie sind also quasi ein Rezept für eine ganze Infrastruktur (bspw. 3 ApplikationsContainer, eine Datenbank mit Persistent Storage)
Note: der Clusteradmin kann globale Templates erstellen, welche allen Usern zur Verfügung stehen.
Alle vorhandenen Templates anzeigen
$ oc get template -n openshift
Über die Web Console kann dies via "Add to Project" gemacht werden, über diese Funktionalität können Templates direkt instanziert werden.
Diese Templates können im Json Format sowohl im Git Repositors neben ihrem Source Code abgelegt werden wie auch über eine URL aufgerufen oder gar lokal im Filesystem abgelegt sein.
Die einzelnen Schritte die wir in den vorherigen Labs manuell vorgenommen haben, können nun mittels Template in einem "Rutsch" durchgeführt werden.
$ oc new-project [USER]-template
Template erstellen
$ oc create -f https://raw.githubusercontent.com/appuio/example-spring-boot-helloworld/master/example-spring-boot-template.json
Template instanzieren (Ersetzen Sie [project]
mit [USER]-template
)
$ oc new-app example-spring-boot -pMYSQL_DATASOURCE=jdbc:mysql://mysql.[project].svc.cluster.local/appuio
--> Deploying template example-spring-boot for "example-spring-boot"
With parameters:
APPLICATION_DOMAIN=
DATABASE_SERVICE_NAME=postgresql
MYSQL_DATABASE_NAME=appuio
MYSQL_USER=appuio
MYSQL_PASSWORD=appuio
MYSQL_DATASOURCE=jdbc:mysql://mysql.techlab-template.svc.cluster.local/appuio
MYSQL_DRIVER=com.mysql.jdbc.Driver
--> Creating resources ...
ImageStream "example-spring-boot" created
DeploymentConfig "example-spring-boot" created
DeploymentConfig "mysql" created
Route "example-spring-boot" created
Service "example-spring-boot" created
Service "mysql" created
--> Success
Run 'oc status' to view your app.
OpenShift startet danach automatisch einen Build und deployt die Container danach wie im Template spezifiziert.
Tipp: Sie könnten Templates auch direkt verarbeiten in dem Sie ein Template direkt $ oc new-app -f template.json -p Param = value
aufrufen
Als Abschluss dieses Labs können Sie sich noch das Template anschauen
https://github.com/appuio/example-spring-boot-helloworld/blob/master/example-spring-boot-template.json
Note: Bestehende Resourcen können als Template exportiert werden, verwenden Sie dafür den oc export [ResourceType] --as-myapptemplate
Command.
Bspw.
oc export bc,is,dc,route,service --as-template=example-spring-boot -o json > example-spring-boot-template.json
Ende Lab 11
[<< zurück zur Übersicht] (../README.md)