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

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

项目的源码

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

目录
相关文章
|
12天前
|
存储 JavaScript 开发工具
基于HarmonyOS 5.0(NEXT)与SpringCloud架构的跨平台应用开发与服务集成研究【实战】
本次的.HarmonyOS Next ,ArkTS语言,HarmonyOS的元服务和DevEco Studio 开发工具,为开发者提供了构建现代化、轻量化、高性能应用的便捷方式。这些技术和工具将帮助开发者更好地适应未来的智能设备和服务提供方式。
36 8
基于HarmonyOS 5.0(NEXT)与SpringCloud架构的跨平台应用开发与服务集成研究【实战】
|
17天前
|
SpringCloudAlibaba Dubbo Java
【SpringCloud Alibaba系列】Dubbo基础入门篇
Dubbo是一款高性能、轻量级的开源Java RPC框架,提供面向接口代理的高性能RPC调用、智能负载均衡、服务自动注册和发现、运行期流量调度、可视化服务治理和运维等功能。
【SpringCloud Alibaba系列】Dubbo基础入门篇
|
4天前
|
人工智能 自然语言处理 Java
Spring Cloud Alibaba AI 入门与实践
本文将介绍 Spring Cloud Alibaba AI 的基本概念、主要特性和功能,并演示如何完成一个在线聊天和在线画图的 AI 应用。
97 7
|
1月前
|
负载均衡 Java 开发者
深入探索Spring Cloud与Spring Boot:构建微服务架构的实践经验
深入探索Spring Cloud与Spring Boot:构建微服务架构的实践经验
150 5
|
2月前
|
JSON Java 测试技术
SpringCloud2023实战之接口服务测试工具SpringBootTest
SpringBootTest同时集成了JUnit Jupiter、AssertJ、Hamcrest测试辅助库,使得更容易编写但愿测试代码。
72 3
|
3月前
|
Dubbo Java 应用服务中间件
Dubbo学习圣经:从入门到精通 Dubbo3.0 + SpringCloud Alibaba 微服务基础框架
尼恩团队的15大技术圣经,旨在帮助开发者系统化、体系化地掌握核心技术,提升技术实力,从而在面试和工作中脱颖而出。本文介绍了如何使用Dubbo3.0与Spring Cloud Gateway进行整合,解决传统Dubbo架构缺乏HTTP入口的问题,实现高性能的微服务网关。
|
4月前
|
设计模式 Java 关系型数据库
【Java笔记+踩坑汇总】Java基础+JavaWeb+SSM+SpringBoot+SpringCloud+瑞吉外卖/谷粒商城/学成在线+设计模式+面试题汇总+性能调优/架构设计+源码解析
本文是“Java学习路线”专栏的导航文章,目标是为Java初学者和初中高级工程师提供一套完整的Java学习路线。
506 37
|
3月前
|
负载均衡 网络协议 Java
浅谈Springboot与Springcloud的区别
浅谈Springboot与Springcloud的区别
66 1
|
5月前
|
Java
SpringBoot和SpringCloud对应版本
SpringBoot和SpringCloud对应版本
97 0
|
4月前
|
SpringCloudAlibaba API 开发者
新版-SpringCloud+SpringCloud Alibaba
新版-SpringCloud+SpringCloud Alibaba