您现在访问的是微软AZURE全球版技术文档网站,若需要访问由世纪互联运营的MICROSOFT AZURE中国区技术文档网站,请访问 https://docs.azure.cn.

快速入门:在 Azure 应用服务中创建 Java 应用

Azure 应用服务提供高度可缩放、自修复的 Web 托管服务。 本快速入门介绍如何将 Azure CLI用于 Maven 的 Azure Web 应用插件配合使用来部署 .jar 文件或 .war 文件。 使用选项卡在 Java SE 和 Tomcat 说明之间切换。

备注

也可使用 IntelliJ 和 Eclipse 等常见 IDE 执行相同的操作。 请查看 Azure Toolkit for IntelliJ 快速入门Azure Toolkit for Eclipse 快速入门中的类似文档。

在 Azure 应用服务中运行的示例应用

如果还没有 Azure 订阅,可以在开始前创建一个免费帐户

使用 Azure Cloud Shell

Azure 托管 Azure Cloud Shell(一个可通过浏览器使用的交互式 shell 环境)。 可以将 Bash 或 PowerShell 与 Cloud Shell 配合使用来使用 Azure 服务。 可以使用 Azure Cloud Shell 预安装的命令来运行本文中的代码,而不必在本地环境中安装任何内容。

若要启动 Azure Cloud Shell,请执行以下操作:

选项 示例/链接
选择代码块右上角的“试用”。 选择“试用”不会自动将代码复制到 Cloud Shell。 Azure Cloud Shell 的“试用”示例
转到 https://shell.azure.com 或选择“启动 Cloud Shell”按钮可在浏览器中打开 Cloud Shell。 在新窗口中启动 Cloud Shell
选择 Azure 门户右上角菜单栏上的 Cloud Shell 按钮。 Azure 门户中的“Cloud Shell”按钮

若要在 Azure Cloud Shell 中运行本文中的代码,请执行以下操作:

  1. 启动 Cloud Shell。

  2. 选择代码块上的“复制”按钮以复制代码。

  3. 在 Windows 和 Linux 上选择 Ctrl+Shift+V 将代码粘贴到 Cloud Shell 会话中,或在 macOS 上选择 Cmd+Shift+V 将代码粘贴到 Cloud Shell 会话中。

  4. 选择 Enter 运行此代码。

创建 Java 应用

克隆 Spring Boot 入门示例项目。

git clone https://github.com/spring-guides/gs-spring-boot

将目录更改为已完成项目。

cd gs-spring-boot/complete

配置 Maven 插件

部署到 Azure 应用服务的过程会自动使用 Azure CLI 中的 Azure 凭据。 如果未在本地安装 Azure CLI,则 Maven 插件将使用 Oauth 或设备登录名进行身份验证。 有关详细信息,请参阅 Maven 插件的身份验证

运行下面的 Maven 命令来配置部署。 此命令将帮助你设置应用服务操作系统、Java 版本和 Tomcat 版本。

mvn com.microsoft.azure:azure-webapp-maven-plugin:1.14.0:config
  1. 当系统提示“订阅”选项时,通过在行首输入数字来选择适当的 Subscription

  2. 当系统提示“Web 应用”选项时,按 Enter 键接受默认选项 <create> 或选择一个现有应用。

  3. 当系统提示 OS 选项时,通过输入 3 选择 Windows 。

  4. 当系统提示“定价层”选项时,通过输入 2 选择 B2 。

  5. 按 Enter 使用默认的 Java 版本 Java 8。

  6. 最后,出现最后一个提示时按 Enter 来确认所做的选择。

    摘要输出将类似于下面所示的代码片段。

    Please confirm webapp properties
    Subscription Id : ********-****-****-****-************
    AppName : spring-boot-1599007390755
    ResourceGroup : spring-boot-1599007390755-rg
    Region : westeurope
    PricingTier : Basic_B2
    OS : Windows
    Java : 1.8
    WebContainer : java 8
    Deploy to slot : false
    Confirm (Y/N)? : Y
    [INFO] Saving configuration to pom.
    [INFO] ------------------------------------------------------------------------
    [INFO] BUILD SUCCESS
    [INFO] ------------------------------------------------------------------------
    [INFO] Total time: 41.118 s
    [INFO] Finished at: 2020-09-01T17:43:45-07:00
    [INFO] ------------------------------------------------------------------------
    
  1. 当系统提示“订阅”选项时,通过在行首输入数字来选择适当的 Subscription

  2. 当系统提示“Web 应用”选项时,按 Enter 键接受默认选项 <create> 或选择一个现有应用。

  3. 当系统提示 OS 选项时,按 Enter 键选择 Linux 。

  4. 当系统提示“定价层”选项时,通过输入 2 选择 B2 。

  5. 按 Enter 使用默认的 Java 版本 Java 8。

  6. 最后,出现最后一个提示时按 Enter 来确认所做的选择。

    Please confirm webapp properties
    Subscription Id : ********-****-****-****-************
    AppName : spring-boot-1599007116351
    ResourceGroup : spring-boot-1599007116351-rg
    Region : westeurope
    PricingTier : Basic_B2
    OS : Linux
    RuntimeStack : JAVA 8-jre8
    Deploy to slot : false
    Confirm (Y/N)? : Y
    [INFO] Saving configuration to pom.
    [INFO] ------------------------------------------------------------------------
    [INFO] BUILD SUCCESS
    [INFO] ------------------------------------------------------------------------
    [INFO] Total time: 20.925 s
    [INFO] Finished at: 2020-09-01T17:38:51-07:00
    [INFO] ------------------------------------------------------------------------
    

如果需要,可以直接在 pom.xml 中修改应用服务的配置。 下面列出了一些常见配置:

属性 必须 说明 版本
<schemaVersion> false 指定配置架构的版本。 支持的值是:v1v2 1.5.2
<subscriptionId> false 指定订阅 ID。 0.1.0+
<resourceGroup> true 用于 Web 应用的 Azure 资源组。 0.1.0+
<appName> true Web 应用的名称。 0.1.0+
<region> true 指定将托管 Web 应用的区域;默认值为“westeurope”。 支持的区域部分中列出了所有有效区域。 0.1.0+
<pricingTier> false Web 应用的定价层。 生产工作负载的默认值为 P1V2,而 B2 是建议用于 Java 开发/测试的最低值 。 了解详细信息 0.1.0+
<runtime> true 运行时环境配置,可以在此处查看详细信息。 0.1.0+
<deployment> true 部署配置,可以在此处查看详细信息。 0.1.0+

请注意 <appName><resourceGroup> 的值(在演示中相应地为 helloworld-1590394316693helloworld-1590394316693-rg),后面会使用它们。

部署应用

Maven 插件会使用 Azure CLI 中的帐户凭据来部署到应用服务。 在继续操作之前使用 Azure CLI 登录

az login

然后你可使用以下命令将 Java 应用部署到 Azure。

mvn package azure-webapp:deploy

部署完成后,应用程序会在 http://<appName>.azurewebsites.net/(在演示中为 http://helloworld-1590394316693.azurewebsites.net)处准备就绪。 在本地 Web 浏览器中打开 url,你应该会看到

在 Azure 应用服务中运行的示例应用

祝贺你! 现已将第一个 Java 应用部署到应用服务。

清理资源

在前面的步骤中,你在资源组中创建了 Azure 资源。 如果认为将来不需要这些资源,请通过门户删除资源组,或在 Cloud Shell 中运行以下命令来这样做:

az group delete --name <your resource group name; for example: helloworld-1558400876966-rg> --yes

此命令可能需要花费一点时间运行。

后续步骤