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

怎样增加网站权重广西建设网官网桂建云

怎样增加网站权重,广西建设网官网桂建云,无锡赛孚建设工程有限公司网站,网站建设 蜂图网络Ribbon 是 Netflix 开发的一个开源项目#xff0c;用于实现客户端负载均衡功能。它在微服务架构中广泛使用#xff0c;并且是 Spring Cloud 生态中的重要组成部分。本文将带你从基础入门#xff0c;逐步掌握如何在 Spring Cloud 项目中使用 Ribbon 实现客户端负载均衡。 1 负…Ribbon 是 Netflix 开发的一个开源项目用于实现客户端负载均衡功能。它在微服务架构中广泛使用并且是 Spring Cloud 生态中的重要组成部分。本文将带你从基础入门逐步掌握如何在 Spring Cloud 项目中使用 Ribbon 实现客户端负载均衡。 1 负载均衡简介 负载均衡是一种将工作任务分摊到多个操作单元上的技术以提高系统的响应速度和稳定性。负载均衡主要分为两种类型 客户端负载均衡由客户端通过一定算法选择服务器进行请求。Ribbon 就是此类实现的代表。 服务端负载均衡例如使用 Nginx负载均衡的逻辑位于服务器端。 常见的负载均衡算法包括 轮询按顺序选择服务器简单而常用。 随机随机选择一个服务器。 加权轮询基于服务器性能设置权重分配请求。 最小连接数选择当前负载最小的服务器。 地址哈希基于请求地址的哈希值进行分配。  2 什么是 Ribbon Ribbon 是一种客户端负载均衡器它通过配置和规则来分配请求到不同的服务实例。它可以与 Spring Cloud 配合使用为 RestTemplate 提供负载均衡功能。 2.1 引入 Ribbon 依赖 在 Spring Cloud 项目中使用 Ribbon通常可以通过以下依赖实现 dependencygroupIdorg.springframework.cloud/groupIdartifactIdspring-cloud-starter-netflix-ribbon/artifactId /dependency 注意如果你已经引入了 nacos-discovery它已默认包含 Ribbon无需额外引入。 2.2 配置 RestTemplate 并启用 Ribbon 通过注解 LoadBalanced 可以让 RestTemplate 实现客户端负载均衡 Configuration public class RestConfig {BeanLoadBalancedpublic RestTemplate restTemplate() {return new RestTemplate();} } 2.3 调用示例 RestController RequestMapping(/order) public class UserController {Autowiredprivate RestTemplate restTemplate;GetMapping(/findOrder)public ResponseEntityString findOrderByUserId(PathVariable Integer id) {String url http://user/findUser?id id;return restTemplate.getForEntity(url, String.class);} } 3 Ribbon 负载均衡策略 Ribbon 提供了多种负载均衡策略包括 RoundRobinRule轮询策略默认实现。 RandomRule随机选择服务器。 RetryRule在失败时进行重试。 BestAvailableRule选择并发请求最小的服务器。 WeightedResponseTimeRule基于响应时间加权选择服务器。  要修改 Ribbon 的默认策略可以使用以下代码 Configuration public class RibbonConfig {Beanpublic IRule ribbonRule() {return new RoundRobinRule(); // 使用轮询策略} } 4 自定义 Ribbon 策略 要实现自定义 Ribbon 策略我们需要实现 IRule 接口并在 choose 方法中编写自定义的服务选择逻辑。 4.1 理解 Ribbon 策略接口 Ribbon 使用 IRule 接口来定义负载均衡策略。这个接口中最重要的方法是 Server choose(Object key): 返回选定的 Server 实例。 Ribbon 提供了多种内置策略如 RoundRobinRule、RandomRule 等我们可以通过实现自定义策略来满足更复杂的业务需求。 4.2 自定义策略实现步骤 2.1 创建自定义策略类 创建一个实现 IRule 接口的类或者继承 AbstractLoadBalancerRule这是 IRule 的一种抽象实现。 import com.netflix.loadbalancer.AbstractLoadBalancerRule; import com.netflix.loadbalancer.Server; import com.netflix.loadbalancer.LoadBalancerStats; import lombok.extern.slf4j.Slf4j;Slf4j public class CustomLoadBalancerRule extends AbstractLoadBalancerRule {Overridepublic Server choose(Object key) {// 获取负载均衡器实例LoadBalancerStats stats getLoadBalancer().getLoadBalancerStats();if (stats ! null) {// 在这里编写自定义的服务选择逻辑例如选择特定条件下的服务器for (Server server : getLoadBalancer().getAllServers()) {// 在此处实现自定义的过滤和选择逻辑if (server.isAlive() server.isReadyToServe()) {log.info(选择的服务实例: {}, server.getHostPort());return server;}}}return null; // 返回 null 时将根据 Ribbon 的默认行为处理}Overridepublic void initWithNiwsConfig(IClientConfig clientConfig) {// 初始化配置如果需要} } 4.3 在 Spring Boot 项目中配置使用自定义策略 将自定义策略配置为应用程序中某个服务的负载均衡策略。我们可以通过全局或局部配置来应用策略。 全局配置对所有的服务都使用自定义策略。 Configuration public class RibbonConfig {Beanpublic IRule ribbonRule() {return new CustomLoadBalancerRule(); // 使用自定义的策略} } 局部配置仅为特定服务配置自定义策略。通过在 application.yml 中设置 order:ribbon:NFLoadBalancerRuleClassName: com.example.CustomLoadBalancerRule 4.4 示例自定义策略基于响应时间加权选择 下面是一个基于服务器响应时间的自定义策略示例选出响应时间最短的服务器。 import com.netflix.loadbalancer.AbstractLoadBalancerRule; import com.netflix.loadbalancer.Server; import com.netflix.loadbalancer.LoadBalancerStats; import lombok.extern.slf4j.Slf4j;Slf4j public class WeightedResponseTimeRule extends AbstractLoadBalancerRule {Overridepublic Server choose(Object key) {LoadBalancerStats stats getLoadBalancer().getLoadBalancerStats();if (stats ! null) {double minResponseTime Double.MAX_VALUE;Server bestServer null;for (Server server : getLoadBalancer().getAllServers()) {double responseTime stats.getSingleServerStat(server).getResponseTimeAvg();if (server.isAlive() server.isReadyToServe() responseTime minResponseTime) {minResponseTime responseTime;bestServer server;}}if (bestServer ! null) {log.info(选择的最佳服务器: {}平均响应时间: {}, bestServer.getHostPort(), minResponseTime);return bestServer;}}return null;}Overridepublic void initWithNiwsConfig(IClientConfig clientConfig) {// 初始化配置如果需要} } 5 总结 Ribbon 是一种轻量级、易于使用的客户端负载均衡工具在微服务架构中扮演了重要角色。虽然它已被 Spring Cloud LoadBalancer 所取代但理解它的原理有助于深入学习负载均衡的实现细节。
http://www.sczhlp.com/news/182279/

相关文章:

  • 全球购物网站排名那些做软件的网站
  • 网站快速推广排名技巧手机版网站建设合同范本
  • 重庆杂酱制作网站seo诊断的主要内容
  • 郑州网站制作哪家好河南建设网站公司哪家好
  • 做直播网站软件有哪些软件react做的网站
  • 个人作品网站怎么做营销qq下载
  • 网站导航app网站建设实验
  • 微信公众号绑定网站网站制作论文总结
  • 做网站为什么需要花钱班级网站建设思路
  • 爱站网关键词密度查询厦门网站建设模拟平台
  • 网站标题字体设计黄山景区的网站做的怎么样
  • 专业营销网站wordpress文章页模板
  • wordpress企业站被黑小程序开发需要的技术
  • 福田做商城网站建设哪家便宜wordpress字体加载
  • 网站建设软著wordpress服务器搭建
  • 注册c模块到lua中使用
  • DNA权威书籍
  • 220V转5V500mA非隔离电源芯片WT5105
  • linux基础-find查找
  • 门户网站是什么意思?做网站为什么需要购买域名
  • 遵义原创网站东莞建设工程交易中心官网
  • 免费做期中考试的网站网站集约化建设的问题
  • 技术支持:上海网站建设怎么做整人的网站
  • 名创 网站建设商标注册网站官网
  • 视频解析网站建设如何在自己建设的网站上发表文章
  • 做网站用方正字体可以额的网站建设案例行情
  • 苏州h5模板建站公司管理流程
  • 荷城网站制作1m带宽做网站怎么样
  • 做低价的跨境电商网站东莞东城招聘网最新招聘
  • c2c电子商务网站建设栏目结构图北京建站优化