当前位置: 首页 > news >正文

免费制作购物网站榆林市网站seo

免费制作购物网站,榆林市网站seo,b2b电子商务平台开发公司,北京市文化局政务网站建设项目LoadBalancer 概念常见的负载均衡策略使用随机选择的负载均衡策略创建随机选择负载均衡器配置 Nacos 权重负载均衡器创建 Nacos 负载均衡器配置 自定义负载均衡器(根据IP哈希策略选择)创建自定义负载均衡器封装自定义负载均衡器配置 缓存 概念 LoadBalancer(负载均衡器)是一种…

LoadBalancer

  • 概念
  • 常见的负载均衡策略
  • 使用随机选择的负载均衡策略
    • 创建随机选择负载均衡器
    • 配置
  • Nacos 权重负载均衡器
    • 创建 Nacos 负载均衡器
    • 配置
  • 自定义负载均衡器(根据IP哈希策略选择)
    • 创建自定义负载均衡器
    • 封装自定义负载均衡器
    • 配置
  • 缓存

概念

LoadBalancer(负载均衡器)是一种网络设备或软件机制, 用于分发传入的网络流量负载(请求)到多个后端目标服务器上, 从而实现系统资源的均衡利用和提高系统的可用性和性能
负载均衡分为服务器端负载均衡和客户端负载均衡

  1. 服务器端负载均衡是指放在服务器端的负载均衡器(反向代理), 如: Nginx, HAProxy, F5等
  2. 客户端负载均衡器是指嵌套在客户端的负载均衡器(正向代理), 如: Ribbon, Spring Cloud LoadBalancer等

服务器端负载均衡器所有请求都会发送到服务器端, 就会造成服务器端压力大的情况

常见的负载均衡策略

  1. 轮询(默认): 按照顺序将请求发送到服务器
  2. 随机选择: 随机选择一个服务器处理请求
  3. 最少连接: 选择连接数最少的一个服务器
  4. IP 哈希: 使用客户端IP地址计算哈希值然后发送到与之对应的服务器
  5. 加权轮询: 按照权重值的比例发送请求
  6. 加权随机选择: 按照权重值随机选择后端服务器
  7. 最短响应时间: 将请求发送到响应时间最短的服务器

Spring Cloud LoadBalancer 默认只支持轮询和随机选择, 但是可以自定义负载均衡策略

使用随机选择的负载均衡策略

创建随机选择负载均衡器

public class MyRandomLoadBalancer {@Beanpublic ReactorLoadBalancer<ServiceInstance> randomLoadBalancer(Environment environment,LoadBalancerClientFactory loadBalancerClientFactory) {String name = environment.getProperty(LoadBalancerClientFactory.PROPERTY_NAME);return new RandomLoadBalancer(loadBalancerClientFactory.getLazyProvider(name, ServiceInstanceListSupplier.class), name);}
}

配置

image.png
注意: 配置局部负载均衡器有可能不起作用, 可以配置全局负载均衡器
image.png

Nacos 权重负载均衡器

Nacos 中支持两种负载均衡器, 一种是权重负载均衡器, 另一种是第三方的CMDB(地域就近访问)标签负载均衡器, 我们可以将Spring Cloud LoadBalancer 直接配置为 Nacos 的负载均衡器

创建 Nacos 负载均衡器

@LoadBalancerClients(defaultConfiguration = MyNacosLoadBalancer.class)
public class MyNacosLoadBalancer {@Resourceprivate NacosDiscoveryProperties nacosDiscoveryProperties;@Beanpublic ReactorLoadBalancer<ServiceInstance> nacosLoadBalancer(Environment environment,LoadBalancerClientFactory loadBalancerClientFactory) {String name = environment.getProperty(LoadBalancerClientFactory.PROPERTY_NAME);return new NacosLoadBalancer(loadBalancerClientFactory.getLazyProvider(name, ServiceInstanceListSupplier.class),name, nacosDiscoveryProperties);}
}

配置

image.png

自定义负载均衡器(根据IP哈希策略选择)

创建自定义负载均衡器

public class CustomLoadBalancer implements ReactorServiceInstanceLoadBalancer {private static final Log log = LogFactory.getLog(RandomLoadBalancer.class);private final String serviceId;private ObjectProvider<ServiceInstanceListSupplier> serviceInstanceListSupplierProvider;public CustomLoadBalancer(ObjectProvider<ServiceInstanceListSupplier> serviceInstanceListSupplierProvider, String serviceId) {this.serviceId = serviceId;this.serviceInstanceListSupplierProvider = serviceInstanceListSupplierProvider;}public Mono<Response<ServiceInstance>> choose(Request request) {ServiceInstanceListSupplier supplier = (ServiceInstanceListSupplier)this.serviceInstanceListSupplierProvider.getIfAvailable(NoopServiceInstanceListSupplier::new);return supplier.get(request).next().map((serviceInstances) -> {return this.processInstanceResponse(supplier, serviceInstances);});}private Response<ServiceInstance> processInstanceResponse(ServiceInstanceListSupplier supplier, List<ServiceInstance> serviceInstances) {Response<ServiceInstance> serviceInstanceResponse = this.getInstanceResponse(serviceInstances);if (supplier instanceof SelectedInstanceCallback && serviceInstanceResponse.hasServer()) {((SelectedInstanceCallback)supplier).selectedServiceInstance((ServiceInstance)serviceInstanceResponse.getServer());}return serviceInstanceResponse;}private Response<ServiceInstance> getInstanceResponse(List<ServiceInstance> instances) {if (instances.isEmpty()) {if (log.isWarnEnabled()) {log.warn("No servers available for service: " + this.serviceId);}return new EmptyResponse();} else {ServletRequestAttributes attributes = (ServletRequestAttributes) RequestContextHolder.getRequestAttributes();HttpServletRequest request = attributes.getRequest();String ipAddress = request.getRemoteAddr();System.out.println("ip地址:" + ipAddress);int hash = instances.hashCode();int index = hash % instances.size();ServiceInstance instance = (ServiceInstance) instances.get(index);return new DefaultResponse(instance);}}
}

由于自定义负载均衡器和内置的负载均衡器只是在服务器选择的时候有所不同, 所以我们可以直接复制 RandomLoadBalancer 然后 在 getInstanceResponse()方法中进行改动即可

封装自定义负载均衡器

image.png

配置

image.png

缓存

Spring Cloud LoadBalancer 在获取实例时有两种选择:

  1. 及时获取: 每次都从注册中心获取到最新的实例, 效果好但是开销大
  2. 缓存服务列表: 每次得到服务列表后, 缓存一段时间,

spring Cloud LoadBalancer 默认缓存过期时间为 35s, 保存个数为 256个
我们也可以通过配置来改变这两个值

spring:cloud:loadbalancer:cache:ttl: 10capacity: 1000
#       enabled: false 关闭缓存

生产环境下不要关闭缓存否则会降低性能

http://www.yidumall.com/news/76348.html

相关文章:

  • 机械公司网站建设品牌营销活动策划方案
  • icp网站备案泉州seo按天计费
  • 建设和交通局网站网络推广的细节
  • 网站推广公司有哪些百度关键词搜索引擎排名优化
  • 沧州网站制作报价seo实战密码电子书
  • 做网站注册商标哪一类开网店怎么推广运营
  • 对于网站建设提出建议南宁网络优化seo费用
  • 个人做视频网站烧钱怎么设计网站
  • 网站建设的发票百度seo霸屏软件
  • 网站建设三秒原则app拉新推广一手接单平台
  • java网站开发谷歌google官方网站
  • 广州做网站平台网络营销工资一般多少
  • 深圳网站建设行吗徐州网站建设方案优化
  • 做网站挣钱快吗产品推广平台排行榜
  • 网站如何快速被百度收录百度站长联盟
  • 什么秀网站做效果图深圳竞价排名网络推广
  • 南通网站建设策划app推广注册接单平台
  • 怎么做网站的代理商app关键词排名优化
  • 电商网站简单html模板下载网站优化什么意思
  • 做网站的分页查询网易搜索引擎
  • 洮南网站建设哪家专业sem优化师是什么意思
  • 十堰网站建设兼职中国十大seo
  • 淮安新网站制作好网站制作公司
  • 重庆招生院校网站百度seo网站在线诊断
  • 网站开发毕业设计代做博为峰软件测试培训学费
  • 韶关网站建设的公司鄂州seo
  • 云浮网站建设公司常用的关键词有哪些
  • 网站建站方案书seo营销推广公司
  • 无锡有哪些做网站的公司老域名
  • 个人网站 建站郑州百度推广外包