zoukankan      html  css  js  c++  java
  • springboot搭建Eureka注册中心

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


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

    1.Eureka是Netflix开源的一个RESTful服务,主要用于服务的注册发现。
    2.Eureka由两个组件组成:Eureka服务器和Eureka客户端。Eureka服务器用作服务注册服务器。
    3.Eureka客户端是一个java客户端,用来简化与服务器的交互、作为轮询负载均衡器,并提供服务的故障切换支持。
    4.Netflix在其生产环境中使用的是另外的客户端,它提供基于流量、资源利用率以及出错状态的加权负载均衡。


    一.先创建一个Eureka-Server服务注册中心

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


    1.pom.xml配置

    <dependency>
                <groupId>org.springframework.cloud</groupId>
                <artifactId>spring-cloud-starter-netflix-eureka-server</artifactId>
            </dependency>

    2.配置application.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/

    3.配置启动类引入@EnableEurekaServer

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

    4.访问注册中心

    二.创建一个Eureka-Client客户端

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


    1.pom.xml配置同步服务端

    2.配置application.yml文件

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

    3.配置启动类引入@EnableEurekaClient

    package com.sun.eureka;
    
    import org.springframework.boot.SpringApplication;
    import org.springframework.boot.autoconfigure.SpringBootApplication;
    import org.springframework.cloud.netflix.eureka.EnableEurekaClient;
    import org.springframework.scheduling.annotation.EnableScheduling;
    
    /**
       * 客户端
     * @author andy
     *
     */
    
    @EnableEurekaClient
    @SpringBootApplication
    public class EurekaClientApplication {
    
        public static void main(String[] args) {
            SpringApplication.run(EurekaClientApplication.class, args);
        }
    
    }

    4.定义ClientController控制器

    package com.sun.eureka.controller;
    
    import org.springframework.web.bind.annotation.GetMapping;
    import org.springframework.web.bind.annotation.RestController;
    
    @RestController
    public class ClientController {
    
        @GetMapping(value = "/index")
        public String getString(){
            return "Hello-Wolrd";
        }
    
    }

    接着我们来访问:127.0.0.1:8082/index

    5.再次访问注册中心
    注意矩形标记,此时我们已经成功的注册客户端service-client

    三.负载均衡的效果图

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

  • 相关阅读:
    sikiA计划问题记录
    列表+泛型
    查看别人项目找代码的方法
    Unity3d 异常与解决方案集合(持续)
    实现继承+接口继承+虚方法+隐藏方法+this/base+抽象类+密封类/方法+修饰符
    定义类+类实例化+属性+构造函数+匿名类型var+堆与栈+GC回收机制+值类型与引用类型
    局部变量和成员变量的区别
    数组元素二分查找(折半查找)
    数组元素冒泡排序
    数组元素选择排序
  • 原文地址:https://www.cnblogs.com/BruceV/p/12067096.html
Copyright © 2011-2022 走看看