spring Cloud之服务治理篇

  1. 云栖社区>
  2. 博客>
  3. 正文

spring Cloud之服务治理篇

划破天际 2019-03-29 16:16:04 浏览685
展开阅读全文

服务治理介绍

服务治理可以说是微服务中最为核心和基础的模块,主要用来实现各个微服务的自动化注册和发现。

服务注册介绍

  在服务治理框架中,通常都会构建一个注册中心,每个服务单元向注册中心登记自己提供的服务,将主机和端口号、
  版本号、通讯协议等一些附加信息告知注册中心。注册中心按服务名分类组织服务清单。
  服务注册中心还需要以心跳的方式去监测清单中的服务是否可用,不可用则从服务清单中剔除,以此达到排除故障服务。
  • 以下示例:
    image

服务发现介绍

  服务调用方在调用服务提供方的接口时,并不知道具体的实例服务地址,因此,服务调用方需要向服务注册中心咨询服务。
  并获得所有的服务实例清单,以实现对具体服务实例的访问。

Netflix Eureka介绍

  spring cloud Eureka使用Netflix Eureka来实现服务注册和发现。Eureka包含了服务端组件同时也包含了客户端组件。

搭建服务注册中心

创建springboot项目

  • pom.xml引入spring-cloud-*响应的包

      <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-netflix-eureka-server</artifactId>
        </dependency>
    <dependencyManagement>
        <dependencies>
            <dependency>
                <groupId>org.springframework.cloud</groupId>
                <artifactId>spring-cloud-dependencies</artifactId>
                <version>${spring-cloud.version}</version>
                <type>pom</type>
                <scope>import</scope>
            </dependency>
        </dependencies>
    </dependencyManagement>

application.properties配置

   server.port=1111
  eureka.instance.hostname=localhost
  //由于该应用为注册中心所以设置为false,表示不能向注册中心注册自己
  eureka.client.register-with-eureka=false
  //由于注册中心的职责就是维护服务实例,不需要去检索服务,也设置为false
  eureka.client.fetch-registry=false
  eureka.client.serviceUrl.defaultZone=http://${eureka.instance.hostname}:${server.port}/eureka/

springboot项目启动类加注解

  @EnableEurekaServer

访问链接

结果

image

注册服务提供者

创建springboot项目

  • pom.xml导入有关eureka包

            <dependency>
                <groupId>org.springframework.cloud</groupId>
                <artifactId>spring-cloud-starter-eureka</artifactId>
                <version>${spring-cloud-starter-eureka.version}</version>
            </dependency>
        <dependencyManagement>
        <dependencies>
            <dependency>
                <groupId>org.springframework.cloud</groupId>
                <artifactId>spring-cloud-dependencies</artifactId>
                <version>Greenwich.SR1</version>
                <type>pom</type>
                <scope>import</scope>
            </dependency>
        </dependencies>
    </dependencyManagement>
  • 启动类加@EnableDiscoveryClient注解
  • application.properties配置相关信息

    //注册中心服务名
     spring.application.name=hello-server
    //注册中心地址
    eureka.client.serviceUrl.defaultZone=http://localhost:1111/eureka/

启动服务提供者项目再回到注册中心查看就有服务了

image

网友评论

登录后评论
0/500
评论
划破天际
+ 关注