Spring Cloud微服务项目实战--Eureka服务搭建

2024-05-31 04:38

本文主要是介绍Spring Cloud微服务项目实战--Eureka服务搭建,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

今天我们要开始SpringCloud的微服务项目系列实战,我仍然以电商项目展开,从搭建一步步深入。在开始实战之前,我们先熟悉下SpringCloud。

一,Spring Cloud是什么?

SpringCloud是一个基于Spring Boot实现的云应用开发工具,它为基于JVM的云应用开发中涉及的配置管理、服务发现、断路器、智能路由、微代理、控制总线、全局锁、决策竞选、分布式会话和集群状态管理等操作提供了简单的开发方式。

Spring Cloud是微服务架构的集大成者,将一系列优秀的组件进行了整合。包含了多个子项目,比如:Spring Cloud Config、Spring Cloud Netflix、Spring Cloud Security、Spring Cloud Commons、Spring Cloud Zookeeper、Spring Cloud CLI等。在项目中通过一些简单的注解,就可以快速的在应用中配置一下常用模块并构建庞大的分布式系统。

SpringCloud的组件相当繁杂,拥有诸多子项目,我们这里重点关注Netflix。

二,SpringCloud分布式开发五大组件

  • 服务发现——Netflix Eureka

  • 客服端负载均衡——Netflix Ribbon

  • 断路器——Netflix Hystrix

  • 服务网关——Netflix Zuul

  • 分布式配置——Spring Cloud Config

今天说的重点就是Eureka,Eureka是Netflix 开发的,一个基于 REST 服务的,服务注册与发现的组件。

它主要包括两个组件:Eureka Server 和 Eureka Client

  • Eureka Server:注册中心,提供服务注册和发现的能力。里面有一个注册表,保存了各个服务所在的机器和端口号。

  • Eureka Client:一个Java客户端,用于简化与 Eureka Server 的交互。负责将这个服务的信息注册到Eureka Server中

如上图:每一个Service的微服务,都有一个Eureka Client组件,这个专门把这个服务的信息注册到Eureka Server中,说白了就是告诉Eureka Server,自己在哪台机器上,监听那个端口。Eureka 注册中心里的注册表,保存各个服务器的机器和端口。

例如电商的微服务环境中,我们有订单、支付、库存、商品等多个服务。如果那个服务想要知道其他服务信息,只需要问下他里面的Eureka Client组件,然后Eureka Client组件会问一下,其他服务都在哪里?然后就可以把其他的相关服务信息从Eureka Server的注册表中拉取到自己本地缓存起来。

如果我们下单,这时订单服务想要调用库存服务,不就可以找自己本地Eureka Client问题下库存服务在那台机器上,监听哪个端口吗?收到响应后,紧接着就可以发送一个请求过去,调用库存服务扣减库存的那个接口。同理,如果订单服务要调用商品服务、客户服务,也是如法炮制。

三,搭建项目实战

我先用IDEA创建一个SpringBoot的的项目。

1),创建SpringBoot项目

在Idea里依次点击:File >>> New  >>> Project,选择Maven,然后点击Next,创建一个SpringBoot项目。

2)添加SpringBoot父级依赖

在创建的项目pom文件里,添加SpringBoot如下:

  •  
  •  
  •  
  •  
  •  
  •  
<parent>    <groupId>org.springframework.boot</groupId>    <artifactId>spring-boot-starter-parent</artifactId>    <version>2.2.0.RELEASE</version>    <relativePath/></parent>

并在刚项目version属性下添加:<packaging>pom</packaging>

3)添加SpringCloud依赖

然后添加SpringBoot和SpringCloud基础依赖。

注意:SpringBoot和SpringCloud版本一定需要匹配,否则使用不了。具体匹配信息如下:

4)创建Eureka项目

在刚创建的项目中,删除src目录。并右击项目名称,New >>> Module。创建一个Eureka服务。创建完成如下:

5)为Eureka添加依赖和配置

Eureka服务的pom配置如下:

application.yml配置如下:

6)添加Eureka启动类

7)启动测试

启动Eureka启动类

8)访问Eureka服务

访问地址:http://localhost:8761/,打开输入账号密码(application.yml里配置),即可访问Eureka服务。

此刻,我们初步的Eureka服务搭建完成。今天就到这里,接下来将是微服务模块的搭建,并讨论服务注册与发现。

推荐阅读:

SpringBoot+SpringCloud面试总结都在这里

今年的金三银四,要找工作的请看这里

扫码关注公众号,可获取学习资料和实战项目源码哦

这篇关于Spring Cloud微服务项目实战--Eureka服务搭建的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1017390

相关文章

Java编译生成多个.class文件的原理和作用

《Java编译生成多个.class文件的原理和作用》作为一名经验丰富的开发者,在Java项目中执行编译后,可能会发现一个.java源文件有时会产生多个.class文件,从技术实现层面详细剖析这一现象... 目录一、内部类机制与.class文件生成成员内部类(常规内部类)局部内部类(方法内部类)匿名内部类二、

SpringBoot实现数据库读写分离的3种方法小结

《SpringBoot实现数据库读写分离的3种方法小结》为了提高系统的读写性能和可用性,读写分离是一种经典的数据库架构模式,在SpringBoot应用中,有多种方式可以实现数据库读写分离,本文将介绍三... 目录一、数据库读写分离概述二、方案一:基于AbstractRoutingDataSource实现动态

Springboot @Autowired和@Resource的区别解析

《Springboot@Autowired和@Resource的区别解析》@Resource是JDK提供的注解,只是Spring在实现上提供了这个注解的功能支持,本文给大家介绍Springboot@... 目录【一】定义【1】@Autowired【2】@Resource【二】区别【1】包含的属性不同【2】@

springboot循环依赖问题案例代码及解决办法

《springboot循环依赖问题案例代码及解决办法》在SpringBoot中,如果两个或多个Bean之间存在循环依赖(即BeanA依赖BeanB,而BeanB又依赖BeanA),会导致Spring的... 目录1. 什么是循环依赖?2. 循环依赖的场景案例3. 解决循环依赖的常见方法方法 1:使用 @La

Java枚举类实现Key-Value映射的多种实现方式

《Java枚举类实现Key-Value映射的多种实现方式》在Java开发中,枚举(Enum)是一种特殊的类,本文将详细介绍Java枚举类实现key-value映射的多种方式,有需要的小伙伴可以根据需要... 目录前言一、基础实现方式1.1 为枚举添加属性和构造方法二、http://www.cppcns.co

使用Python实现快速搭建本地HTTP服务器

《使用Python实现快速搭建本地HTTP服务器》:本文主要介绍如何使用Python快速搭建本地HTTP服务器,轻松实现一键HTTP文件共享,同时结合二维码技术,让访问更简单,感兴趣的小伙伴可以了... 目录1. 概述2. 快速搭建 HTTP 文件共享服务2.1 核心思路2.2 代码实现2.3 代码解读3.

Elasticsearch 在 Java 中的使用教程

《Elasticsearch在Java中的使用教程》Elasticsearch是一个分布式搜索和分析引擎,基于ApacheLucene构建,能够实现实时数据的存储、搜索、和分析,它广泛应用于全文... 目录1. Elasticsearch 简介2. 环境准备2.1 安装 Elasticsearch2.2 J

Java中的String.valueOf()和toString()方法区别小结

《Java中的String.valueOf()和toString()方法区别小结》字符串操作是开发者日常编程任务中不可或缺的一部分,转换为字符串是一种常见需求,其中最常见的就是String.value... 目录String.valueOf()方法方法定义方法实现使用示例使用场景toString()方法方法

Java中List的contains()方法的使用小结

《Java中List的contains()方法的使用小结》List的contains()方法用于检查列表中是否包含指定的元素,借助equals()方法进行判断,下面就来介绍Java中List的c... 目录详细展开1. 方法签名2. 工作原理3. 使用示例4. 注意事项总结结论:List 的 contain

MySQL双主搭建+keepalived高可用的实现

《MySQL双主搭建+keepalived高可用的实现》本文主要介绍了MySQL双主搭建+keepalived高可用的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,... 目录一、测试环境准备二、主从搭建1.创建复制用户2.创建复制关系3.开启复制,确认复制是否成功4.同