Przykładowe wdrożenie aplikacji Java
W tej lekcji skonfigurujesz aplikację platformy Spring Boot do wdrożenia za pośrednictwem programu Maven. Następnie aplikacja zostanie wdrożona w wystąpieniu Azure App Service. W tej lekcji pokazano przykład przychodni weterynaryjnej.
Przykładowa aplikacja
Sklonuj aplikację w ulubionym narzędziu wiersza polecenia.
git clone https://github.com/spring-projects/spring-petclinic.git
Następnie uruchom ją lokalnie.
cd spring-petclinic
./mvnw package
java -jar target/*.jar
Po otwarciu przykładu w przeglądarce powinien on wyglądać następująco:
Przygotowywanie przykładowej aplikacji do użycia w chmurze
W folderze src znajdziesz klasy Objects (obiekty), Controller (kontroler) i Repository (repozytorium).
Ponieważ język Java jest niezależny od platformy, możesz wybrać system operacyjny, ale wersja języka Java jest ważna dla wdrożenia. Wersję języka Java można znaleźć w pliku pom.xml.
<properties>
<java.version>17</java.version>
</properties>
W tym przykładzie użyto języka Java 8, więc nasze wystąpienie usługi aplikacja systemu Azure , zarówno w systemie Linux, jak i Windows, powinno również używać języka Java 8. Ponieważ platforma nie ma znaczenia, w naszym przykładzie będziemy używać systemu Linux.
Musimy dodać pewne zależności platformy Azure do pliku pom.xml. Dodanie zależności może nastąpić automatycznie, jeśli uruchomisz następujące polecenie:
mvn com.microsoft.azure:azure-webapp-maven-plugin:2.11.1:config
Uruchomienie tego polecenia spowoduje wyświetlenie monitu o określenie pewnych opcji. Te opcje będą przechowywane automatycznie w naszym pliku pom.xml.
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
Jak widzisz, w prostym wdrożeniu możesz skorzystać z wartości domyślnych.
Plik pom.xml dodał teraz wymaganą wtyczkę dla automatycznego wdrożenia opartego na programie Maven na platformie Azure.
<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>
Wdrażanie aplikacji za pomocą programu Maven
Przygotowaliśmy się już do wdrożenia w usłudze Azure App Service.
mvn package com.microsoft.azure:azure-webapp-maven-plugin:1.12.0:deploy
To polecenie uruchamia testy. Następnie automatycznie uruchamia wystąpienie Azure App Service i wdraża spakowaną aplikację.
Gratulacje! Aplikacja została pomyślnie wdrożona w usłudze Azure App Service.