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

Stella981
• 阅读 668

一,引言

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

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

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

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

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

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

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

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”

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

 搜索框 输入 "Load Balancer"

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

 点击 “Create” 进行创建。

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

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

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

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” 进行预创建校验

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

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

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

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

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

2,创建VM,部署 Web 项目

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

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

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

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

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

Name:“CnBateBlogWeb_VNET”

Region 选择:“East Asia”

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

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

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

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

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

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

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

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

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

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

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

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

再次回到资源创建页面,我们开始创建 "Network security group(网络安全组)" ,搜索框输入 “Network security group”Azure Load Balancer(一) 为我们的Web项目提供负载均衡

 点击 “create” 按钮进行创建

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

Resource group 选择:"Web_Test_RG"

Name:“CnbateBlogWeb_NSG”

Region 选择:“East Asia”

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

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

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

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

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

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

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

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

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

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

接下来,我们进行创建VM

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

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

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

Virtual machine name:“cnbateblogweb01”

Region:“East Asia”

UserName:“cnbateblogweb01”

Password:大家自行填写

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

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

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

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

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

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

Virtual Network 选择:"CnBateBlogWeb_VENT"

Subnet 选择:“CbBateBlogWeb01_SubNET”

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

NIC network security group 选择:"Advanced"

Configure network security group 选择:"CnBateBlogWeb_NSG"

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

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

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

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

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

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

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

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

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

3,服务器安装IIS

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

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

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

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

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

powerShell 输入:

Install-WindowsFeature -name Web-Server -IncludeManagementTools

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

等待安装进度条加载完成 

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

等待安装完成后,我们可以看到 成功或者失败的提示Azure Load Balancer(一) 为我们的Web项目提供负载均衡

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

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

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

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

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

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

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

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

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

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

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

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

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

4,配置 Load Balancer 的后端池

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

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

Name:"cnbateblogweb_backendpool"

Virtual network 选择:“CnBateWeb_VNET”

IP 默认为:IPV4

Asscociated to 选择: “Virtual machines”

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

最后点击 “Add” 操作

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

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

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

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

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

 Name:“cnbateblogweb_healthcheck”

 port:“80”

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

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

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

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

Name:“cnbateblogweb_HttpRule”

Port:“80”

Backend port:“80”

Backend pool 选择:"cnbateweb_backendpool"

Health probe 选择:“cnbateblogweb_healthcheck”

点击 “OK”

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

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

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

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

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

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

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

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

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

三,结尾

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

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

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

作者:Allen 

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

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

点赞
收藏
评论区
推荐文章
blmius blmius
3年前
MySQL:[Err] 1292 - Incorrect datetime value: ‘0000-00-00 00:00:00‘ for column ‘CREATE_TIME‘ at row 1
文章目录问题用navicat导入数据时,报错:原因这是因为当前的MySQL不支持datetime为0的情况。解决修改sql\mode:sql\mode:SQLMode定义了MySQL应支持的SQL语法、数据校验等,这样可以更容易地在不同的环境中使用MySQL。全局s
皕杰报表之UUID
​在我们用皕杰报表工具设计填报报表时,如何在新增行里自动增加id呢?能新增整数排序id吗?目前可以在新增行里自动增加id,但只能用uuid函数增加UUID编码,不能新增整数排序id。uuid函数说明:获取一个UUID,可以在填报表中用来创建数据ID语法:uuid()或uuid(sep)参数说明:sep布尔值,生成的uuid中是否包含分隔符'',缺省为
待兔 待兔
6个月前
手写Java HashMap源码
HashMap的使用教程HashMap的使用教程HashMap的使用教程HashMap的使用教程HashMap的使用教程22
Jacquelyn38 Jacquelyn38
3年前
2020年前端实用代码段,为你的工作保驾护航
有空的时候,自己总结了几个代码段,在开发中也经常使用,谢谢。1、使用解构获取json数据let jsonData  id: 1,status: "OK",data: 'a', 'b';let  id, status, data: number   jsonData;console.log(id, status, number )
Stella981 Stella981
3年前
KVM调整cpu和内存
一.修改kvm虚拟机的配置1、virsheditcentos7找到“memory”和“vcpu”标签,将<namecentos7</name<uuid2220a6d1a36a4fbb8523e078b3dfe795</uuid
Easter79 Easter79
3年前
Twitter的分布式自增ID算法snowflake (Java版)
概述分布式系统中,有一些需要使用全局唯一ID的场景,这种时候为了防止ID冲突可以使用36位的UUID,但是UUID有一些缺点,首先他相对比较长,另外UUID一般是无序的。有些时候我们希望能使用一种简单一些的ID,并且希望ID能够按照时间有序生成。而twitter的snowflake解决了这种需求,最初Twitter把存储系统从MySQL迁移
Wesley13 Wesley13
3年前
00:Java简单了解
浅谈Java之概述Java是SUN(StanfordUniversityNetwork),斯坦福大学网络公司)1995年推出的一门高级编程语言。Java是一种面向Internet的编程语言。随着Java技术在web方面的不断成熟,已经成为Web应用程序的首选开发语言。Java是简单易学,完全面向对象,安全可靠,与平台无关的编程语言。
Stella981 Stella981
3年前
Django中Admin中的一些参数配置
设置在列表中显示的字段,id为django模型默认的主键list_display('id','name','sex','profession','email','qq','phone','status','create_time')设置在列表可编辑字段list_editable
Wesley13 Wesley13
3年前
MySQL部分从库上面因为大量的临时表tmp_table造成慢查询
背景描述Time:20190124T00:08:14.70572408:00User@Host:@Id:Schema:sentrymetaLast_errno:0Killed:0Query_time:0.315758Lock_
Python进阶者 Python进阶者
1年前
Excel中这日期老是出来00:00:00,怎么用Pandas把这个去除
大家好,我是皮皮。一、前言前几天在Python白银交流群【上海新年人】问了一个Pandas数据筛选的问题。问题如下:这日期老是出来00:00:00,怎么把这个去除。二、实现过程后来【论草莓如何成为冻干莓】给了一个思路和代码如下:pd.toexcel之前把这