SpringCloud【Greenwich版本】第一章 服务注册与发现(Eureka)

序言

在去年参加云栖大会的时候,从分享嘉宾的项目介绍中得知了SpringCloud,仅知道是当下比较火热的微服务解决方案,能为不同行业,不同领域提供更高效、更便捷、成本更低的服务;这次正好公司需要更换框架,所以自己非常荣幸能学习下伟大的SpringCloud。

SpringCloud版本

本次所有测试项目中Springboot版本为2.1.4.RELEASE,SpringCloud版本为Greenwich.SR1,JDK版本为1.8,集成环境为IntelliJ IDEA。

服务端注册

Spring cloud 为开发人员提供了快速构建分布式系统的一些工具,包括配置管理、服务发现、断路器、路由、微代理、事件总线、全局锁、决策竞选、分布式会话等等。运行环境简单,底层基于springboot,所以在下面开发之前,小编建议你具备两个概念,第一个是什么是springboot?springboot怎么运用?;第二个是什么叫微服务架构?

好了,闲话不多说了,切入主题,开始先来创建 eureka server。

项目创建

打开IntelliJ,新建项目工程,选择Spring Assistant(若碰到没有Spring Assistant需要在IntelliJ的插件库中查询并安装即可)

选择SpringAssistant

设置完项目属性后,选择Cloud Discovery,再勾选上Eureka Server,直接完成就可以了

选择Cloud Discovery

启动服务

项目创建后,我们先来看下pom.xml,ide已经帮我们自动创建好项目的依赖

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

        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-tomcat</artifactId>
            <scope>provided</scope>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
        </dependency>
    </dependencies>

    <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>

这里主要依赖spring clound 和 spring-cloud-starter-netflix-eureka-server,接下来只需要配置下端口和服务名称就完工啦

注解配置

在启动类文件里面添加eureka server注解

    @SpringBootApplication
    @EnableEurekaServer
    public class EurekaServerApplication {

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

    }

端口、服务配置

在application.properties加上端口和服务配置

    server.port=8761

    eureka.instance.hostname=localhost
    eureka.client.registerWithEureka=false
    eureka.client.fetchRegistry=false
    eureka.client.serviceUrl.defaultZone=http://${eureka.instance.hostname}:${server.port}/eureka/

    spring.application.name=eureka-server

浏览访问

出现下图,代码你已经成功启动了Eureka Server _

eureka-server browser

客户端注册

创建客户端

Eureka客户端与服务端只是依赖的jar包有所区别,其他都差不多

安装依赖

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

配置注解

启动类添加注解

@SpringBootApplication
@EnableEurekaClient
@EnableDiscoveryClient
public class EurekaclientApplication {

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

}

配置端口、服务

同样application.properties里面配置端口和服务名称

server.port=8762

spring.application.name=service-hi

eureka.client.serviceUrl.defaultZone=http://localhost:8761/eureka/

浏览访问

刷新之前服务窗口,你会惊奇的发现有个service-hi客户端服务了,出现下图效果,恭喜你第一章已经搞定啦_

Eureka client browser

项目示例地址

https://github.com/lenvonsam/spring-cloud-training/tree/master/chapter-one

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Spring Cloud学习02-服务注册与发现 Spring Cloud简介 Spring Cloud是一个基于...
    it_zzy阅读 4,677评论 2 20
  • Eureke Eureka是Netflix开源的一款提供服务注册和发现的产品,它提供了完整的Service Reg...
    fad2aa506f5e阅读 490评论 0 0
  • 心忘方入妙,意到不求工。 点拂横斜处,天机在其中。 再平坦的路,缺失一颗平坦的心,那也是一场崎...
    半樵阅读 1,270评论 11 25
  • 中国有句老话:没有规矩不成方圆。校有校规,班有班规,家也有家规。 而我的家规,那叫一个狠!家规如下: ...
    曹越0阅读 496评论 0 2
  • 《地藏经》 稽首本然清净地 无尽佛藏大慈尊 南方世界涌香云 香雨花云及花雨 宝雨宝云无数种 为祥为瑞遍庄严 天人问...
    yanziguilai阅读 2,169评论 0 2