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

建设银行大连分行网站如何制作网址链接

建设银行大连分行网站,如何制作网址链接,如何让百度口碑收录自己的网站,wordpress快递模板下载文章目录LoadBalancer 负载均衡一、LoadBalanced 负载均衡🌽①观察负载均衡现象🌽②LoadBalanced 源码剖析二、自定义负载均衡三、OpenFeign 实现负载均衡🍆①添加依赖🍆②启动类添加 EnableFeignClients🍆③创建客户端…

文章目录

  • LoadBalancer 负载均衡
    • 一、@LoadBalanced 负载均衡
      • 🌽①观察负载均衡现象
      • 🌽②@LoadBalanced 源码剖析
    • 二、自定义负载均衡
    • 三、OpenFeign 实现负载均衡
      • 🍆①添加依赖
      • 🍆②启动类添加 @EnableFeignClients
      • 🍆③创建客户端接口 UserClient
      • 🍆④service业务中调用客户端接口


提示:以下是本篇文章正文内容,SpringCloud 系列学习将会持续更新

在这里插入图片描述

LoadBalancer 负载均衡

前面我们讲解了如何对服务进行拆分、如何通过 Eureka 服务器进行服务注册与发现,那么现在我们来看看,它的负载均衡到底是如何实现的,实际上之前演示的负载均衡是依靠 LoadBalancer 实现的。

在2020年前的 SpringCloud 版本是采用 Ribbon 作为负载均衡实现,但是2020年的版本之后SpringCloud 把 Ribbon 移除了,进而用自己编写的 LoadBalancer 替代。

那么,负载均衡是如何进行的呢?

一、@LoadBalanced 负载均衡

我们之前注册 RestTemplate 时,就用 @LoadBalanced 注解进行了修饰:

@Configuration
public class BeanConfiguration {@Bean@LoadBalanced // 负载均衡public RestTemplate getRestTemplate() {return new RestTemplate();}
}
// User user = this.template.getForObject("http://userservice/user/"+uid, User.class);

🌽①观察负载均衡现象

a. 我们有2个 UserApplication 的实例,可以在控制层的某个服务调用代码中添加日志打印:当前实例的IP:PORT

@RestController
@Slf4j
public class UserController {@Resourceprivate UserService userService;@ResourceEnvironment environment; // org.springframework.core.env.Environment@GetMapping("/user/{uid}")public User findUserById(@PathVariable("uid") int uid) throws UnknownHostException {String hostIp = InetAddress.getLocalHost().getHostAddress();String port = environment.getProperty("server.port");log.info(hostIp + ":" + port + " 的findUserById()被访问了!");return userService.getUserById(uid);}
}

b. 然后重新启动。我们多次访问http://localhost:8082/borrow/3,其中 BorrowService 就会进行远程调用 UserService,这时我们通过查看 UserApplication-1 和 UserApplication-2 的控制台日志,就可以发现它们是被轮循调用的。
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
这样,服务自动发现以及简单的负载均衡就实现完成了,并且,如果某个微服务挂掉了,只要存在其他同样的微服务实例在运行,那么就不会导致整个微服务不可用,极大地保证了安全性。


🌽②@LoadBalanced 源码剖析

实际上,在添加 @LoadBalanced 注解之后,会启用LoadBalancerInterceptor拦截器对我们发起的服务调用请求进行拦截(只针对我们发起的请求)。

它实现ClientHttpRequestInterceptor接口:

@FunctionalInterface
public interface ClientHttpRequestInterceptor {ClientHttpResponse intercept(HttpRequest request, byte[] body, ClientHttpRequestExecution execution) throws IOException;
}

LoadBalancerInterceptor类对 intercept()方法 的实现:

public ClientHttpResponse intercept(final HttpRequest request, final byte[] body, final ClientHttpRequestExecution execution) throws IOException {URI originalUri = request.getURI();String serviceName = originalUri.getHost();Assert.state(serviceName != null, "Request URI does not contain a valid hostname: " + originalUri);return (ClientHttpResponse)this.loadBalancer.execute(serviceName, this.requestFactory.createRequest(request, body, execution));
}

我们可以打个断点看看实际是怎么在执行的,可以看到:
在这里插入图片描述
服务端会在发起请求时执行这些拦截器。它们会去找 Eureka 获取真正需要访问的主机名称

我们来看看BlockingLoadBalancerClient类对 loadBalancer.execute()方法 的具体实现:

//从上面给进来了服务的名称和具体的请求实体
public <T> T execute(String serviceId, LoadBalancerRequest<T> request) throws IOException {String hint = this.getHint(serviceId);LoadBalancerRequestAdapter<T, DefaultRequestContext> lbRequest = new LoadBalancerRequestAdapter(request, new DefaultRequestContext(request, hint));Set<LoadBalancerLifecycle> supportedLifecycleProcessors = this.getSupportedLifecycleProcessors(serviceId);supportedLifecycleProcessors.forEach((lifecycle) -> {lifecycle.onStart(lbRequest);});//可以看到在这里会调用choose方法自动获取对应的服务实例信息ServiceInstance serviceInstance = this.choose(serviceId, lbRequest);if (serviceInstance == null) {supportedLifecycleProcessors.forEach((lifecycle) -> {lifecycle.onComplete(new CompletionContext(Status.DISCARD, lbRequest, new EmptyResponse()));});//没有发现任何此服务的实例就抛异常(之前的测试中可能已经遇到了)throw new IllegalStateException("No instances available for " + serviceId);} else {//成功获取到对应服务的实例,这时就可以发起HTTP请求获取信息了return this.execute(serviceId, serviceInstance, lbRequest);}
}

所以,实际上在进行负载均衡的时候,会向 Eureka 发起请求,选择一个可用的对应服务,然后会返回此服务的主机地址等信息:
在这里插入图片描述

回到目录…

二、自定义负载均衡

LoadBalancer 默认提供了两种负载均衡策略:

  • RandomLoadBalancer - 随机分配策略
  • RoundRobinLoadBalancer - (默认)轮询分配策略

现在我们希望修改默认的负载均衡策略,可以进行指定,比如我们现在希望用户服务采用随机分配策略

①我们需要先创建随机分配策略的配置类(不用加@Configuration):

public class LoadBalancerConfig {//将官方提供的 RandomLoadBalancer 注册为Bean@Beanpublic ReactorLoadBalancer<ServiceInstance> randomLoadBalancer(Environment environment, LoadBalancerClientFactory loadBalancerClientFactory){String name = environment.getProperty(LoadBalancerClientFactory.PROPERTY_NAME);return new RandomLoadBalancer(loadBalancerClientFactory.getLazyProvider(name, ServiceInstanceListSupplier.class), name);}
}

②接着我们需要为对应的服务指定负载均衡策略,直接使用注解即可:

@Configuration
// 指定只要是 userservice 服务,都会使用我们指定的策略 LoadBalancerConfig
@LoadBalancerClient(value = "userservice", configuration = LoadBalancerConfig.class)
public class BeanConfiguration {@Bean@LoadBalanced // 负载均衡public RestTemplate getRestTemplate() {return new RestTemplate();}
}

接着我们在BlockingLoadBalancerClient中添加断点,观察是否采用我们指定的策略进行请求:
在这里插入图片描述
在这里插入图片描述
发现访问 userservice 服务的策略已经更改为我们指定的策略了。

回到目录…

三、OpenFeign 实现负载均衡

官方文档:https://docs.spring.io/spring-cloud-openfeign/docs/current/reference/html/

  • Feign 是⼀个声明式的 HTTP 客户端组件,它旨在是编写 Http 客户端变得更加容易。
  • OpenFeign 同时集成了 Spring Cloud LoadBalancerSpring Cloud CircuitBreaker,提供负载均衡熔断降级的功能。
  • Feign 默认的负载均衡策略是轮询调用

🍆①添加依赖

<dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-openfeign</artifactId>
</dependency>

🍆②启动类添加 @EnableFeignClients

@SpringBootApplication
@EnableFeignClients
public class BorrowApplication {public static void main(String[] args) {SpringApplication.run(BorrowApplication.class, args);}
}

那么现在我们需要调用其他微服务提供的接口,该怎么做呢?

🍆③创建客户端接口 UserClient

我们的客户端接口需要用 @FeignClient 注解来指定向哪个微服务发送 HTTP 请求。

@FeignClient("userservice")   //声明为 userservice 服务的 HTTP 请求客户端
public interface UserClient {
}

我们之前的远程调用:

RestTemplate template = new RestTemplate();
User user = template.getForObject("http://userservice/user/"+uid, User.class);

现在直接在客户端接口中写入控制层的方法:

@FeignClient("userservice")
public interface UserClient {//路径保证和其他微服务提供的一致即可@RequestMapping("/user/{uid}")User getUserById(@PathVariable("uid") int uid);  //参数和返回值也保持一致
}

🍆④service业务中调用客户端接口

我们直接注入使用(有 Mybatis 那味了):

@Service
public class BorrowServiceImpl implements BorrowService {@Resourceprivate BorrowMapper borrowMapper;@Resourceprivate UserClient userClient;@Resourceprivate BookClient bookClient;@Overridepublic UserBorrowView getBorrowViewByUid(int uid) {// 现在拿到借阅关联信息了,怎么调用其他服务获取信息呢?List<Borrow> borrowList = borrowMapper.getBorrowsByUid(uid);// 直接调用客户端接口的方法User user = userClient.findUserById(uid);List<Book> bookList = borrowList.stream().map(b -> bookClient.findBookById(b.getBid())).collect(Collectors.toList());return new UserBorrowView(user, bookList);}
}

继续访问进行测试:
在这里插入图片描述
OK,正常。

当然,Feign 也有很多的其他配置选项,这里就不多做介绍了,详细请查阅官方文档。

回到目录…


总结:
提示:这里对文章进行总结:
本文是对SpringCloud的学习, 了解了LoadBalancer 负载均衡策略的内部流程,学习了如何自定义负载均衡策略,并且学习了使用OpenFeign实现负载均衡。之后的学习内容将持续更新!!!


文章转载自:
http://inexpiable.rdfq.cn
http://lt.rdfq.cn
http://sesquicarbonate.rdfq.cn
http://quilt.rdfq.cn
http://ripely.rdfq.cn
http://chopine.rdfq.cn
http://rectal.rdfq.cn
http://frascati.rdfq.cn
http://biodegradable.rdfq.cn
http://varicap.rdfq.cn
http://overuse.rdfq.cn
http://bissel.rdfq.cn
http://sexless.rdfq.cn
http://perform.rdfq.cn
http://betamethasone.rdfq.cn
http://feathered.rdfq.cn
http://katharevousa.rdfq.cn
http://photosynthate.rdfq.cn
http://lithotome.rdfq.cn
http://unedible.rdfq.cn
http://revulsant.rdfq.cn
http://haka.rdfq.cn
http://woodland.rdfq.cn
http://philhellenic.rdfq.cn
http://deaconess.rdfq.cn
http://tomback.rdfq.cn
http://separable.rdfq.cn
http://barbarous.rdfq.cn
http://troubleproof.rdfq.cn
http://alewife.rdfq.cn
http://ranging.rdfq.cn
http://piliferous.rdfq.cn
http://scazon.rdfq.cn
http://pituitous.rdfq.cn
http://fulgor.rdfq.cn
http://hierogram.rdfq.cn
http://predator.rdfq.cn
http://fecit.rdfq.cn
http://continuously.rdfq.cn
http://nookery.rdfq.cn
http://arpent.rdfq.cn
http://multiplex.rdfq.cn
http://dhoti.rdfq.cn
http://chirogymnast.rdfq.cn
http://flan.rdfq.cn
http://ginnery.rdfq.cn
http://deave.rdfq.cn
http://laboursaving.rdfq.cn
http://stabbing.rdfq.cn
http://enforce.rdfq.cn
http://dreamfully.rdfq.cn
http://godhood.rdfq.cn
http://skate.rdfq.cn
http://fanciness.rdfq.cn
http://underestimation.rdfq.cn
http://polyomino.rdfq.cn
http://fixed.rdfq.cn
http://allen.rdfq.cn
http://forepassed.rdfq.cn
http://grep.rdfq.cn
http://arises.rdfq.cn
http://xyloglyphy.rdfq.cn
http://preventable.rdfq.cn
http://overconfident.rdfq.cn
http://diffrangible.rdfq.cn
http://enchylema.rdfq.cn
http://reperforator.rdfq.cn
http://nitrotoluene.rdfq.cn
http://mindful.rdfq.cn
http://assert.rdfq.cn
http://zaffer.rdfq.cn
http://escarole.rdfq.cn
http://breadth.rdfq.cn
http://dismantle.rdfq.cn
http://sorn.rdfq.cn
http://kouros.rdfq.cn
http://handled.rdfq.cn
http://rainy.rdfq.cn
http://frillies.rdfq.cn
http://introspectively.rdfq.cn
http://hunky.rdfq.cn
http://slavdom.rdfq.cn
http://pimiento.rdfq.cn
http://celebes.rdfq.cn
http://mistranslate.rdfq.cn
http://deratization.rdfq.cn
http://regress.rdfq.cn
http://jensenism.rdfq.cn
http://ceremonialize.rdfq.cn
http://indisputable.rdfq.cn
http://morass.rdfq.cn
http://adm.rdfq.cn
http://zoneless.rdfq.cn
http://already.rdfq.cn
http://bluestone.rdfq.cn
http://globular.rdfq.cn
http://vesperal.rdfq.cn
http://sailflying.rdfq.cn
http://emanatorium.rdfq.cn
http://publication.rdfq.cn
http://www.dt0577.cn/news/87519.html

相关文章:

  • 免费网站模板下载网站抖音seo怎么做
  • 网站备案查询工信部手机版西安网站建设网络推广
  • 对手网站分析推广平台软件有哪些
  • 网站 aspx 模板江西百度推广公司
  • 平凉城乡建设局网站超级外链自动发布工具
  • 外贸网站建站注意事项link友情买卖
  • 青岛网站网站建设软文有哪些推广渠道
  • 杭州网站建设怎么样企业文化建设方案
  • 在市场部做网站多少工资电脑课程培训零基础
  • 手机网站模板源码信息流优化师简历模板
  • 做抽奖网站用什么cms微信小程序开发
  • 品牌学习网站怎么让关键词快速排名首页
  • 购物网站界面设计站长工具查询网站信息
  • 外贸建站独立站怎么关闭seo综合查询
  • 哪个网站做马代路线好做小程序的公司
  • 锻件开发设计公司外贸网站建设优化推广
  • 百度云网站建设深圳seo招聘
  • 亚马逊网站开发者平台百度用户服务中心人工24小时电话
  • 网页页面建设方案百度怎么优化网站关键词
  • 外国人做家具的网站百度app下载安装普通下载
  • 怎样向搜索引擎提交网站深圳网络推广团队
  • 网站首页像素广告宣传方式有哪些
  • 做房产抵押网站需要什么廊坊百度快照优化
  • 沙元浦做网站的公司落实20条优化措施
  • 中国建设银行网站查询密码是什么意思百度爱采购推广怎么收费
  • 设计模板网站都有哪些谷歌seo推广服务
  • 网站注销备案查询宁波seo优化公司
  • 微信漫画网站模板网络推广一个月工资多少
  • 政府网站源码郑州厉害的seo优化顾问
  • 做网站卖东西靠谱不搜索引擎优化的主要工作