一,引言

  上节,我们讲到使用 Azure Traffic Manager 为我们的 Demo 项目提供负载均衡,以及流量转发的功能。但是Azure 提供类似的功能的服务远远不止这一个,今天我们就来讲一下 Azure Load Balance ,通过它来实现负载均衡,流量转发,以及分享一下 Azure Load Balance 的创建,和具体的配置。

  Azure Load Balance:是指在一组后端资源和服务器之间负载均衡的分配负载(传入网络流量)

  Azure 负载均衡器在开放式系统互连 (OSI) 模型的第四层上运行。 它是客户端的单一联系点。 负载均衡器将抵达负载均衡器前端的入站流量分配到后端池实例。 这些流取决于所配置的负载均衡规则和运行状况探测。 后端池实例可以是 Azure 虚拟机,或虚拟机规模集中的实例。

  我们今天演示的后端链接的是一组VM。

--------------------我是分割线--------------------上架构图

--------------------我是分割线--------------------

Azure Web App 部署系列:

1,Azure Web App(一)发布你的Net Core Web 项目

2,Azure Web App(二)使用部署槽切换部署环境代码

3,Azure Web App(三)切换你的Net Core Web 项目的数据库连接字符串

4,Azure 提供负载均衡(一)Azure Traffic Manager 为我们的Web项目提供负载均衡

5,Azure Traffic Manager(二) 基于权重与基于优先级的路由策略为我们的Web项目提供负载均衡

6,Azure Load Balance(一) 为我们的Web项目提供负载均衡

二,正文

1,创建外部的Azure Load Balance

Azure Portal 点击 “create a resource”

搜索框 输入 "Load Balancer"

点击 “Create” 进行创建。

我们可以看到,Load Balance 需要输入一些参数,例如 类型,SKU,公共IP配置,是否使用IPV6 等

Resource group:点击 Create new  输入 “Web_Test_LB_RG”

Name:“lb_cnbateblogweb”

Type:“Public”

region 选择 :“East Asia”

Public IP address Name:"cbbateblgweb_pub_ip"

剩下都是默认选项, 点击 “Review + create” 进行预创建校验

我们可以页面上显示 “Validation passed”,然后我们点击 “Create” 进行创建操作

稍等一下,我们可以在Azure Portal的通知栏看到 部署成功的提示信息,我们可以点击 “Go to resource” 跳转到资源

2,创建VM,部署 Web 项目

在创建VM 之前,我们先创建网络资源,比如,一个虚拟网络,虚拟网络中有个两个子网

搜索框中搜索 “Virtual Network”,进行搜索

我们点击 “create” ,进行创建 虚拟网络 资源

Name:“CnBateBlogWeb_VNET”

Region 选择:“East Asia”

点击下一步,进行配置 “IP Addresses” 信息

IPv4 address space 配置我们使用默认的 “10.1.0.0/16”

我们点击红色圈圈部分 ”default“,修改默认子网的配置信息。

我们讲默认的 subnet name 改成 “CnBateBlogWeb01_SubNET”,Subnet address range 改为 “10.1.1.0/24”,点击 “Save” 进行保存操作

操作完成后,我们可以在 IP 地址配置页面可以看到刚刚修改的以及新添加的子网的信息,确认无误后,我们点击 “Review+create” ,进行添加预校验操作。

等待检验成功后,我们可以看到 验证成功提示,然后我们点击 “Create”,进行创建,进行创建虚拟网络以及子网的资源。

再次回到资源创建页面,我们开始创建 "Network security group(网络安全组)" ,搜索框输入 “Network security group”

点击 “create” 按钮进行创建

Resource group 选择:"Web_Test_RG"

Name:“CnbateBlogWeb_NSG”

Region 选择:“East Asia”

点击 “Review + create”,进行预检查

完成预校验之后,我们点击 “create” 进行创建资源,创建完成后,我们点击 “Go to resource”

我们在 CnBateBlogWeb_NSG 页面需要配置入站规则,选择 "Settings=>Inbound security rules",然后点击 “Add”,进行添加操作

我们计划是使用 windows 服务器,所以远程连接端口必须得打开,端口为 “3389”,如下图所示

然后我接着使用相同的方式也将 “80” 端口加到入站规则中,添加完成后,我们也可以看到自己刚刚添加完成的入站规则信息

接下来,我们进行创建VM

还是回到创建资源页面,我们选择 “Windows Server 2016 Datacenter”(作为演示,大家不要在意服务器类型,以及服务器性能的问题),并且跳转到配置页面

我们可以看到,这么我们需要进行简单的配置服务器的镜像,所在区域,Size,以及远程登录所需要的服务器的用户名以及密码,以及需要开放的 3389 和 80 端口

Virtual machine name:“cnbateblogweb01”

Region:“East Asia”

UserName:“cnbateblogweb01”

Password:大家自行填写

VM 的 size 的大小,我们可以点开看一下,我这边悬着的是  1核1g大小的,也是我图中圈起来的

磁盘方面,我们使用默认,只是做演示用,不需要加数据盘,我们点击 “Next-Networking >” ,进入下一步配置网络信息

关于 “Virtual Network” 和 “subnet” ,我们可以选择刚刚创建好的

Virtual Network 选择:"CnBateBlogWeb_VENT"

Subnet 选择:“CbBateBlogWeb01_SubNET”

public ip 我们使用默认,创建一个新的公共的IP

NIC network security group 选择:"Advanced"

Configure network security group 选择:"CnBateBlogWeb_NSG"

将 Public IP 的 SKU 修改为 “Standard”,点击 “OK”

点击 “Review+create”,进行预创建校验操作,完成 预校验操作后,点击 “create” 进行创建操作。

预校验完成后,我们点击 “Create”,进行创建资源

等待部署成功后,我们可以点击 “Go to resource” 进行跳转到刚刚创建到的VM资源的页面查看具体信息

 我们重复上述工作,再次创建一台名字叫 cnbateblogweb02 的新的VM,IP 地址配置中子网选择 之前创建好的 "CnBateBlogWeb02_SubNET"

3,服务器安装IIS

Azure Portal 中找到 刚刚创建好的 cnbateblogweb01 的 VM,复制图中的 “Public IP address”

回到我们的桌面,我们使用远程桌面连接,登录到 ”cnbateblogweb01“ 这台 VM 上

登录上去后,我们使用 Powershell 安装IIS服务

powerShell 输入:

Install-WindowsFeature -name Web-Server -IncludeManagementTools

等待安装进度条加载完成

等待安装完成后,我们可以看到 成功或者失败的提示

再次输入以下命令,移除默认的IIS启动页面

remove-item  C:\inetpub\wwwroot\iisstart.htm

再次输入如下命令,重新添加我们自定义的 index.html 文件。

Add-Content -Path "C:\inetpub\wwwroot\index.html" -Value $("Hello cnbatebogweb01---" + $env:computername)

添加完成后,我们在本地访问 cnbateblogweb01 的 ip地址 测试一下,看看是否将 IIS 安装成功,以及我们自定义的页面是否成功展示,ok,测成功

接下来,我们使用相同的方式登录到 cnbateblogweb02 这台VM 上也进行安装IIS,并且添加自定义的 index.html 文件

同样的,我们在本地访问 cnbateblogweb02 的 ip地址 测试一下,看看是否将 IIS 安装成功,以及我们自定义的页面是否成功展示.

ok,以上步骤完成后,我们就开始配置 Load Balancer

4,配置 Load Balancer 的后端池

回到 Azure Portal 中,我们找到之前创建好的名字叫 “lb_cnbateblogweb” 的负载均衡器,选择 “Settings=>Backend pools” 添加后端池信息

Name:"cnbateblogweb_backendpool"

Virtual network 选择:“CnBateWeb_VNET”

IP 默认为:IPV4

Asscociated to 选择: “Virtual machines”

我们点击 “+Add” 讲我们之前创建好的两台VM 添加进来,如图所示

最后点击 “Add” 操作

稍等片刻,我们可以看到刚刚添加好的负载均衡器的 Backend Pool 信息

接下来,我们需要设置健康检查,选择 “Settings=>Health probes”,点击 “Add” 按钮

Name:“cnbateblogweb_healthcheck”

port:“80”

其他的都走默认配置,也就是说,Azure会每隔 15s 访问一下后端池 80 端口 会进行健康探测,连续出现2次不正常的请求后,负载均衡器会自动将检查不正常的后端池中的 VM 移除掉

接下来,我们就要配置负载均衡的规则,页面上我们 选择 “Settings=>Load balancing rules” ,点击 “Add”

Name:“cnbateblogweb_HttpRule”

Port:“80”

Backend port:“80”

Backend pool 选择:"cnbateweb_backendpool"

Health probe 选择:“cnbateblogweb_healthcheck”

点击 “OK”

以上信息,创建完成后,我们进行测试,服务当前 Load balancer 的 Public IP address ,复制到浏览器中,访问试试。

我们访问负载均衡器的公网地址,目前是将我本地发出的请求转发到 cnbateblogweb02 这台VM上

同时,我们可以选择Load Balance 的 “Insights”功能,如下图所示,我们可以清楚的看到当前请求的一个大致的走向,这个图和我们在文章最上面介绍的架构图特别相似

ok,今天介绍的Load Balance 的用法,以及做了一个小小的演示页面,成功的通过负载均衡器将请求流量转发到后端池的某个 VM 中.

分享到此结束。撒花,撒花!!!

三,结尾

  ok,今天的分析篇幅有些多,确实是自己没有控制好,希望大家多多包涵,今天大概讲解关于 Load Balancer 创建,配置后端池,配置健康检查,配置负载均衡规则等,以及通过在两个VM中的IIS服务器中添加自定义的 “index” 页面,我们可能直观的看到负载均衡器将流量进行转发。下一节我们具体讲解

1,负载均衡器具体的一些配置

2,将之前说的demo 发布到 VM的IIS 服务器中,用demo项目更贴切与实际项目中的架构设计

作者:Allen

项目代码:https://github.com/yunqian44/CnBateBlogWeb.git

版权:转载请在文章明显位置注明作者及出处。如发现错误,欢迎批评指正。

Azure Load Balancer(一) 为我们的Web项目提供负载均衡的更多相关文章

  1. Azure Traffic Manager(二) 基于权重与基于优先级的路由策略为我们的Web项目提供负载均衡

    一,引言 上一片文章我们使用 Azure Traffic Manager 分发用户请求,同时演示了两种路由策略,“Performance”,“Geographic”的两种方式,今天我们继续讲解 Tra ...

  2. Azure 提供负载均衡(一)Azure Traffic Manager 为我们的Web项目提供负载均衡

    一,引言 上一篇讲到我们将自己的Net Core Web 项目部署到 Azure 的 Web App 的一项 pass 服务,假如随着项目的日益增长的访问量,之前部署到单节点的应用可能无法保证其稳定性 ...

  3. Azure Load Balancer(二) 基于内部的负载均衡来转发为访问请求

    一,引言 上一节,我们使用 Azure Load Balancer 类型为外部的,来转发我们的 Web 服务.今天我们看看另一种类型为 “Internal” 的 Azure Load Balancer ...

  4. Azure Application Gateway(一)对后端 Web App 进行负载均衡

    一,引言 今天,我们学习一个新的知识点-----Azure Application Gateway,通过Azure 应用程序网关为我么后端的服务提供负载均衡的功能.我们再文章头中大概先了解一下什么是应 ...

  5. Azure Load Balancer : 简介

    Azure 提供的负载均衡服务叫 Load Balancer,它工作在 ISO 七层模型的第四层,通过分析 IP 层及传输层(TCP/UDP)的流量实现基于 "IP + 端口" 的 ...

  6. Azure Load Balancer : 支持 IPv6

    越来越多的网站开始支持 IPv6,即使是哪些只提供 api 服务的站点也需要支持 IPv6,比如苹果应用商店中的 app 早就强制要求服务器端支持 IPv6 了.笔者在前文<Azure Load ...

  7. 以Jar形式为Web项目提供资源文件

    以Jar形式为Web项目提供资源文件 http://www.webjars.org/ Web前端使用了越来越多的JS或CSS如jQuery, Backbone.js 和Twitter Bootstra ...

  8. Azure Load Balancer : 动态扩展

    笔者在前文<Azure Load Balancer : 支持 IPv6>中介绍了如何通过 PowerShell 脚本创建支持 IPv6 的 Load Balancer.本文我们接着介绍如何 ...

  9. 使用Python SDK管理Azure Load Balancer

    概述 下面将演示如何使用Python SDK管理中国区Azure Load balancer.关于Azure负载均衡器的详细功能介绍,请参考官方文档. Code Sample import os fr ...

随机推荐

  1. [源码解析]Oozie来龙去脉之提交任务

    [源码解析]Oozie来龙去脉之提交任务 0x00 摘要 Oozie是由Cloudera公司贡献给Apache的基于工作流引擎的开源框架,是Hadoop平台的开源的工作流调度引擎,用来管理Hadoop ...

  2. return ,continue,break的用法与区别总结

    1.return 语句的作用 (1) return 从当前的方法中退出,返回到该调用的方法的语句处,继续执行.       (2) return 返回一个值给调用该方法的语句,返回值的数据类型必须与方 ...

  3. CentOS7开机报错piix4_smbus ****host smbus controller not enabled

    vi /etc/modprobe.d/blacklist.conf 输入:blacklist i2c_piix4 保存退出::wq 重启:reboot (完)

  4. uni-app网络请求

    对于 GET 方法,会将数据转换为 query string.例如 { name: 'name', age: 18 } 转换后的结果是 name=name&age=18. 对于 POST 方法 ...

  5. vs遇到的字符串问题

    原以为自己的字符串已经理解不错了, 今天又被vs搞了. 情景就不说了, 直接说结果: 有两种情况 1 当文件是存储为gbk或者utf-8的时候, 中文字符存储永远是gbk的值. ‘按’字的gbk编码 ...

  6. 大致掌握django的功能

    目录 静态文件配置 request对象方法初识 pycharm链接数据库(mysql) django链接数据库(mysql) django orm 字段的增删查改 数据的增删查改 数据的查,改,删 d ...

  7. 华为云MVP熊保松谈物联网开发:华为云IoT是首选,小熊派是神器

    摘要:在AI.5G的技术驱动下,物联网行业的发展愈加如火如荼,开发者在技术的快速更迭间,也得乘风破浪跟上新技术的节奏. 在AI.5G的技术驱动下,物联网行业的发展愈加如火如荼,开发者在技术的快速更迭间 ...

  8. dva的简介

    dva的定义 dva 是基于现有应用架构 (redux + react-router + redux-saga 等)的一层轻量封装; redux 他是react当中的仓库,如果熟悉vue的话,他的功能 ...

  9. day20 函数收尾+面向过程+模块

    目录 一.算法(二分法) 二.面向过程与函数式 1 编程范式/思想 2 面向过程 3 函数式 3.1 匿名函数与lambda 三.模块 1 什么是模块 2 为何要有模块 3 怎么用模块 3.1第一次导 ...

  10. element-ui 表单校验 Rules 配置 常用黑科技

    type 指示type要使用的验证器.可识别的类型值为: string:类型必须为string.type 默认是 string // 校验 string: [ {type: 'string', mes ...