springCloud Finchley 实战入门(基于springBoot 2.0.3)【二 服务治理 Eureka】

简介: 开发工具及环境说明Idea 2018.1建议使用idea作为开发工具,因为idea在我们创建项目的时候可以通过选择组件的方式帮助在pom.xml自动引用对应的jar位置。

开发工具及环境说明

  • Idea 2018.1
    建议使用idea作为开发工具,因为idea在我们创建项目的时候可以通过选择组件的方式帮助在pom.xml自动引用对应的jar位置。
  • jdk 1.8
    springBoot 2.x就默认需要使用jdk1.8的,这个没有什么好说
  • maven 3.3.9
  • windows 10

服务治理 springCloud Eureka

springCloud Eureka是spring Cloud Netflix微服务套件的一部分。它基于Netflix Eureka做了二次封装的。该组件的主要任务是负责微服务架构中的服务治理功能。
服务治理可以说是微服务架构中最为核心和基础的模块,主要是用来实现各个微服务实例的自动注册与发现。

快速入门

首先我们先创建一个基础的项目,最为接下来项目组件项目的父类项目。

  1. 创建parent项目

选择spring Initializr


img_0cb47406e156c3c10628c5531a764487.png
15324186431.jpg

填写项目名称


img_159a30f583b164738c9656840a3854d3.png
15324186811.jpg

创建一个空的项目


img_25e69e214a6ef830be3b369eef8974c7.png
15324187001.jpg

创建完成把项目下除了pom.xml文件全部删除


img_c33c0bb8859606e06c303203b937b9b9.png
15324188521.jpg

pom文件添加以下的配置

<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.version>Finchley.RELEASE</spring-cloud.version>
</properties>

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

<!--使用aliyun镜像-->
<repositories>
    <repository>
        <id>alimaven</id>
        <name>Maven Aliyun Mirror</name>
        <url>http://maven.aliyun.com/nexus/content/repositories/central/</url>
        <releases>
            <enabled>true</enabled>
        </releases>
        <snapshots>
            <enabled>false</enabled>
        </snapshots>
    </repository>
</repositories>

搭建服务注册中心

在父类项目下新建一个module。


img_a71873176589badec258a3729b2f04a0.png
15324194591.jpg

把module命名为"eureka-register-center"


img_b7d9f43a785037869328d273f10fb571.png
1532419586.jpg

选择Eureka-server组件


img_c769ab60d0b3d36a6b29bdb7f37a3a1d.png
15324196651.jpg

这个时候pom.xml的内容应该是这样子的

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>

    <groupId>com.example</groupId>
    <artifactId>eureka-register-center</artifactId>
    <version>0.0.1-SNAPSHOT</version>
    <packaging>jar</packaging>

    <name>eureka-register-center</name>
    <description>Demo project for Spring Boot</description>

    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>2.0.3.RELEASE</version>
        <relativePath/> <!-- lookup parent from repository -->
    </parent>

    <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.version>Finchley.RELEASE</spring-cloud.version>
    </properties>

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

    <build>
        <plugins>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
            </plugin>
        </plugins>
    </build>


</project>

配置application.yml

将resources目录下的application.properties改名为application.yml。springBoot的配置文件格式有yaml和properties两种格式。本人喜欢使用yaml格式。所以项目中的配置文件都是以yml来使用。
配置文件内容如下:相关的字段也有解释

server:
  port: 8761
spring:
  application:
    name: service-register
eureka:
  instance:
    prefer-ip-address: false
    hostname: localhost
  client:
    fetch-registry: false
    register-with-eureka: false
    serviceUrl:
      defaultZone: http://${eureka.instance.hostname}:${server.port}/eureka/
  server:
    wait-time-in-ms-when-sync-empty: 0
     # 测试时关闭自我保护机制,保证不可用服务及时踢出 默认打开状态,建议生产环境打开此配置
    enable-self-preservation: true #(设为false,关闭自我保护主要)
    eviction-interval-timer-in-ms: 4000 #清理间隔(单位毫秒,默认是60*1000)

注意:
fetch-registry 由于注册中心的任务是维护实例服务,他并不需要去检索服务,所以也设置为false
register-with-eureka 由于该应用为注册中心,所以设置为false,代表不向注册中心注册自己

项目主类名添加@EnableEurekaServer注解


img_7f3a56a3b7b9b03a9e9f25f88e75cc1a.png
15324215071.jpg

通过上面的配置就把eureka 服务注册中心搭建起来了。
启动应用并访问地址 http://localhost:8761/ 。可以看到如下图显示的eureka信息面板。Instances currently registered with Eureka这里是空的。说明该注册中心还没有注册任何服务。

img_e94238f65c6ae0f254bef6df955035fd.png
15324210891.jpg

到这里说明我们的eureka服务注册中心是正常的。

注册服务提供者

按照创建服务注册中心的方式创建一个eureka-client 项目。
pom文件和上面的一样。只是application.yml不同

spring:
  application:
    name: service-eureka-client
server:
  port: 8800

然后在项目主类名添加@EnableDiscoveryClient注解。表示该项目作为一个服务实例注册到服务注册中心。


img_fadf410e114e699e2f833472a75b6116.png
15324216771.jpg

到这里其实服务提供者的一个服务实例就基本搭建好了,我们启动服务如果没有报错那应该就没有问题。
确保服务正常启动后,我们重新再访问 http://localhost:8761/

img_bd6c6bc2a35ec302e355219093bb255d.png
20180724171946396.png

在服务注册中心的项目面板,我们可以看到了eureka-cient服务实例已经注册到了服务注册中心。

PS: 可能有人会疑问~为什么我们的服务提供者eureka-client项目中的配置文件只配置了端口和服务名称外,就没有其他额外的配置了。为什么这个服务实例会自动注册到服务注册中心的?
我们可以查看源码:EurekaClientConfigBean这个类
在这个类我们可以看到,注册中心的地址是默认为http://localhost:8761的,这也是我们为什么会在之前的注册中心配置port为8761.

@(bolg)ConfigurationProperties(EurekaClientConfigBean.PREFIX)
public class EurekaClientConfigBean implements EurekaClientConfig {

    public static final String PREFIX = "eureka.client";

    public static final String DEFAULT_URL = "http://localhost:8761" + DEFAULT_PREFIX
            + "/";

    public static final String DEFAULT_ZONE = "defaultZone";

    private static final int MINUTES = 60;

我们其实也可以在application.yml显示的指明服务注册中心的地址。

spring:
  application:
    name: service-eureka-client
server:
  port: 8800
eureka:
  client:
      serviceUrl:
        defaultZone: http://localhost:8761/eureka

到这里一个基础的服务注册中心和服务提供者项目实例就已经搭建好了。

项目的源码

在微服务架构中,我们需要充分的考虑发生故障的情况,所以在生产环境中必须对各个组件进行高可用部署。上面演示的只是单个服务,下一篇我们会讲一下服务注册中心怎样高可用部署。

目录
相关文章
|
1月前
|
消息中间件 Cloud Native Java
【Spring云原生系列】SpringBoot+Spring Cloud Stream:消息驱动架构(MDA)解析,实现异步处理与解耦合
【Spring云原生系列】SpringBoot+Spring Cloud Stream:消息驱动架构(MDA)解析,实现异步处理与解耦合
|
1月前
|
消息中间件 JSON Java
Spring Boot、Spring Cloud与Spring Cloud Alibaba版本对应关系
Spring Boot、Spring Cloud与Spring Cloud Alibaba版本对应关系
553 0
|
2天前
|
Java Nacos 开发者
Java从入门到精通:4.2.1学习新技术与框架——以Spring Boot和Spring Cloud Alibaba为例
Java从入门到精通:4.2.1学习新技术与框架——以Spring Boot和Spring Cloud Alibaba为例
|
24天前
|
开发框架 负载均衡 Java
Spring boot与Spring cloud之间的关系
总之,Spring Boot和Spring Cloud之间的关系是一种构建和扩展的关系,Spring Boot提供了基础,而Spring Cloud在此基础上提供了分布式系统和微服务架构所需的扩展和工具。
18 4
Spring boot与Spring cloud之间的关系
|
1月前
|
人工智能 负载均衡 Java
【Spring实战】动手拥有自己的ai小站!使用Springboot整合Spring Cloud Gateway实现对接open ai并实现令牌记量和限制对话次数
【Spring实战】动手拥有自己的ai小站!使用Springboot整合Spring Cloud Gateway实现对接open ai并实现令牌记量和限制对话次数
|
2月前
|
XML Java API
Spring Boot 和 Spring Cloud: 区别与联系
在现代企业级应用开发中,Spring Boot 和 Spring Cloud 是两个非常流行的项目。它们通常被用于构建和部署微服务架构的应用。尽管它们属于同一个大家族 —— Spring,但它们的设计目标和应用场景有所不同。本文将探讨 Spring Boot 和 Spring Cloud 的基本区别和它们之间的联系。
90 9
|
2月前
|
Java 调度 开发工具
SpringCloud【微服务架构进化论、微服务的拆分规范和原则、为什么选择Spring Cloud、什么是服务治理 】(一)-全面详解(学习总结---从入门到深化)
SpringCloud【微服务架构进化论、微服务的拆分规范和原则、为什么选择Spring Cloud、什么是服务治理 】(一)-全面详解(学习总结---从入门到深化)
184 0
|
Java 应用服务中间件 Maven
传统maven项目和现在spring boot项目的区别
Spring Boot:传统 Web 项目与采用 Spring Boot 项目区别
357 0
传统maven项目和现在spring boot项目的区别
|
XML Java 数据库连接
创建springboot项目的基本流程——以宠物类别为例
创建springboot项目的基本流程——以宠物类别为例
127 0
创建springboot项目的基本流程——以宠物类别为例
|
存储 机器学习/深度学习 IDE
SpringBoot 项目与被开发快速迁移|学习笔记
快速学习 SpringBoot 项目与被开发快速迁移
157 0
SpringBoot 项目与被开发快速迁移|学习笔记