干货 | 三分钟带你挑选专属负载均衡

干货 | 三分钟带你挑选专属负载均衡

原创:   京东云IaaS产品部   京东云开发者社区    今天



对于云厂商来说,在提高系统可用性、扩展系统服务能力方面,负载均衡可谓是重要一环。


负载均衡可将用户的业务请求按照一定策略自主分发给多台后端服务器处理,从而调整资源利用情况,消除由于单台后端服务器故障对系统的影响。


LB?

ALB?

NLB?

DNLB?

傻傻分不清楚

负载均衡的使用场景众多,

无论你是传统行业,还是互联网行业,

不知不觉中,你就会接触到负载均衡。

如果还分不清其中的区别,

不知道如何做选择,

那就不是坑队友,

是坑自己了!

|

剧透一下

我们今天会重点比较

ALB

NLB

DNLB

欢迎围观!

2_02.png?wxfrom=5&wx_lazy=1&wx_co=1


·

·

·

·



负载均衡,Load Balancer,简称为 LB 京东云负载均衡产品包括 应用负载均衡 (Application Load Balancer,简称ALB)、 网络负载均衡 (Network Load Balancer,简称NLB)和 分布式网络负载均衡 (Distributed Network Load Balancer,简称DNLB)。


三款负载均衡在组网中的部署位置相同,且都可以为内网和外网业务提供负载均衡服务,只是服务的业务类型不同。下面,我们从多角度介绍三者的不同,为大家提供选择的依据。



640?wx_fmt=png&wxfrom=5&wx_lazy=1&wx_co=1




No.1 应用场景


ALB☟

工作在proxy模式的 七层负载均衡 ,主要面向基于HTTP和HTTPS的WEB应用程序,其在请求级别运行, 可以为应用层业务提供更加出色的服务


NLB☟

有状态 四层负载均衡 ,专注于提供四层有状态负载均衡服务,主要面向基于TCP的四层有状态业务, 可提供高性能、低延时、会话保持等四层应用服务能力


DNLB☟

基于SDN技术的 无状态四层负载均衡 ,提供软件定义的全可用区分布式负载均衡服务。相比于兼具会话保持功能的ALB和NLB,DNLB将负载均衡功能与会话保持解耦,天然具有转发性能无瓶颈、全可用区高可用、低时延、自动弹缩和长期免费的优点, 满足客户三高一低(高性能、高可用、高弹性和低时延)服务场景需求





No.2 产品特性


相比较于ALB支持丰富的七层特性,NLB支持保持业务状态信息,DNLB作为一款轻量级负载均衡产品,提供纯粹的负载均衡服务,满足用户的高性能需求,简化用户配置。


640?wx_fmt=png&wxfrom=5&wx_lazy=1&wx_co=1




No.3 资源占用情况


ALB和NLB实例有具体的实体,需要占用京东云的计算资源及用户私网IP地址,规划网络方案时需考虑ALB和NLB实例的弹性扩展情况,预留足够的私网IP地址。


DNLB实例是基于京东云SDN技术架构的逻辑实体,不占用任何计算资源,实例IP地址采用京东云预留的IP地址,不占用用户私网IP地址,且DNLB天然具有转发性能无瓶颈的特性,无需弹性扩展。





No.4 产品定价


目前三款负载均衡均免费,后续将采取不同的收费策略。

三款相比??? ALB>??NLB>?DNLB


DNLB作为一款为广大京东云用户提供实惠的重量级产品,长期免费哦!

???

作为传说中的不占用计算资源、全可用区高可用、免费、转发性能无瓶颈的负载均衡产品

DNLB已经完全开放!

邀请大家一起公测!!!






Summary


最后,本着满足各位大佬业务需求、提供更好的性能体验、花费更低的原则,敲黑板划重点:


  • 如果您的业务 需要负载均衡产品提供七层负载均衡服务 请选择ALB;

  • 如果您的业务 需要负载均衡产品提供四层有状态负载均衡服务 请选择NLB。相比于ALB,NLB可以提供更高的性能体验、更低的费用;

  • 如果您的业务 需要负载均衡产品提供四层无状态负载均衡服务, 请选择DNLB。相比于ALB和NLB,DNLB可以提供无瓶颈的性能体验、更简单的配置,且不收取任何费用,是成本相对敏感用户的不二选择。





最后的最后,

分享两个负载均衡产品选择不合适的小case,

仅供参考,不建议模仿!!!


??? 用户场景需提供基于TCP的四层负载均衡服务,且后端服务端需感知或者统计真实源端信息,用户选择使用ALB。



(点击空白处查看内容)

分析: ALB也支持提供四层负载均衡服务并获取客户端源IP,但配置复杂、费用相对较高。ALB工作在proxy模式,通过proxy protocol携带客户端源IP,后端服务器需额外配置支持解析proxy protocol相关字段。建议根据业务场景选择NLB或DNLB,二者都支持直接透传客户端源IP,无需后端服务器额外配置,且费用较低或免费。

???目前三款负载均衡产品都是免费的,所以无论什么场景,都选择功能最丰富、最成熟的ALB。

(点击空白处查看内容)

分析: NLB和DNLB虽然是京东云陆续推出的新产品,但是这两款产品早已在京东云多个产品服务(例如:CFS、RDS、MongoDB、Redis等)的高可用架构中成熟应用,所以稳定性及可用性无需顾虑。况且,ALB和NLB即将收费,建议大家根据需求选择最合适的负载均衡产品。


*点击“阅读原文”快来试试看,哪一款负载均衡最适合你吧!*


640?wxfrom=5&wx_lazy=1&wx_co=1



阅读原文
 


来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/69912185/viewspace-2646132/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/69912185/viewspace-2646132/

### 回答1: Spark Streaming 和 Flink 都是流处理框架,但在一些方面有所不同。 1. 数据处理模型 Spark Streaming 基于批处理模型,将流数据分成一批批进行处理。而 Flink 则是基于流处理模型,可以实时处理数据流。 2. 窗口处理 Spark Streaming 的窗口处理是基于时间的,即将一段时间内的数据作为一个窗口进行处理。而 Flink 的窗口处理可以基于时间和数据量,可以更加灵活地进行窗口处理。 3. 状态管理 Spark Streaming 的状态管理是基于 RDD 的,需要将状态存储在内存中。而 Flink 的状态管理是基于内存和磁盘的,可以更加灵活地管理状态。 4. 容错性 Flink 的容错性比 Spark Streaming 更加强大,可以在节点故障时快速恢复,而 Spark Streaming 则需要重新计算整个批次的数据。 总的来说,Flink 在流处理方面更加强大和灵活,而 Spark Streaming 则更适合批处理和数据仓库等场景。 ### 回答2: Spark Streaming 和 Flink 都是流处理框架,它们都支持低延迟的流处理和高吞吐量的批处理。但是,它们在处理数据流的方式和性能上有许多不同之处。下面是它们的详细比较: 1. 处理模型 Spark Streaming 采用离散化流处理模型(DPM),将长周期的数据流划分为离散化的小批量,每个批次的数据被存储在 RDD 中进行处理,因此 Spark Streaming 具有较好的容错性和可靠性。而 Flink 采用连续流处理模型(CPM),能够在其流处理过程中进行事件时间处理和状态管理,因此 Flink 更适合处理需要精确时间戳和状态管理的应用场景。 2. 数据延迟 Spark Streaming 在处理数据流时会有一定的延迟,主要是由于对数据进行缓存和离散化处理的原因。而 Flink 的数据延迟比 Spark Streaming 更低,因为 Flink 的数据处理和计算过程是实时进行的,不需要缓存和离散化处理。 3. 机器资源和负载均衡 Spark Streaming 采用了 Spark 的机器资源调度和负载均衡机制,它们之间具有相同的容错和资源管理特性。而 Flink 使用 Yarn 和 Mesos 等分布式计算框架进行机器资源调度和负载均衡,因此 Flink 在大规模集群上的性能表现更好。 4. 数据窗口处理 Spark Streaming 提供了滑动、翻转和窗口操作等灵活的数据窗口处理功能,可以使用户更好地控制数据处理的逻辑。而 Flink 也提供了滚动窗口和滑动窗口处理功能,但相对于 Spark Streaming 更加灵活,可以在事件时间和处理时间上进行窗口处理,并且支持增量聚合和全量聚合两种方式。 5. 集成生态系统 Spark Streaming 作为 Apache Spark 的一部分,可以充分利用 Spark 的分布式计算和批处理生态系统,并且支持许多不同类型的数据源,包括Kafka、Flume和HDFS等。而 Flink 提供了完整的流处理生态系统,包括流SQL查询、流机器学习和流图形处理等功能,能够灵活地适应不同的业务场景。 总之,Spark Streaming 和 Flink 都是出色的流处理框架,在不同的场景下都能够发挥出很好的性能。选择哪种框架取决于实际需求和业务场景。 ### 回答3: Spark Streaming和Flink都是流处理引擎,但它们的设计和实现方式有所不同。在下面的对比中,我们将比较这两种流处理引擎的主要特点和差异。 1. 处理模型 Spark Streaming采用离散流处理模型,即将数据按时间间隔分割成一批一批数据进行处理。这种方式可以使得Spark Streaming具有高吞吐量和低延迟,但也会导致数据处理的粒度比较粗,难以应对大量实时事件的高吞吐量。 相比之下,Flink采用连续流处理模型,即数据的处理是连续的、实时的。与Spark Streaming不同,Flink的流处理引擎能够应对各种不同的实时场景。Flink的实时流处理能力更强,因此在某些特定的场景下,它的性能可能比Spark Streaming更好。 2. 窗口计算 Spark Streaming内置了许多的窗口计算支持,如滑动窗口、滚动窗口,但支持的窗口计算的灵活性较低,只适合于一些简单的窗口计算。而Flink的窗口计算支持非常灵活,可以支持任意窗口大小或滑动跨度。 3. 数据库支持 在处理大数据时,存储和读取数据是非常重要的。Spark Streaming通常使用HDFS作为其数据存储底层的系统。而Flink支持许多不同的数据存储形式,包括HDFS,以及许多其他开源和商业的数据存储,如Kafka、Cassandra和Elasticsearch等。 4. 处理性能 Spark Streaming的性能比Flink慢一些,尤其是在特定的情况下,例如在处理高吞吐量的数据时,在某些情况下可能受制于分批处理的架构。Flink通过其流处理模型和不同的调度器和优化器来支持更高效的实时数据处理。 5. 生态系统 Spark有着庞大的生态系统,具有成熟的ML库、图处理库、SQL框架等等。而Flink的生态系统相对较小,但它正在不断地发展壮大。 6. 规模性 Spark Streaming适用于规模小且不太复杂的项目。而Flink可扩展性更好,适用于更大、更复杂的项目。Flink也可以处理无限制的数据流。 综上所述,Spark Streaming和Flink都是流处理引擎,它们有各自的优缺点。在选择使用哪一个流处理引擎时,需要根据实际业务场景和需求进行选择。如果你的业务场景较为复杂,需要处理海量数据并且需要比较灵活的窗口计算支持,那么Flink可能是更好的选择;如果你只需要简单的流处理和一些通用的窗口计算,Spark Streaming是更为简单的选择。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值