入门spring clould --服务注册、发现

最近公司在推广spring cloud,之前只是听闻spring cloud大名,并没有实际在开发使用过,为了能更快接入spring cloud到项目中,自己学习并将学习过程进行整理,做一个spring cloud系列 。

前戏

学习spring cloud 必须对springboot有一定了解,因为spring cloud是基于spring boot作为基础框架,这里就不在赘述springboot 的使用。

  • spring cloud 简介
    一般学习一项技术第一个选择路径就是去官网(https://spring.io/projects/spring-cloud)看文档,虽然英语不好,但是通过翻译也知道个大概。也就是springcloud 提供了一系列快速构建分布式系统的工具(配置管理,服务发现,断路器,智能路由,微代理,控制总线,一次性令牌,全局锁定,领导选举,分布式会话,集群状态),适用于任何分布式环境。我们今天就是简单介绍服务发现的使用,其实spring cloud服务发现工具有很多可以用zokeeper、eureka等,这篇文章使用eureka作为服务发现工具。
  • eureka 简介
    同样我们可以去官网去看看https://github.com/Netflix/eureka
    image.png

Eureka是Netflix开发的服务发现框架,本身是一个基于REST的服务,主要用于定位运行在AWS域中的中间层服务,以达到负载均衡和中间层服务故障转移的目的。SpringCloud将它集成在其子项目spring-cloud-netflix中,以实现SpringCloud的服务发现功能。
这里我给出Eureka官网给出的架构图,并做一点简单解释,让我们对微服务或者eureka服务架构有一定了解。


image.png

直奔主题

在开始写代码之前先了解一下服务注册与发现,使用过 dubbo应该很熟悉下面这张图,其中注册中心、服务提供端、服务消费端是各种服务发现必有的模块,我们今天的spring cloud基本也基于此架构


image.png

今天我们项目的简单架构入下图,我们使用spring cloud 因为Eureka作为注册中心(Eureka server),两个服务组件用户服务和积分服务,再用户服务通过用户id调用积分服务中对应用户的积分。


image.png

搭建spring cloud 注册中心服务

建立springboot项目,需要注意的是spring cloud版本各种各样,需要根据springcloud版本使用对于springboot版本,有些版本间是不兼容的,我们可以参考spring官网给出的版本关系进入依赖https://spring.io/projects/spring-cloud

image.png

  1. 引入依赖
<properties>
        <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
        <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
        <java.version>1.8</java.version>
        <spring-cloud-task.version>2.0.0.RELEASE</spring-cloud-task.version>
        <spring-cloud.version>Finchley.SR1</spring-cloud.version>
    </properties>

    <dependencies>

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

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

    </dependencies>

2.作为注册中心启动

@SpringBootApplication
@EnableEurekaServer
public class SpringcloudApplication {
    public static void main(String[] args) {
        SpringApplication.run(SpringcloudApplication.class, args);
    }
}

  1. 配置
server:
  port: 8888


eureka:
  instance:
    hostname: localhost
  client:
    registerWithEureka: false # 这两个属性 作为注册中心时关闭其作为客户端去寻找注册的功能
    fetchRegistry: false     #
    serviceUrl:
      defaultZone: http://${eureka.instance.hostname}:${server.port}/eureka

spring:
        jmx:
          default-domain: eureka-server
        application:
          name: eureka-server

4.启动项目,访问https://localhost:8888出现下面页面,第一步注册中心就这样搭建成功。

成功

积分服务(score client)搭建

  1. 引入依赖,只需要将上面Eureka server依赖更换为client依赖
    <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
        </dependency>
        <!-- 需要使用springmvc -->
    <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>


2.核心代码

  • 启动类
@SpringBootApplication
@EnableEurekaClient
public class SpringCloudApplication {

    public static void main(String[] args) {
        SpringApplication.run(SpringCloudApplication.class, args);
    }
}
  • 获取积分的rest接口
@RestController
@RequestMapping("/score")
public class TestController {
    private static Logger logger = LoggerFactory.getLogger(TestController.class);

    /** 模拟数据库: demo 为了简单方便使用HashMap模拟查询数据库 */
    private static   HashMap<Integer,String> scoreDb  = new HashMap<>();
    static {
        scoreDb.put(1,"100");
        scoreDb.put(2,"88");
        scoreDb.put(3,"99");
        scoreDb.put(4,"90");
        scoreDb.put(5,"93");
    }

    @GetMapping("/get/{id}")
    public String test(@PathVariable String id){

        String score = scoreDb.get(id);
        System.err.println("查询"+ id +"分数:"+ score);

        return score;
    }

}

3.配置

server:
  port: 8800

eureka:
  instance:
    hostname: localhost
  client:
#    registerWithEureka: false    # 作为client端是 这两个使用默认值
#    fetchRegistry: false
    serviceUrl:
      defaultZone: http://localhost:8888/eureka   # eureka 服务注册中心地址,刚才启动的注册中心地址

spring:
        jmx:
          default-domain: score
        application:
          name: score-client

4.启动,在注册中心查看服务是否被发现


image.png

用户(user client)服务搭建

1、2步同上;

  1. 配置
server:
  port: 8802

eureka:
  instance:
    hostname: localhost
  client:
#    registerWithEureka: false    作为服务client 这两项默认(true)即可
#    fetchRegistry: false
    serviceUrl:
      defaultZone: http://localhost:8888/eureka # eureka 服务注册中心地址

spring:
        jmx:
          default-domain: user
        application:
          name: user-client

4.配置RestTemplate远程调用,其中使用@LoadBalanced注解进行负载均衡,下篇文章具体讲负载均衡的实现以及负载均衡策略自定义

@Configuration
public class BootConfig {
    private static Logger logger = LoggerFactory.getLogger(BootConfig.class);

    @Bean
    //此注解主要是开启负载均衡,在http调用时会将url根据Eureka 服务中实例做转换,并可以进行应 用端负载均衡
    @LoadBalanced
    public RestTemplate restTemplate(){
        return new RestTemplate();
    }

  
}

5.启动类配置和上面client一样

/**
 *  spring cloud 客户端
 *
 * @author tongqingbo
 */
@SpringBootApplication
@EnableEurekaClient
public class SpringCloudApplication {

    public static void main(String[] args) {
        SpringApplication.run(SpringCloudApplication.class, args);
    }
}

6.通过用户获取分数rest接口,需要注意的是我们不是采用直接调用真实的接口地址,而是使用eureka中注册的服务实体名,前提是需要在IOC注入的时候加 @LoadBalanced注解实现负载均衡,要不不能使用实体名访问;

@RestController
@RequestMapping("/user")
public class TestController {
    private static Logger logger = LoggerFactory.getLogger(TestController.class);

    @Autowired
    RestTemplate restTemplate ;

    @GetMapping("/getScore/{userId}")

    public String test(@PathVariable() String userId){
        //  此处调用地址在单体架构中可以直接使用IP:Port接口地址进行直接调用,那其实就体现不出来服务注册的作用了,这里的score-client就是在注册服务上的实体名称,可以简单理解为注册服务帮你做了映射
        String forObject = restTemplate.getForObject("http://score-client/score/get/"+userId, String.class);
        return  userId+ "获取积分: " + forObject;
    }

}

7.在服务注册页面查看此客户端已成功注册


image.png

在页面上调用user-client接口查看分数,可以成功查看;


image.png

总结:

其实spring cloud 就是一套分布式服务的工具集,此篇文章我们只是介绍服务注册、发现,其实在没有集群或者多网域的情况下我们不使用服务注册直接调用真实接口地址也是可行的,就像前后端分离一样直接调用接口,但是在集群情况下我们可以通过注册中心对服务进行管理;进行负载均衡、熔断、网关等实现高可用的服务。关于微服务的其他工具使用在后面也会慢慢讲到,我也是一边学习一边总结如果文中有什么描述不当或者理解错误的地方欢迎各位大佬批评指导。

补充

大家可以试一下,当注册中心宕机后其实服务还是能正常访问的,因为当一次访问成功后在客户端会有缓存这个调用地址,注册中心挂掉其实也不会立马导致服务功能无法实现,当然注册中心挂掉后我们应该及时处理问题,或者一般情况下核心服务节点都会做集群处理这样倒下一个服务器还有千千万万个服务器。

补充2,所有eureka client 在启动类的注解@EnableEurekaClient可以省略,springboot会自定配置进行EurekaClient的初始化配置。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 199,340评论 5 467
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 83,762评论 2 376
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 146,329评论 0 329
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 53,678评论 1 270
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 62,583评论 5 359
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 47,995评论 1 275
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,493评论 3 390
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,145评论 0 254
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,293评论 1 294
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,250评论 2 317
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,267评论 1 328
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,973评论 3 316
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,556评论 3 303
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,648评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,873评论 1 255
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,257评论 2 345
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 41,809评论 2 339

推荐阅读更多精彩内容