写点什么

如何在 Azure Stack 上使用 Web App PaaS 服务?

  • 2017-10-09
  • 本文字数:3733 字

    阅读完需:约 12 分钟

App Service 是微软 Azure 的 PaaS 产品,为任何平台或设备创建 Web App PaaS 服务和 mobile App PaaS 服务,将应用与 SaaS 解决方案集成、与本地应用程序进行连接,以实现业务流程的自动化。在我们日常开发中,经常会使用 Web App PaaS 服务来承载企业的业务。

本文试图通过一个案例来分别详细说明 Azure Web App 业务的下列几大特点:

  • 应用服务计划
  • 多种语言和框架
  • 持续集成和部署
  • 连接数据库服务
  • 可用性全局缩放

就在本文撰写过程中,Azure Stack Development Kit GA,Azure Stack Tools 也进行了一定程度的更新。后续,我们会根据更新内容测试之后,更新相关技术文档。

应用服务计划

App Service Plan(应用服务计划):表示托管应用的物理资源的集合,例如 region(区域)、scale count(规模计数,多少个实例)、instance size(实例大小)、SKU(免费、共享、基础、标准、高级)。

App Service 中的 Web 应用、移动应用、API 应用、Function App(或 Functions)均在应用服务计划中运行。 同一订阅、区域和资源组中的应用可共享应用服务计划。

值得注意的是,Azure Stack App Service 提供的服务与目前 Moonccake 版本有所不同。Azure Stack App Service 提供了 Serverless 服务 Function App。这为应用开发的架构师提供了另一种技术路径。对于已有的企业级系统,Logic App 提供了一种工作流程,把已有的系统与 Azure Stack 连接,进行数据的交互和处理。

对于开发者而言,不需要知道 Web App PaaS 服务背后的支撑框架。不管是 LAMP 也好,还是 Windows+.NET+IIS 也罢,开发人员只需要使用熟悉的技术栈做相同的事情就行。Web App PaaS 服务支持多种语言,如 C#、Python、Java、PHP 等,同时也支持.NET、J2EE 之类的开发框架。

下图很好的说明了 Web App PaaS 服务的组成,虚线之外是独立存在的开发者。把开发者与 Web App PaaS 连在一起的是众多的开发工具(我们会在第二节介绍使用情况)。

下面我们通过一个简单 PHP 网站案例介绍,该特性。首先创建一个 Web App 应用。在 New->Web + Mobile->Web App (preview)

初次创建 Web App 的过程中,需要用户新建 Resource Group(资源组)和 App Service Plan(应用服务计划)

创建完成之后,我们点击左侧导航栏 App Services

选择 Advanced Tools,点击 Go 图标

点击 Go 之后,显示 App Service 注册认证页面

选择用户名,输入密码。(用户名和密码为创建该 Web App 的租户信息)

此时,我们进入 Kudu Services。Kudu 是一个用于 git 部署的 CI/CD 引擎。详情可以参阅: https://github.com/projectkudu/kudu/wiki。我们点击页面顶部的 debug console -> CMD,正如使用 Windows 操作系统 cmd 指令窗口一样,可以在该窗口进行 command line 的操作。

为了验证 Web App PaaS 服务的多语言性,输入 php -v 检查 Web App 是否安装 PHP 语言。

如果需要安装 python 或者 nodejs,点击 Site extensions->Gallery。

拖动滚动条,寻找需要安装的语言和第三方工作包。找到 Composer 工具包,点击 + 按钮。

等待片刻后,在 Installed 栏中出现我们要安装的工具包。

在返回 Debug->console 目录,在 home/SiteExtensions 下,我们可以看到 Composer 文件目录。

输入 composer 指令,此时工具包已经安装完成。

持续集成和部署

编程语言和相关工具包是开发 Web 应用的基础,我们可以将代码部署到微软 Web App PaaS 服务中。Azure 公有云提供了包括 Visual Studio Online、Git、Github、FTP 等多种持续集成和部署的方式。虽然在 Azure Stack PoC 环境中,我们暂时只能测试 local gitrepository 和 external repository 两种模式,但相信在 GA 之后,会有更多的第三方 provider 为开发者提供优质的软件服务。

在本案中,我们使用 Github 作为 Web App 的代码版本管理工具,进行简单的持续部署和开发的工作。

选中 Web App->Deployment credentials, 在此界面设置 Git 或者 FTP 的用户认证信息。这里,输入自己的 Github 账户和密码,点击确定。

然后,选择 Deployment options, 选择 external repository。

填写相关的 Repository URL,同时选择 branch 分支。笔者自己开发了一个基于 php 和 mysql 的简单 web 应用,想要了解朋友,可以下载代码。 https://github.com/Penergy/AzSwebDemo01.git

点击确定后,Azure Stack 中的 Web App 便会自动更新代码。

下图显示了第一次更新后的结果。

值得一提的是在 Azure Stack PoC 环境中无法使用 Deployment Slots。而这个功能的作用是定时从代码库中读取代码,这对于持续集成和部署作用不可言喻。相信在 GA 之后,开发者要想的功能会逐步的上线。我们仪电集团也会跟进后续的研究和开发。下图为上传的网站。

在本地环境中,我们更新了部分代码,上传到 Github 中。在 Azure Stack Web App 中,同步代码。

底下的按钮变成 Hello 字样。

连接数据库服务

现在我们已经创建了 Web App 环境,上传代码,完成了网站静态页面的显示。接下来,将介绍 Web App 如何与数据库对接,进行动态展示。

Azure Stack 提供了众多的数据库存储环境,如 Azure Table、SQL Server 这样的微软产品。同时,微软也引入了第三方的 Provider。对于熟悉 LAMP 网站开发的朋友,微软提供了 MySQL 数据库服务。在我们的案例中,也将为大家介绍 Web App 与 MySQL 链接实现持久化。

a. 创建 MySQL Database (preview)

首先创建一个 MySQL Database 服务。点击 New -> Data + Storage -> MySQL Database (preview),输入基本信息。

创建之后,新建的 MySQL 数据库会显示在所属的 Resource Group(资源组),此时数据库已经创建成功。

b. 使用 MySQL Workbench 或者 Navicat

对于新建的数据库,我们需要为数据库新建 Schema(模式),并从中插入表格。开发者可以使用不同的工具,如 MySQL Workbench、Navicat 或者是其他指令行软件。这里为了方便起见,我们使用 Navicat。

首先,进入新建的 MySQL Database。在 Essential 中,获取 Connection String.

复制代码
server=192.168.102.15;password=************;
user id=root;port=3306;database=pengtestdb02

从上述字符串中,我们获得了几个重要信息,如 server(数据库服务器 ip 地址)、user id(数据库用户名),port(端口号),database(数据库名称)。出于对 credential 信息保护的缘故,Azure Stack 了屏蔽密码这类敏感信息。

打开 Navicat,填写之前获取的信息,点击连接。

进入数据库,数据库已经显示在软件中,我们要做的就是创建数据表。这里,创建名为 users 的数据表,分别添加 id、username、email 三个字段。

这样,创建数据表的工作做完。MySQL Database Server 已经开始运转。

c.Web App 连接数据库

为了让 Web App 连接已经创建好的 MySQL 服务器,我们需要将获取的 Connection String 填写到 Web App 中的 Application Settings 中。

在 Application Settings 中,有 Connection Strings 一栏,在这个表格中可以填写任意参数。这个由 Key 和 Value 组成的变量,会作为环境变量存在于 Web App 中。

在 PHP 代码中,我们使用如下代码,获取环境变量。

复制代码
$appsetting = getenv("MYSQLCONNSTR_test");
$conn = connectForAzure($appsetting);

对于不同的数据库,Web app 提供了不同的命名规则:

在我们的案例中,点击 Hello 按钮之后,跳转到动态页面。开发者可以操作向数据库输入用户名和邮箱信息。

可用性全局缩放

微软 Web App PaaS 提供两种自动全局缩放模式,一种是扩大(Scale Out),另一种是增加(Scale Up)。

扩大(Scale Out)

用于 Web 应用访问的不确定性,可能导致不断变化的使用需求。Azure Stack 中的自动缩放就是通过增加虚机实例的个数,使用负载均衡做到按需访问。这样做的好处在于动态分配资源,不用浪费资源。

下面是 Scale Out 界面,我们可以增加或者减少虚机实例。

增加(Scale Up)

通过改变 App Service Plan 的类型来增加单个虚机实例的虚机资源,包括 CPU 个数、内存大小、存储资源等。

不同于公有云 Azure 中的 App Service 服务, Azure Stack 管理员 portal 提供了一种配置 App Service 服务各种角色性能的可能性。

我们可以为 App Service 新增角色,包括 Web Worker、Front End、Publisher、Database、File Server、Controller 等角色。这里新增 Worker Tier 角色。

对于新增的角色,选择“Shared”、“Small”、“Medium”、“Large”等角色。

总结

微软的 Web App PaaS 服务,作为一种面向云端的快捷、有效的的开发模式之一。相较于传统 Web App 开发需要搭建服务器环境、安装相关的编程语言、配置相应的软件包和数据库而言,开发者只需要关注业务逻辑和代码本身,有效的提高了开发的质量和速度。

本文通过一个简单案例的实现,介绍了 Azure Stack 中 Web App PaaS 服务的开发过程。其目的是为开发者介绍如何在 Azure Stack 中进行应用的开发。希望开发者了解 Azure Stack 提供的服务和能力,更好的帮助开发者从应用开发、代码实施部署、需求动态分配、PaaS 服务协同等四个角度,了解 Web App PaaS 功能。

同时,我们也对 Azure Stack 和 Azure Mooncake 版本做了简短的对比介绍,Azure Stack 提供了目前比较热门的 Serverless 服务 -Function App,并为云管理员提供动态分配 App Service 资源的权利。可以说这两点是 Azure Stack 特有的亮点之一。

感谢江柳对本文的审校。

2017-10-09 18:386549

评论

发布
暂无评论
发现更多内容

TDSQL | 在整个技术解决方案中HTAP对应的混合交易以及分析系统应该如何实现?

腾讯云数据库

tdsql 国产数据库

ODC V3.2.0 新版本发布 | 着重用户体验,挑战权限管控业务场景

OceanBase 数据库

数据库 开发者 稳定性 应用场景 新功能

JavaIO流核心模块与基本原理

Java nio IO流 字符流 字节流

个人信息保护法生效,企业数据安全合规正当时

行云管家

信息安全 数据安全 企业安全 网络保护

11.11上云嘉年华,华为云数据库助力客户备战业务高峰

华为云数据库小助手

GaussDB GaussDB(for openGauss) GaussDB ( for Redis ) 华为云数据库

入职字节跳动那一天,我哭了(蘑菇街被裁,奋战7个月拿下offer)

Java MySQL redis 程序员 算法

Sentinel-Go 源码系列(二)|初始化流程和责任链设计模式

捉虫大师

sentinel Go 语言 sentinel-go

一文,动态规划入门

bigsai

算法 动态规划

行云管家荣登36kr企服点评云计算软件排行榜NO.1

行云管家

云计算 软件 排行榜 IT运维

《Linux一学就会》:第二章:Linux基本命令操作和文件管理

侠盗安全

Linux 运维 linux运维 云计算架构师

初识Java反射概念和使用

CRMEB

原来我才是内卷王,闭关3个月肝完Java 7大核心知识,成功斩获字节58万Offer。

Java高级开发

字节跳动 java; 字节跳动面经

IOS技术分享| WebRTC iOS源码下载&编译

anyRTC开发者

ios 音视频 WebRTC 实时通信 视频直播

白码低代码/无代码开发平台功能及作用

低代码小观

低代码 开发工具 开发平台 无代码 企业服务

什么是DISA STIG?概述+STIG安全

旋极智能

OceanBase 源码解读(六):存储引擎详解

OceanBase 数据库

数据库 开发者 高性能 资源隔离 租户

业务数据清洗,落地实现方案

数据 数据清洗 数据管理 数据服务 业务数据

真香!180页100+题15W+字解析的《Java高级面试指南》,果断收下

Java 程序员 架构 分布式 算法

如何快速应对井喷下的OCR需求?

鲸品堂

OCR

你以为委派模式很神秘,其实你每天都在用

Tom弹架构

Java 架构 设计模式

推动产业创新,腾讯的底层逻辑是什么?

ToB行业头条

这场蝴蝶效应,从“丝滑”的双11开始

脑极体

springboot集成阿里云短信

小鲍侃java

11月日更

墨天轮国产数据库沙龙 | 黄新著:金仓数据库全生命周期管控

墨天轮

国产数据库 KingBase 人大金仓

为什么那么多人在用WGCLOUD

王逅逅

zabbix 监控系统 linux运维 运维系统

腾讯安全李滨:腾讯云数据安全与隐私保护探索与实践

腾讯安全云鼎实验室

数据安全 云安全

MapReduce Service更换集群外部时钟源,仅需10步

华为云开发者联盟

大数据 FusionInsight ntp 时钟同步 MapReduce Service

低代码是什么意思?

低代码小观

程序员 低代码 开发工具 开发平台 企业开发系统

如何获取所有安装的应用程序信息

Changing Lin

11月日更

技术干货|开源项目-FlyFish使用攻略

云智慧AIOps社区

开源 大前端 低代码 数据可视化 大屏

“神算子”上线!EasyDL时序预测模型零门槛轻松上手

百度开发者中心

百度飞桨

如何在Azure Stack上使用Web App PaaS服务?_微软_彭毅程_InfoQ精选文章