• 微服务之服务注册与发现--Eureka(附代码)


    该贴为入门贴,看完可快速知道服务注册与发现是什么?怎么用?至于深入的内容不在此篇文章所述之内,请自行百度。

    内容来自:https://blog.csdn.net/nanbiebao6522/article/details/80574463

    本文讲述如下内容:

    1、什么是Eureka,什么是服务注册与发现

    2、服务端

    3、客户端---服务提供者

    4、客户端--服务消费者

    5、负载均衡

    1、什么是Eureka,什么是服务注册与发现

    Spring Boot作为目前最火爆的web框架。那么它与Eureka又有什么关联呢?

    Eureka是Netflix开源的一个RESTful服务,主要用于服务的注册发现。

    Eureka由两个组件组成:Eureka服务器Eureka客户端(服务提供者、服务消费者)。Eureka服务器用作服务注册服务器。

    Eureka客户端是一个java客户端,用来简化与服务器的交互、作为轮询负载均衡器,并提供服务的故障切换支持。

    Netflix在其生产环境中使用的是另外的客户端,它提供基于流量、资源利用率以及出错状态的加权负载均衡。

    2、服务端

    这里需要用到spring-cloud的Eureka模块,他是一个服务的注册和发现模块

    如图我们先new一个Spring-boot工程引入Eureka Server

     添加SpringBoot启动类:

    package com.eureka.server;
    import org.springframework.boot.SpringApplication;
    import org.springframework.boot.autoconfigure.SpringBootApplication;
    import org.springframework.cloud.netflix.eureka.server.EnableEurekaServer;
    /**
     * 启动一个服务注册中心
     */
    @EnableEurekaServer
    @SpringBootApplication
    public class ServerApplication {
     
        public static void main(String[] args) {
            SpringApplication.run(ServerApplication.class, args);
        }
    }

    Eureka是一个高可用的组件,每一个实例注册之后需要向注册中心发送心跳包,在默认情况下erureka server也是一个eureka client ,必须要指定一个 server。eureka server的配置文件appication.yml:

    server:
      port: 8081 #服务注册中心端口号
    eureka:
      instance:
        hostname: 127.0.0.1 #服务注册中心IP地址
      client:
        registerWithEureka: false #是否向服务注册中心注册自己
        fetchRegistry: false #是否检索服务
        serviceUrl: #服务注册中心的配置内容,指定服务注册中心的位置
          defaultZone: http://${eureka.instance.hostname}:${server.port}/eureka/

     启动后,访问http://127.0.0.1:8081/可以在界面看到:

     到这里,服务端就完成了。

    接着来搞客户端

    3、客户端---服务提供者

     客户端在向注册中心它会提供一些元数据,例如主机和端口,URL,主页等。Eureka server 从每个client实例接收心跳消息。 如果心跳超时,则通常将该实例从注册server中删除。       

     创建客户端和服务端差不多,只是启动注解有点不一样,还有yml配置文件

    配置启动类:

    package com.eureka.provider;
    import org.springframework.boot.SpringApplication;
    import org.springframework.boot.autoconfigure.SpringBootApplication;
    import org.springframework.cloud.netflix.eureka.EnableEurekaClient;
    import org.springframework.web.bind.annotation.GetMapping;
    import org.springframework.web.bind.annotation.RequestParam;
    import org.springframework.web.bind.annotation.ResponseBody;
    import org.springframework.web.bind.annotation.RestController;
    import java.util.HashMap;
    import java.util.Map;
    /**
     * Eureka客户端
     */
    @RestController
    @EnableEurekaClient
    @SpringBootApplication
    public class ProviderApplication {
     
        public static void main(String[] args) {
            SpringApplication.run(ProviderApplication.class, args);
        }
     
     
        /**
         * 假如这个客户端要提供一个getUser的方法
         * @return
         */
        @GetMapping(value = "/getUser")
        @ResponseBody
        public Map<String,Object> getUser(@RequestParam Integer id){
            Map<String,Object> data = new HashMap<>();
            data.put("id",id);
            data.put("userName","admin");
            data.put("from","provider-A");
            return data;
        }
     
    }

    配置yml文件:

    eureka:
      client:
        serviceUrl: #注册中心的注册地址
          defaultZone: http://127.0.0.1:8081/eureka/
    server:
      port: 8082  #服务端口号
    spring:
      application:
        name: service-provider #服务名称--调用的时候根据名称来调用该服务的方法

    访问服务端界面,可以看到应用已经注册到服务中心了:

    OK,到这里客户端--服务提供者搞定了,接着来搞客户端--服务消费者。 

    4、客户端--服务消费者

     

    配置启动类:

    package com.eureka.consumer;
    
    import org.springframework.beans.factory.annotation.Autowired;
    import org.springframework.boot.SpringApplication;
    import org.springframework.boot.autoconfigure.SpringBootApplication;
    import org.springframework.cloud.client.loadbalancer.LoadBalanced;
    import org.springframework.cloud.netflix.eureka.EnableEurekaClient;
    import org.springframework.context.annotation.Bean;
    import org.springframework.web.bind.annotation.GetMapping;
    import org.springframework.web.bind.annotation.RequestParam;
    import org.springframework.web.bind.annotation.ResponseBody;
    import org.springframework.web.bind.annotation.RestController;
    import org.springframework.web.client.RestTemplate;
    
    import java.util.HashMap;
    import java.util.Map;
    
    /**
     * Eureka客户端-消费者
     */
    @RestController
    @EnableEurekaClient
    @SpringBootApplication
    public class ConsumerApplication {
    
        @Autowired
        RestTemplate restTemplate;
    
        public static void main(String[] args) {
            SpringApplication.run(ConsumerApplication.class, args);
        }
    
        /**
         * 实例化RestTemplate
         * @return
         */
        @LoadBalanced
        @Bean
        public RestTemplate rest() {
            return new RestTemplate();
        }
    
        /**
         * Rest服务端使用RestTemplate发起http请求,然后得到数据返回给前端----gotoUser是为了区分getUser怕小伙伴晕头
         * @param id
         * @return
         */
        @GetMapping(value = "/gotoUser")
        @ResponseBody
        public Map<String,Object> getUser(@RequestParam Integer id){
            Map<String,Object> data = new HashMap<>();
            /**
             * 小伙伴发现没有,地址居然是http://service-provider
             * 居然不是http://127.0.0.1:8082/
             * 因为他向注册中心注册了服务,服务名称service-provider,我们访问service-provider即可
             */
            data = restTemplate.getForObject("http://service-provider/getUser?id="+id,Map.class);
            return data;
        }
    
    
    }

    配置yml文件:

    eureka:
      client:
        serviceUrl: #注册中心的注册地址
          defaultZone: http://127.0.0.1:8081/eureka/
    server:
      port: 8083  #服务端口号
    spring:
      application:
        name: service-consumer #服务名称--调用的时候根据名称来调用该服务的方法

    启动后,可以在服务端界面看到,消费者已经注册上去了:

    OK,服务消费者搞定了。

    我们把服务提供者复制一个工程出来,我们再做下小小的修改,看看是否能实现负载均衡 

    5、负载均衡

     复制一份服务提供者的代码,修改端口,启动两个服务提供者。可以看到两个PROVIDER的实例,如下:

     分别来访问两个服务提供者的效果如下,响应内容8082--A,8088--B :

     通过消费者来访问,效果如下,请求的同一个端口,返回的内容不同,说明内部做了负载,两个服务提供者在交替工作:

    补充一个图便于理解:

    每个微服务都是一个Eureka-Client,我们把每个app(SpringBootApplication)都向注册中心注册一个服务。
    有时候,某个服务的工作量比较大的时候,我们可以多注册几个同名称的微服务,从而让他们交替工作,减轻单个服务的压力。

  • 相关阅读:
    XIX Open Cup, Grand Prix of China【杂题】
    开发自己的composer包
    IOS微信禁用分享跳转页面返回BUG修复
    Pytest Fixture(一)
    Python使用requests和requests_toolbelt上传文件
    Pytest之参数化
    Pytest Fixture(三)
    Pytest 多进程并发执行
    Pytest Fixture(二)
    20212923 202120222 《网络攻防实践》第二次作业
  • 原文地址:https://www.cnblogs.com/aligege/p/10876751.html
Copyright © 2020-2023  润新知