當(dāng)前位置:首頁(yè) > IT技術(shù) > 數(shù)據(jù)庫(kù) > 正文

SC Alibaba20211019 Nacos 手寫LoadBalancer
2021-10-22 17:00:02

1、provider

SC Alibaba20211019 Nacos         手寫LoadBalancer_ide

?

?SC Alibaba20211019 Nacos         手寫LoadBalancer_返回結(jié)果_02

?

?

?

?

?

?

2、?手寫LoadBalancer

SC Alibaba20211019 Nacos         手寫LoadBalancer_幫助文檔_03

?

?SC Alibaba20211019 Nacos         手寫LoadBalancer_返回結(jié)果_04

?

?SC Alibaba20211019 Nacos         手寫LoadBalancer_ide_05

?

?SC Alibaba20211019 Nacos         手寫LoadBalancer_ide_06

?

?SC Alibaba20211019 Nacos         手寫LoadBalancer_html_07

?

?SC Alibaba20211019 Nacos         手寫LoadBalancer_html_08

?

?SC Alibaba20211019 Nacos         手寫LoadBalancer_幫助文檔_09

?

?SC Alibaba20211019 Nacos         手寫LoadBalancer_幫助文檔_10

?

?

?

?

?

?

?

?

?

?

?

?

?

?

3、實(shí)例

? ? ? ? ? ? ? ?1)、provider2004

SC Alibaba20211019 Nacos         手寫LoadBalancer_ide_11

?

?SC Alibaba20211019 Nacos         手寫LoadBalancer_ide_12

?

?SC Alibaba20211019 Nacos         手寫LoadBalancer_返回結(jié)果_13

?

?

?

? ? ? ?2)、consumer2018? ??手寫LoadBalancer? ?

?

? ? ? ? ?i)、pom.xml

? ? ? ? ?

  <dependency>

    <groupId>org.springframework.boot</groupId>

    <artifactId>spring-boot-starter-web</artifactId>

  </dependency>

  <dependency>

    <groupId>com.alibaba.cloud</groupId>

    <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>

  </dependency>

? ? ???ii)、application.properties

? ? ? #?應(yīng)用名稱

  spring.application.name=consumer2018

  #?應(yīng)用服務(wù)?WEB?訪問端口

  server.port=2018

  #?Nacos幫助文檔:?https://nacos.io/zh-cn/docs/concepts.html

  #?Nacos認(rèn)證信息

  spring.cloud.nacos.discovery.username=nacos

  spring.cloud.nacos.discovery.password=nacos

  #?Nacos?服務(wù)發(fā)現(xiàn)與注冊(cè)配置,其中子屬性?server-addr?指定?Nacos?服務(wù)器主機(jī)和端口

  spring.cloud.nacos.discovery.server-addr=127.0.0.1:8848

  #?注冊(cè)到?nacos?的指定?namespace,默認(rèn)為?public

  spring.cloud.nacos.discovery.namespace=public

? ? ? ?iii)、LoadBalancer?

    public interface LoadBalancer {

      ServiceInstance getSingleAddres(List<ServiceInstance> serviceInstances);

    }

?

? ? ? ?iiii)、RotationLoadBalancer?

  @Component

  public class RotationLoadBalancer implements LoadBalancer{

  private AtomicInteger atomicInteger=new AtomicInteger(0);

    @Override

    public ServiceInstance getSingleAddres(List<ServiceInstance> serviceInstances) {

      int index=atomicInteger.incrementAndGet()%serviceInstances.size();

      return serviceInstances.get(index);

    }

  }

?

? ? ? ? iiiii)、Consumer2018Application?

?

  @SpringBootApplication

  public class Consumer2018Application {

    public static void main(String[] args) {

      SpringApplication.run(Consumer2018Application.class, args);

    }

    @Bean

    public RestTemplate restTemplate(){

    return new RestTemplate();

    }

  }

?

? ? ???iiiiii)、OrderService

? ? ?

  @RestController

  public class OrderService {

    @Autowired

    private DiscoveryClient discoveryClient;

    @Autowired

    private RestTemplate restTemplate;

    @Autowired

    private LoadBalancer loadBalancer;

    @RequestMapping("/orderToMember")

    public String orderToMember(){

      List<ServiceInstance> instances=discoveryClient.getInstances("provider2004");

      ServiceInstance serviceInstance=instances.get(0);

      String rpcMemberUrl2=serviceInstance.getUri().toString();

      String result2=restTemplate.getForObject(rpcMemberUrl2+"/hello/123131321312",String.class);

      String rpcMemberUrl=loadBalancer.getSingleAddres(instances).getUri().toString();

      String result=restTemplate.getForObject(rpcMemberUrl+"/hello/123131321312",String.class);

      return "調(diào)用provider2004 返回結(jié)果:"+result;

    }

  }

?

SC Alibaba20211019 Nacos         手寫LoadBalancer_返回結(jié)果_14

?

?SC Alibaba20211019 Nacos         手寫LoadBalancer_ide_15

?

本文摘自 :https://blog.51cto.com/s

開通會(huì)員,享受整站包年服務(wù)立即開通 >