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

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

项目的源码

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

目录
相关文章
|
29天前
|
自然语言处理 Java API
Spring Boot 接入大模型实战:通义千问赋能智能应用快速构建
【10月更文挑战第23天】在人工智能(AI)技术飞速发展的今天,大模型如通义千问(阿里云推出的生成式对话引擎)等已成为推动智能应用创新的重要力量。然而,对于许多开发者而言,如何高效、便捷地接入这些大模型并构建出功能丰富的智能应用仍是一个挑战。
109 6
|
1月前
|
Dubbo Java 应用服务中间件
Dubbo学习圣经:从入门到精通 Dubbo3.0 + SpringCloud Alibaba 微服务基础框架
尼恩团队的15大技术圣经,旨在帮助开发者系统化、体系化地掌握核心技术,提升技术实力,从而在面试和工作中脱颖而出。本文介绍了如何使用Dubbo3.0与Spring Cloud Gateway进行整合,解决传统Dubbo架构缺乏HTTP入口的问题,实现高性能的微服务网关。
|
2月前
|
设计模式 Java 关系型数据库
【Java笔记+踩坑汇总】Java基础+JavaWeb+SSM+SpringBoot+SpringCloud+瑞吉外卖/谷粒商城/学成在线+设计模式+面试题汇总+性能调优/架构设计+源码解析
本文是“Java学习路线”专栏的导航文章,目标是为Java初学者和初中高级工程师提供一套完整的Java学习路线。
422 37
|
1月前
|
负载均衡 网络协议 Java
浅谈Springboot与Springcloud的区别
浅谈Springboot与Springcloud的区别
38 1
|
2月前
|
缓存 NoSQL Java
Springboot实战——黑马点评之秒杀优化
【9月更文挑战第27天】在黑马点评项目中,秒杀功能的优化对提升系统性能和用户体验至关重要。本文提出了多项Spring Boot项目的秒杀优化策略,包括数据库优化(如索引和分库分表)、缓存优化(如Redis缓存和缓存预热)、并发控制(如乐观锁、悲观锁和分布式锁)以及异步处理(如消息队列和异步任务执行)。这些策略能有效提高秒杀功能的性能和稳定性,为用户提供更佳体验。
157 6
|
3月前
|
NoSQL Java Redis
Redis6入门到实战------ 八、Redis与Spring Boot整合
这篇文章详细介绍了如何在Spring Boot项目中整合Redis,包括在`pom.xml`中添加依赖、配置`application.properties`文件、创建配置类以及编写测试类来验证Redis的连接和基本操作。
Redis6入门到实战------ 八、Redis与Spring Boot整合
|
3月前
|
Java API UED
【实战秘籍】Spring Boot开发者的福音:掌握网络防抖动,告别无效请求,提升用户体验!
【8月更文挑战第29天】网络防抖动技术能有效处理频繁触发的事件或请求,避免资源浪费,提升系统响应速度与用户体验。本文介绍如何在Spring Boot中实现防抖动,并提供代码示例。通过使用ScheduledExecutorService,可轻松实现延迟执行功能,确保仅在用户停止输入后才触发操作,大幅减少服务器负载。此外,还可利用`@Async`注解简化异步处理逻辑。防抖动是优化应用性能的关键策略,有助于打造高效稳定的软件系统。
74 2
|
3月前
|
Java 微服务 Spring
SpringBoot+Vue+Spring Cloud Alibaba 实现大型电商系统【分布式微服务实现】
文章介绍了如何利用Spring Cloud Alibaba快速构建大型电商系统的分布式微服务,包括服务限流降级等主要功能的实现,并通过注解和配置简化了Spring Cloud应用的接入和搭建过程。
SpringBoot+Vue+Spring Cloud Alibaba 实现大型电商系统【分布式微服务实现】
|
3月前
|
JSON Java API
解码Spring Boot与JSON的完美融合:提升你的Web开发效率,实战技巧大公开!
【8月更文挑战第29天】Spring Boot作为Java开发的轻量级框架,通过`jackson`库提供了强大的JSON处理功能,简化了Web服务和数据交互的实现。本文通过代码示例介绍如何在Spring Boot中进行JSON序列化和反序列化操作,并展示了处理复杂JSON数据及创建RESTful API的方法,帮助开发者提高效率和应用性能。
160 0
|
3月前
|
SQL Java 数据库连接
Spring Boot联手MyBatis,打造开发利器:从入门到精通,实战教程带你飞越编程高峰!
【8月更文挑战第29天】Spring Boot与MyBatis分别是Java快速开发和持久层框架的优秀代表。本文通过整合Spring Boot与MyBatis,展示了如何在项目中添加相关依赖、配置数据源及MyBatis,并通过实战示例介绍了实体类、Mapper接口及Controller的创建过程。通过本文,你将学会如何利用这两款工具提高开发效率,实现数据的增删查改等复杂操作,为实际项目开发提供有力支持。
187 0

热门文章

最新文章