[菜鸟SpringCloud入门]第一章:构建多模块的Maven项目+创建注册中心Eureka子模块
2020-12-17 13:34
标签:插入 教程 客户端连接 article 手册 支持 代码实现 tree 服务器 欢迎来到菜鸟SpringCloud入门实战系列(SpringCloudForNoob),该系列通过层层递进的实战视角,来一步步学习和理解SpringCloud。 本系列适合有一定Java以及SpringBoot基础的同学阅读。 每篇文章末尾都附有本文对应的Github源代码,方便同学调试。 Github仓库地址: https://github.com/qqxx6661/springcloud_for_noob 你还可以通过以下两种途径查看菜鸟SpringCloud入门实战系列: 由于SpringCloud中有许多组件,每个组件都需要单独进行开发和维护,为了便于统一的版本维护和管理,我们经常会用到Maven的多模块模式。 结构如下: 首先创建一个Maven项目作为主工程,类型无所谓,这里建议使用maven-archetype-quickstart骨架,创建过程如下: File-->New-->Project 在new-module里新建模块: 一路下一步即可: 在这里我们新建子模块名为eureka,用来放之后要用的eureka模块,新建好后,子模块的目录如下: 由于并不需要在主工程进行任何代码开发,所以删除其src目录。 可以看到现在我们的目录结构: 主工程的pom.xml里做的事: 上图简要描述了Eureka的基本架构,由3个角色组成: 1、Eureka Server 提供服务注册和发现 将自身服务注册到Eureka,从而使服务消费方能够找到 接下来我们在子模块Eureka中创建一个SpringCloud的注册中心Eureka 代码重点: 请问一下为什么我本地启动了3个,还是No instances available,DS Replicas里面有值 启动服务时候,如果存在application.properties,里面还设置了 EurekaApplication.java 如果你发现@EnableEurekaServer无法引入,请检查你的SpringCloud版本与SpringBoot版本是否兼容: springboot无法引入@enableeurekaserver以及Spring Cloud与Spring Boot版本匹配关系: https://blog.csdn.net/zhang53141/article/details/83091032 默认生成的配置文件是application.properties,也可以写成application.yml格式,配置如下: 注意: 可以看到下面的页面,其中还没有发现任何服务,这只是一个孤零零的eureka-server。 在下一个教程中,我们将创建服务提供者并在Eureka进行注册。 https://github.com/qqxx6661/springcloud_for_noob/tree/master/01-eureka 全复习手册文章导航:通过以下两种途径查看 菜鸟SpringCloud实战专栏 Spring-Cloud笔记01:IDEA中同一个项目启动多个实例: https://blog.csdn.net/hanchao5272/article/details/80558190 Spring-Cloud笔记02:IDEA中构建多模块的Maven项目: https://blog.csdn.net/hanchao5272/article/details/80558780 springcloud(二):注册中心Eureka: http://www.ityouknow.com/springcloud/2017/05/10/springcloud-eureka.html 我是蛮三刀把刀,后端开发。 主要关注后端开发,数据安全,爬虫等方向。 来微信和我聊聊:yangzd1102 Github个人主页:https://github.com/qqxx6661 同步更新公众号及以下博客 http://blog.csdn.net/qqxx6661 拥有专栏: https://www.zhihu.com/people/yang-zhen-dong-1/ 拥有专栏: https://juejin.im/user/5b48015ce51d45191462ba55 https://www.jianshu.com/u/b5f225ca2376 如果文章对你有帮助,不妨收藏起来并转发给您的朋友们~ [菜鸟SpringCloud入门]第一章:构建多模块的Maven项目+创建注册中心Eureka子模块 标签:插入 教程 客户端连接 article 手册 支持 代码实现 tree 服务器 原文地址:https://blog.51cto.com/15047490/2561078菜鸟SpringCloud入门实战系列
实战版本
-----正文开始-----
构建多模块的Maven项目 + 创建注册中心Eureka子模块
构建多模块的Maven项目
在这里插入图片描述创建主工程
-->Maven-->Create from archetype-->maven-archetype-quickstart-Next
-->GroupId={你的GroupId}-->AritifactId={你的ArtifactId}
-->Next-->Next-->Finish-->New Whindow创建子模块
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述删除主工程多于目录
编辑主工程pom.xml
创建注册中心Eureka子模块
Eureka介绍
服务中心又称注册中心,管理各种服务功能包括服务的注册、发现、熔断、负载、降级等,比如dubbo admin后台的各种功能。
Spring Cloud 封装了 Netflix 公司开发的 Eureka 模块来实现服务注册和发现。Eureka 采用了 C-S 的设计架构。Eureka Server 作为服务注册功能的服务器,它是服务注册中心。而系统中的其他微服务,使用 Eureka 的客户端连接到 Eureka Server,并维持心跳连接。这样系统的维护人员就可以通过 Eureka Server 来监控系统中各个微服务是否正常运行。Spring Cloud 的一些其他模块(比如Zuul)就可以通过 Eureka Server 来发现系统中的其他微服务,并执行相关的逻辑。
Eureka由两个组件组成:Eureka服务器和Eureka客户端。Eureka服务器用作服务注册服务器。Eureka客户端是一个java客户端,用来简化与服务器的交互、作为轮询负载均衡器,并提供服务的故障切换支持。Netflix在其生产环境中使用的是另外的客户端,它提供基于流量、资源利用率以及出错状态的加权负载均衡。
在这里插入图片描述
2、Service Provider
3、Service Consumer编辑子模块Eureka的pom.xml
eureka.client.register-with-eureka=false
eureka.client.fetch-registry=false,还是会去读取,导致服务没能注册.添加启动代码中添加@EnableEurekaServer注解
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.netflix.eureka.server.EnableEurekaServer;
@SpringBootApplication
@EnableEurekaServer
public class EurekaApplication {
public static void main(String[] args) {
SpringApplication.run(EurekaApplication.class, args);
}
}
配置文件
# 端口号
server:
port: 8761
# 服务注册相关配置
eureka:
# 服务实例主机名
instance:
hostname: localhost
# 服务提供者配置
client:
# 不进行注册(当服务注册中心是单点而非高可用时的配置方式)
registerWithEureka: false
# 不获取注册信息(当服务注册中心是单点而非高可用时的配置方式)
fetchRegistry: false
# 服务注册中心地址
serviceUrl:
defaultZone: http://${eureka.instance.hostname}:${server.port}/eureka/
运行
在这里插入图片描述本文教程所对应工程代码
-----正文结束-----
参考
关注我
原创博客主要内容
个人公众号:Rude3Knife
个人公众号:Rude3Knife
文章标题:[菜鸟SpringCloud入门]第一章:构建多模块的Maven项目+创建注册中心Eureka子模块
文章链接:http://soscw.com/index.php/essay/36860.html