zoukankan      html  css  js  c++  java
  • SpringCloud组件Eureka

    什么是微服务架构

    架构设计概念,各服务间隔离(分布式也是隔离),自治(分布式依赖整体组合)其它特性(单一职责,边界,异步通信,独立部署)是分布式概念的跟严格执行
    SOA到微服务架构的演进过程
    作用:各服务可独立应用,组合服务也可系统应用(巨石应用[monolith]的简化实现策略-平台思想)

    SOA架构与微服务架构区别

    SOA架构主要针对企业级、采用ESB服务(ESB企业服务总线),非常重,需要序列化和反序列化,采用XML格式传输。
    微服务架构主要互联网公司,轻量级、小巧,独立运行,基于Http+Rest+JSON格式传输。
    ESB也可以说是传统中间件技术与XML、Web服务等技术相互结合的产物。

    SpringCloud

    SpringCloud 为开发人员提供了快速构建分布式系统的一些工具,包括配置管理、服务发现、断路器、路由、负载均衡、
    微代理、事件总线、全局锁、决策竞选、分布式会话等等。它运行环境简单,可以在开发人员的电脑上跑。
    另外说明spring cloud是基于Springboot的,所以需要开发中对Springboot有一定的了解,如果不了解的话可以看蚂蚁课堂SpringBoot课程。

    服务提供者与消费关系

    服务提供者:提供服务被人调用
    消费者:调用被人服务

    服务的注册与发现(Eureka )

    在这里,我们需要用的的组件上Spring Cloud Netflix的Eureka ,eureka是一个服务注册和发现模块。

    什么是Eureka

    官方的介绍在这里Eureka wiki。Eureka是Netflix开源的一个RESTful服务,主要用于服务的注册发现。
    Eureka由两个组件组成:Eureka服务器和Eureka客户端。Eureka服务器用作服务注册服务器。
    Eureka客户端是一个java客户端,用来简化与服务器的交互、作为轮询负载均衡器,并提供服务的故障切换支持。
    Netflix在其生产环境中使用的是另外的客户端,它提供基于流量、资源利用率以及出错状态的加权负载均衡。
    在我看来,Eureka的吸引力来源于以下几点:
    开源:大家可以对实现一探究竟,甚至修改源码。
    可靠:经过Netflix多年的生产环境考验,使用应该比较靠谱省心
    功能齐全:不但提供了完整的注册发现服务,还有Ribbon等可以配合使用的服务。
    基于Java:对于Java程序员来说,使用起来,心里比较有底。
    spring cloud可以使用Spring Cloud, 与Eureka进行了很好的集成,使用起来非常方便。

     实现服务注册

    创建springcloud_eureka_server项目

    导依赖

        <!--eureka依赖-->
        <dependency>
          <groupId>org.springframework.cloud</groupId>
          <artifactId>spring-cloud-starter-netflix-eureka-server</artifactId>
        </dependency>
    
    
    <dependencyManagement>
        <dependencies>
          <!--springCloud依赖-->
          <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-dependencies</artifactId>
            <version>Greenwich.RELEASE</version>
            <type>pom</type>
            <scope>import</scope>
          </dependency>
        </dependencies>
      </dependencyManagement>        

    配置文件application.yml

    ##应用名称
    spring:
      application:
        name: eureka-server
    ##声明当前eurekaserver的端口号
    server:
      port: 8888
    ##配置eureka
    eureka:
      client:
        ##代表是否将自己注册到注册中心当中去
        register-with-eureka: false
        ##表明自己是注册中心
        fetch-registry: false
        ##配置地址
        server-url:
          defaultZone:http//localhost:8888/eureka

    启动StarEurekaServer

    @SpringBootApplication
    @EnableEurekaServer
    public class StarEurekaServer {
        public static void main(String[] args) {
            SpringApplication.run(StarEurekaServer.class,args);
        }
    }
  • 相关阅读:
    springmvc与ajax交互
    [PAT] A1052 Linked List Sorting
    [PAT] A1032 Sharing
    [PAT] A1076 Forwards on Weibo
    [PAT] A1034 Head of a Gang
    [PAT] A1030 Travel Plan
    [PAT] A1031 Hello World for U
    [PAT] A1029 Median
    [PAT] A1028 List Sorting
    [PAT] A1026 Table Tennis
  • 原文地址:https://www.cnblogs.com/dabrk/p/12055144.html
Copyright © 2011-2022 走看看