Beispielhafte Bereitstellung einer Java-App

Abgeschlossen

In dieser Einheit konfigurieren Sie eine Spring Boot-Anwendung, die über Maven bereitgestellt werden soll. Anschließend stellen Sie die Anwendung in einer Azure App Service-Instanz bereit. Diese Einheit zeigt das Beispiel einer Tierklinik.

Beispielanwendung

Klonen Sie Folgendes in Ihrem bevorzugten Befehlszeilentool:

git clone https://github.com/spring-projects/spring-petclinic.git

Führen Sie dann die Anwendung lokal aus:

cd spring-petclinic

./mvnw package

java -jar target/*.jar

Wenn Sie das Beispiel im Browser öffnen, sollte es wie folgt aussehen:

Screenshot der Navigation in der lokalen Bereitstellung der Tierklinikbeispielanwendung

Die Beispielanwendung cloudfähig machen.

Im Ordner "src " finden Sie Objekt-, Controller- und Repositoryklassen.

Da Java plattformunabhängig ist, können Sie das Betriebssystem auswählen, aber die Java-Version ist für die Bereitstellung wichtig. Sie finden die Java-Version in der pom.xml Datei.

<properties>
    <java.version>17</java.version>
</properties>

Im Beispiel wird Java 8 verwendet, daher sollte auch unsere Azure App Service-Instanz , ob Linux oder Windows, Java 8 verwenden. Da die Plattform keine Rolle spielt, verwenden wir Linux für unser Beispiel.

Wir müssen der pom.xml Datei einige Azure-Abhängigkeiten hinzufügen. Das Hinzufügen der Abhängigkeiten kann automatisch erfolgen, wenn Sie den folgenden Befehl ausführen:

mvn com.microsoft.azure:azure-webapp-maven-plugin:2.11.1:config

Die Ausgabe dieses Befehls fordert einige Optionen an, die angegeben werden sollen. Diese Optionen werden automatisch in pom.xmlgespeichert.

Please choose which part to config:
* 1: Application
  2: Runtime
  3: DeploymentSlot
Enter your choice: 1
Define value for appName [spring-petclinic-XXXX200]:
Define value for resourceGroup [spring-petclinic-XXXX200-rg]:
Define value for region [westeurope]:
Define value for pricingTier(P1v2):
   1: b1
   2: b2
   3: b3
   4: d1
   5: f1
*  6: p1v2
   7: p2v2
   8: p3v2
   9: s1
  10: s2
  11: s3
Enter your choice: 1
Please confirm webapp properties
AppName : spring-petclinic-XXXX200
ResourceGroup : spring-petclinic-XXXX200-rg
Region : westeurope
PricingTier : Basic_B2
OS : Linux
RuntimeStack : JAVA 8-jre8
Deploy to slot : false
Confirm (Y/N) [Y]: y

[INFO] Saving configuration to pom.
[INFO] ------------------------------------------------------------------------
[INFO] BUILD SUCCESS

Wie Sie sehen können, können Sie die Standardwerte für eine einfache Bereitstellung verwenden.

Die pom.xml Datei hat nun das erforderliche Plug-In für die automatische Maven-basierte Bereitstellung zu Azure hinzugefügt.

 <plugin>
    <groupId>com.microsoft.azure</groupId>  
        <artifactId>azure-webapp-maven-plugin</artifactId>  
        <version>2.11.1</version>  
        <configuration>
          <schemaVersion>V2</schemaVersion>  
          <subscriptionId>XXX-XXX-XXX</subscriptionId>  
          <resourceGroup>spring-petclinic-XXX200-rg</resourceGroup>  
          <appName>spring-petclinic-XXX200</appName>  
          <pricingTier>B2</pricingTier>  
          <region>westeurope</region>  
          <runtime>
            <os>linux</os>  
            <javaVersion>jre8</javaVersion>  
            <webContainer>jre8</webContainer>
          </runtime>  
          <deployment>
            <resources>
              <resource>
                <directory>${project.basedir}/target</directory>  
                <includes>
                  <include>*.jar</include>
                </includes>
              </resource>
            </resources>
          </deployment>
        </configuration>
  </plugin>

Bereitstellen der Anwendung mit Maven

Wir sind bereits auf die Bereitstellung für Azure App Service vorbereitet.

mvn package com.microsoft.azure:azure-webapp-maven-plugin:1.12.0:deploy

Dieser Befehl führt die Tests aus. Anschließend wird automatisch eine Azure App Service-Instanz gestartet und die verpackte Anwendung bereitgestellt.

Screenshot der bereitgestellten Beispielanwendung für Tierkliniken.

Glückwunsch! Die App wird erfolgreich in Azure App Service bereitgestellt.