B082-SpringCloud-Eureka

目录

      • 微服务架构与springcloud
        • 架构演变
        • 为什么使用微服务
        • 微服务的通讯方式
        • 架构的选择
        • springcloud概述
        • 场景模拟之基础架构的搭建
        • 模拟微服务之间的服务调用
        • 目前远程调用的问题
      • eureka
        • 注册中心的作用
        • 注册中心的实现
        • 服务提供者注册到注册中心

springcloud基于springboot

微服务架构与springcloud

架构演变

1.一个单体项目
缺点:大型项目文件太多体积太大,维护难,编译难,测试难,一个tomcat不够用
在这里插入图片描述
2.集群部署单体项目(多做几个,做的都是同样的事情)
只能解决上述第4个问题,前三个问题更复杂,如改代码要同步改整个集群
新出现问题:不是所有功能用的人都很多,不同的功能需要集群的数量不一致
在这里插入图片描述
3.根据功能把项目分开,把单独的模块拆成项目
可以解决不同功能需要集群数量不一致的问题和剩下的前3个问题
新出现问题:服务之间的通信,jar之间的相互依赖
在这里插入图片描述
4.最后用上springcloud管理微服务
在这里插入图片描述

为什么使用微服务

一个项目/系统中各个模块的压力
压力大的模块做集群分担压力
在这里插入图片描述
其他见文档2.1.1,2.1.2,2.2.1,2.2.2

微服务的通讯方式

见文档2.2.3

架构的选择

见文档2.3

微服务是一种思想,是一种架构模式
springcloud是微服务的一种落地方案

见文档2.4

springcloud主要用来解决微服务之间通信的一系列问题

springcloud概述

见文档3

场景模拟之基础架构的搭建

不同的项目不同的端口
建立一个公共项目用来存放其他项目共同用到的类,然后给其他项目依赖,如user-common中的domain,query,user等
在这里插入图片描述
新建maven项目D082-springcloud-parent,tips:不要用下划线
删除src

新建maven模块user-common

新建maven模块user-provider-4010

新建maven模块user-consumer-5010

user-common的pom中引入lombok,刷新依赖,建立User类

生产者和消费者两个项目的pom中各自引入user-common,刷新依赖,新建UserController,使用依赖过来的User类

模拟微服务之间的服务调用

tips:隐藏不需要关心的.idea和.iml文件
设置 - 编辑器 - 文件类型 - 忽略文件和文件夹中追加* .idea;* .iml;

父级pom引入相关依赖

生产者和消费者两个项目的pom中各自引入web和test依赖,新建application.yml,配置端口,新建启动类

改造生产者的UserController,
启动生产者项目,浏览器访问:http://localhost:4010/user/provider/1

消费者中新建config.HttpUtils,把RestTemplate交给容器管理
新建UserController,
启动生产者和消费者两个项目,浏览器访问:http://localhost:5010/user/consumer/2

目前远程调用的问题

在这里插入图片描述
如消费者URL中的ip目前是localhost,上线后会变化
上线后如果提供者机器挂了重开一台机器,消费者记的还是以前的provider的地址
消费者不知道提供者机器的状态,是否健康,是否挂了
提供者只有一台机器,挂了就都没了
这种模式进行提供者集群后,消费者难以实现负载均衡

负责均衡:实时知道集群中有多少机器,哪些机器可用,哪些机器不可用,不给不可用机器发请求

eureka

注册中心的作用

见文档5.1
在这里插入图片描述

注册中心的实现

springcloud是基于springboot的,所以选择版本要对应

新建工程eureka-server-1010

导入相关依赖

<!--springboot支持-->
<dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-test</artifactId>
</dependency><!--Eureka服务端支持-->
<dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-netflix-eureka-server</artifactId>
</dependency>

新建application.yml,配置参数

server:port: 1010
eureka:instance:hostname: localhostclient:registerWithEureka: false #是否要注册到eurekafetchRegistry: false #表示是否从Eureka Server获取注册信息serviceUrl:defaultZone: http://${eureka.instance.hostname}:${server.port}/eureka/ #单机配置

新建启动类EurekaApp

@SpringBootApplication
@EnableEurekaServer
public class EurekaApp {public static void main(String[] args) {SpringApplication.run(EurekaApp.class);}
}

启动项目,浏览器访问:http://localhost:1010

服务提供者注册到注册中心

生产者项目引入euraka-client依赖

 	<!--eureka客户端支持 --><dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-netflix-eureka-client</artifactId></dependency>

application.yml加入相关参数

server:port: 4010
spring:application:name: user-provider
eureka:client:service-url:defaultZone: http://localhost:1010/eureka

启动类加入euraka客户端注解

@SpringBootApplication
@EnableEurekaClient //表示是eureka的客户端
public class App {public static void main(String[] args) {SpringApplication.run(App.class,args);}
}

浏览器访问:http://localhost:1010,可看到注册进来的 USER-PROVIDER

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/716546.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

10 计算机结构

冯诺依曼体系结构 冯诺依曼体系结构&#xff0c;也被称为普林斯顿结构&#xff0c;是一种计算机架构&#xff0c;其核心特点包括将程序指令存储和数据存储合并在一起的存储器结构&#xff0c;程序指令和数据的宽度相同&#xff0c;通常都是16位或32位 我们常见的计算机,笔记本…

在Centos7中用Docker部署gitlab-ce

一、介绍 GitLab Community Edition (GitLab CE) 是一个开源的版本控制系统和协作平台&#xff0c;用于管理和追踪软件开发项目。它提供了一套完整的工具和功能&#xff0c;包括代码托管、版本控制、问题跟踪、持续集成、持续交付和协作功能&#xff0c;使团队能够更加高效地进…

动态规划|【路径问题】|931.下降路径最小和

目录 题目 题目解析 思路 1.状态表示 2.状态转移方程 3.初始化 4.填表顺序 5.返回值 代码 题目 931. 下降路径最小和 给你一个 n x n 的 方形 整数数组 matrix &#xff0c;请你找出并返回通过 matrix 的下降路径 的 最小和 。 下降路径 可以从第一行中的任何元素开…

【Vue3】Props的使用详解

&#x1f497;&#x1f497;&#x1f497;欢迎来到我的博客&#xff0c;你将找到有关如何使用技术解决问题的文章&#xff0c;也会找到某个技术的学习路线。无论你是何种职业&#xff0c;我都希望我的博客对你有所帮助。最后不要忘记订阅我的博客以获取最新文章&#xff0c;也欢…

概率基础——多元正态分布

概率基础——多元正态分布 介绍 多元正态分布是统计学中一种重要的多维概率分布&#xff0c;描述了多个随机变量的联合分布。在多元正态分布中&#xff0c;每个随机变量都服从正态分布&#xff0c;且不同随机变量之间可能存在相关性。本文将以二元标准正态分布为例&#xff0…

多线程JUC 第2季 中断线程

一 中断线程 1.1 中断概念 1.在java中&#xff0c;没有提供一种立即停止一条线程。但却给了停止线程的协商机制-中断。 中断是一种协商机制。中断的过程完全需要程序员自己实现。也即&#xff0c;如果要中断一个线程&#xff0c;你需要手动调用该线程的interrupt()方法&…

录制用户操作实现自动化任务

先上视频&#xff01;&#xff01; 流程自动化工具-录制操作绘制流程 这个想法之前就有了&#xff0c;趁着周末时间给它撸出来。 实现思路 从之前的文章自动化桌面未来展望中已经验证了录制绘制流程图的可行性。基于DOM录制页面操作轨迹的思路监听页面点击、输入事件即可&…

无人机镜头稳定的原理和相关算法

无人机的镜头稳定主要基于两个关键技术&#xff1a;镜头平衡技术和实时电子稳像。无人机镜头稳定的原理和相关算法主要是通过镜头平衡技术和实时电子稳像技术来保持摄像镜头的稳定性&#xff0c;从而拍摄出清晰、稳定的画面。无人机镜头稳定的原理主要是通过传感器和算法来实现…

Ocr之PaddleOcr模型训练

目录 一、系统环境 1 镜像拉取ppocr 进行部署 2 安装paddlepaddle 二、训练前的准备 1 下载源码 2 预模型下载 3 修改模型训练文件yml 4 编排训练集 5 执行脚本进行训练 6 需要修改文件夹名称 三、开始训练 1 执行训练命令 2 对第一次评估进行解释 3 引言 五、总…

NestJS使用模板引擎ejs

模板引擎​ 模板引擎是一种用于生成动态内容的工具&#xff0c;它通过将预定义的模板与特定数据结合&#xff0c;来生成最终的输出。​ 在NodeJS开发中&#xff0c;我们会使用模板引擎来渲染一些常用的页面&#xff0c;比如渲染代表404的Not Found 页面&#xff0c;502的Bad …

【【C语言简单小题学习-1】】

实现九九乘法表 // 输出乘法口诀表 int main() {int i 0;int j 0;for (i 1; i < 9; i){for (j 1; j < i;j)printf("%d*%d%d ", i , j, i*j);printf("\n"); }return 0; }猜数字的游戏设计 #define _CRT_SECURE_NO_WARNINGS 1 #include<stdi…

源码视角,vue3为什么推荐用ref,而不是reactive

ref 和 reactive 是 Vue3 中实现响应式数据的核心 API。ref 用于包装基本数据类型&#xff0c;而 reactive 用于处理对象和数组。尽管 reactive 似乎更适合处理对象&#xff0c;但 Vue3 官方文档更推荐使用 ref。 我的想法&#xff0c;ref就是比reactive好用&#xff0c;官方也…

Java 中对包含关系的判断

本文将为您详细讲解 Java 中对包含关系的判断&#xff0c;包括数组、字符串等&#xff0c;并提供相应的代码例子。 1. 数组包含关系判断 在 Java 中&#xff0c;数组包含关系判断通常使用循环来实现。以下是几种常见的判断方法&#xff1a; 示例 1&#xff1a;使用 for…

Unity曲柄滑块四杆机构运动计算

一、运动效果 二、机构的介绍 曲柄长度&#xff1a;a&#xff0c;线段AB长度 连杆长度&#xff1a;b&#xff0c;线段BC长度 偏心距离&#xff1a;e&#xff0c;滑块轨迹与曲柄中心点A的垂直距离 三、已知点A点B和e的值&#xff0c;计算C点的位置 1、计算s的值 var h math.…

通过多进程并发方式(fork)实现服务器(注意要回收子进程)

以下内容为视频学习记录。 1、父进程accept后返回的文件描述符为cfd以及用于创建连接的lfd; 调用fork()创建子进程后&#xff0c;子进程继承cfd,lfd&#xff0c;通过该cfd与连接过来的客户端通信,lfd对子进程来说没用&#xff0c;可以直接close(lfd); 对于父进程来说&#x…

Vue中的计算属性和方法有什么区别?

Vue.js是一款流行的JavaScript前端框架&#xff0c;提供了丰富的功能和便捷的开发方式。在Vue中&#xff0c;计算属性和方法是常用的两种方式来处理数据和逻辑。但它们之间存在一些区别&#xff0c;本文将详细介绍Vue中计算属性和方法的区别&#xff0c;并通过示例代码加深理解…

183896-00-6,Biotin-C3-PEG3-C3-NH2,可以选择性降解靶蛋白

您好&#xff0c;欢迎来到新研之家 文章关键词&#xff1a;183896-00-6&#xff0c;Biotin-C3-PEG3-C3-NH2&#xff0c;Biotin-C3-PEG3-C3-amine&#xff0c;生物素-C3-PEG3-C3-胺 一、基本信息 【产品简介】&#xff1a;Biotin-PEG3-C3-NH2是一种PROTAC linker&#xff0c;…

Python推导式大全与实战:精通列表、字典、集合和生成器推导式【第115篇—python:推导式】

Python推导式大全与实战&#xff1a;精通列表、字典、集合和生成器推导式 Python语言以其简洁、优雅的语法而闻名&#xff0c;其中推导式是其独特之处之一。推导式是一种在一行代码中构建数据结构的强大方式&#xff0c;它涵盖了列表、字典、集合和生成器。本篇博客将全面介绍…

YOLOv8实例分割实战:ONNX模型转换及TensorRT部署

课程链接&#xff1a;https://edu.csdn.net/course/detail/39320 PyTorch版的YOLOv8支持高性能的实时实例分割。 TensorRT是针对英伟达GPU的加速工具。 ONNX &#xff08;Open Neural Network Exchange&#xff09; 作为一个开放的网络模型中间表示&#xff08;IR&#xff0…

spring boot 修复 Spring Framework URL解析不当漏洞(CVE-2024-22243)

漏洞描述 当应用程序使用UriComponentsBuilder来解析外部提供的URL&#xff08;如通过查询参数&#xff09;并对解析的URL的主机执行验证检查时可能容易受到Open重定向攻击和SSRF攻击&#xff0c;导致网络钓鱼和内部网络探测等。 受影响产品或系统 6.1.0 < Spring Framew…