Azure Load Balancer(一) 为我们的Web项目提供负载均衡
一,引言
上节,我们讲到使用 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项目提供负载均衡的更多相关文章
- Azure Traffic Manager(二) 基于权重与基于优先级的路由策略为我们的Web项目提供负载均衡
一,引言 上一片文章我们使用 Azure Traffic Manager 分发用户请求,同时演示了两种路由策略,“Performance”,“Geographic”的两种方式,今天我们继续讲解 Tra ...
- Azure 提供负载均衡(一)Azure Traffic Manager 为我们的Web项目提供负载均衡
一,引言 上一篇讲到我们将自己的Net Core Web 项目部署到 Azure 的 Web App 的一项 pass 服务,假如随着项目的日益增长的访问量,之前部署到单节点的应用可能无法保证其稳定性 ...
- Azure Load Balancer(二) 基于内部的负载均衡来转发为访问请求
一,引言 上一节,我们使用 Azure Load Balancer 类型为外部的,来转发我们的 Web 服务.今天我们看看另一种类型为 “Internal” 的 Azure Load Balancer ...
- Azure Application Gateway(一)对后端 Web App 进行负载均衡
一,引言 今天,我们学习一个新的知识点-----Azure Application Gateway,通过Azure 应用程序网关为我么后端的服务提供负载均衡的功能.我们再文章头中大概先了解一下什么是应 ...
- Azure Load Balancer : 简介
Azure 提供的负载均衡服务叫 Load Balancer,它工作在 ISO 七层模型的第四层,通过分析 IP 层及传输层(TCP/UDP)的流量实现基于 "IP + 端口" 的 ...
- Azure Load Balancer : 支持 IPv6
越来越多的网站开始支持 IPv6,即使是哪些只提供 api 服务的站点也需要支持 IPv6,比如苹果应用商店中的 app 早就强制要求服务器端支持 IPv6 了.笔者在前文<Azure Load ...
- 以Jar形式为Web项目提供资源文件
以Jar形式为Web项目提供资源文件 http://www.webjars.org/ Web前端使用了越来越多的JS或CSS如jQuery, Backbone.js 和Twitter Bootstra ...
- Azure Load Balancer : 动态扩展
笔者在前文<Azure Load Balancer : 支持 IPv6>中介绍了如何通过 PowerShell 脚本创建支持 IPv6 的 Load Balancer.本文我们接着介绍如何 ...
- 使用Python SDK管理Azure Load Balancer
概述 下面将演示如何使用Python SDK管理中国区Azure Load balancer.关于Azure负载均衡器的详细功能介绍,请参考官方文档. Code Sample import os fr ...
随机推荐
- 如何运行Spring Boot项目
背景 帮别人指导一个Spring Boot项目,它在本地把项目push到git服务器上,然后在部署的服务器上把代码pull下来(我猜应该是这个流程) 然后他问我这项目怎么运行? 我当时就懵了,因为我平 ...
- 1166 - Unknown error 1166[mysql 错误
错误码 1166 原因 字段名因为是复制过来的, 末尾存在了一个空格换行
- 洛谷 P5683 【[CSPJX2019]道路拆除】
先用做的暴力,因为n最多才3000嘛,但是后来发现时间复杂度不止\(O\)(\({n}^2\)),然后就放弃了. 讲讲我的暴力+错误思路吧: 把1到s1和s2的最短路算出来,用SPFA,然后用DFS求 ...
- 路由网关(Zuul)
上一篇已经讲了微服务组件中的 分布式配置中心,本章讲述 由JAVA编写的服务路由网关Zuul… - Zuul 路由是微服务体系结构的一个组成部分.例如 / 可以映射到您的Web应用程序,/api/us ...
- 【react】实现动态表单中嵌套动态表单
要实现一个功能动态表单中嵌套动态表单如下: 仔细看看antd的文档其实不难 具体步骤如下 1.建立一个 名为 ConcatRegion的组件(动态表单A)代码如下 export function Co ...
- 求助:Runtime exception at 0x004000bc: invalid integer input (syscall 5)
代码 .data S17: .asciiz "the bigger one is:" .text move $fp $sp j main max: lw $t8 ($sp) sub ...
- C++中cin>>a原理
int a; vector<int>res; while(cin>>a){ res.push_back(a); } 给出这段代码 可以输入1 2 3 4 5并以回车结束,从而 ...
- Android屏幕适配技巧
屏幕适配一直是困扰 Android 开发工程师的一大问题,但是随着近几年各种屏幕适配方案的诞生,以及谷歌各种适配控件的推出,屏幕适配也显得越来越容易,这节课我们就来总结一下关于屏幕适配的那些技巧. C ...
- dotnet core 在 MIPS 下的移值进度
本文仍处于修订中 写在开始前 我们的主要业务基于 dotnet core 2.x 与 3.1 完成,目前 dotnet core 3.1 支持的 CPU 架构列表中还不包含龙芯,且在 gitlab i ...
- Edit Static Web File Http Header Metadata of AWS S3 from SDK | SDK编程方式编辑储存在AWS S3中Web类文件的Http Header元数据
1.Motivation | 起因 A requirement from the product department requires download image from AWS S3 buck ...