spring Cloud之服务治理篇

服务治理介绍

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

服务注册介绍

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

优秀的个人博客,低调大师

微信关注我们

原文链接:https://yq.aliyun.com/articles/695894

转载内容版权归作者及来源网站所有!

低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。

相关文章

发表评论

资源下载

更多资源
Mario,低调大师唯一一个Java游戏作品

Mario,低调大师唯一一个Java游戏作品

马里奥是站在游戏界顶峰的超人气多面角色。马里奥靠吃蘑菇成长,特征是大鼻子、头戴帽子、身穿背带裤,还留着胡子。与他的双胞胎兄弟路易基一起,长年担任任天堂的招牌角色。

Apache Tomcat7、8、9(Java Web服务器)

Apache Tomcat7、8、9(Java Web服务器)

Tomcat是Apache 软件基金会(Apache Software Foundation)的Jakarta 项目中的一个核心项目,由Apache、Sun 和其他一些公司及个人共同开发而成。因为Tomcat 技术先进、性能稳定,而且免费,因而深受Java 爱好者的喜爱并得到了部分软件开发商的认可,成为目前比较流行的Web 应用服务器。

Java Development Kit(Java开发工具)

Java Development Kit(Java开发工具)

JDK是 Java 语言的软件开发工具包,主要用于移动设备、嵌入式设备上的java应用程序。JDK是整个java开发的核心,它包含了JAVA的运行环境(JVM+Java系统类库)和JAVA工具。

Sublime Text 一个代码编辑器

Sublime Text 一个代码编辑器

Sublime Text具有漂亮的用户界面和强大的功能,例如代码缩略图,Python的插件,代码段等。还可自定义键绑定,菜单和工具栏。Sublime Text 的主要功能包括:拼写检查,书签,完整的 Python API , Goto 功能,即时项目切换,多选择,多窗口等等。Sublime Text 是一个跨平台的编辑器,同时支持Windows、Linux、Mac OS X等操作系统。