今天是刘小爱自学Java的第134天。

感谢你的观看,谢谢你。

image

学习内容安排如下:

  • SpringCloud的接触。

  • 利用SpringCloud搭建微服务架构,当然这个估计要3天时间才能完成,今天主要是注册中心Eureka的学习。

一、SpringCloud

微服务是一种系统架构方式,最终肯定需要技术架构去实施,我们使用的就是SpringCloud了,不用多说,看名称都知道又是Spring旗下的一个项目。

所以对于Java开发来说,spring真是个绕不开的坎,哪里都有它。

image

其主要涉及的组件包括,Netflix:

  • Eureka:注册中心

  • Zuul:服务网关

  • Ribbon:负载均衡

  • Feign:服务调用

  • Hystix:熔断器

这几天依次学习这些知识点。

二、Eureka:注册中心

顾名思义,注册中心的作用在于服务的管理,记录服务提供者的信息。

1Eureka服务端

所有的服务都要在Eureka服务端上注册,那如何让一个SpringBoot应用成为Eureka服务端呢?

image

①引入eureka服务端依赖

这个依赖非常长,记2个核心点:

  • starter启动器的意思.

  • erueka-server对应erueka的服务端,有服务端肯定也会有客户端。

②启动类开启eureka服务

@EnableEurekaServer,看这个注解的意思就能知道是开始前eureka服务。

也就是说该SpringBoot引用被作为了euerka服务端,也就是前面说的管理服务的注册中心。

image

③配置注册中心地址

这里就是指它自己,这是什么意思呢?

eureka服务端是专门用来管理服务的,所有的服务都要在它这个注册,而它本身也是一个服务,所以需要自己注册自己。

④给服务命名

这个也好理解,application翻译是应用,在这里也就是一个服务,给它命名为eureka-server。

2Eureka客户端:服务的注册

比如user-service这个服务是用来查询和user相关数据的,将该服务注册,让其它服务都可以直接调用它。

image

①引入eureka客户端依赖

一样的,2个核心点:

  • starter启动器的意思。

  • erueka-client对应erueka的客户端。

②启动类开启eureka客户端

@EnableEurekaClient,同理确实也是有这个注册的,开启eureka客户端。

不过这里使用@EnableDiscoveryClient,它功能要更加地强大。

3Eureka客户端:服务的发现

上述服务注册了,那另外的服务要直接使用它,就称之为服务的发现。

既然是服务,肯定也需要先完成注册,一样的步骤:导入依赖,启动类上添加客户端注解。

image

DiscoverClient:也就是启动类上注解配置的客户端。

RestTemplate:这个昨天详细学习过,通过它可是实现服务之间的调用。

①拉取服务

通过discoverClient的getInstances()方法可以拉取指定的服务。

②负载均衡

利用负载均衡获取其中的一个服务,因为我们这里总共就只有一个服务,所以不需要利用负载均衡。

这个文章结尾会详细讲述到。

③字符串占位符

通过restTemplate的getForObject()方法可以向指定的url发起get请求。

通过String的format()方法实现拼接,将后面的ip,端口和id拼接到%s这个占位符中。

4服务的调用测试

上述配置完成后,就可以通过consumer-demo这个服务,调用user-service这个服务了。

image

根据id去数据库查询对应的用户,我们只在user-service服务中实现了service层和dao层的代码编写。

如果在consumer服务中要用,直接调用user-service服务即可。

三、Eureka详解

Eureka架构中的三个核心角色:

image

①服务注册中心

Eureka的服务端应用,提供服务注册和发现功能,也就是上述的eureka-server。

②服务提供者

提供服务的应用,可以是SpringBoot应用,也可以是其它任意技术实现,只要对外提供的是Rest风格服务即可。

也就是上述实现的user-service。

③服务消费者

消费应用从注册中心获取服务列表,从而得知每个服务方的信息,知道去哪里调用服务方,也就是我们实现的consumer-demo。

2服务续约

image

lease-renewal-interval-in-seconds

服务续约的间隔,默认为30秒,renewal本身就是续约的意思。

lease-expiration-duration-in-seconds

服务失效时间,默认值90秒,expiration本身就是终结的意思

也就是说,默认情况下每个30秒服务会向注册中心发送一次心跳,证明自己还活着。

如果超过90秒没有发送心跳,EurekaServer就会认为该服务GG了,会从服务列表中移除。

这两个值在生产环境不要修改,默认即可。

3负载均衡Ribbon

在刚才的案例中,我们启动了一个user-service,通过DiscoveryClient来获取服务实例信息,获取ip和端口来访问。

但是实际环境中,往往会开启很多个user-service。

此时我们获取的服务列表中就会有多个,到底该访问哪一个呢?

Eureka中已经帮我们集成了负载均衡组件:Ribbon,简单修改代码即可使用。

image

①开启负载均衡

通过@LoadBanlanced注解即可开启负载均衡。

开启之后,就可以直接使用了。

image

②url编写

开启负载均衡,url中的ip和端口直接使用服务的名称使用即可。

最后

谢谢你的观看。

如果可以的话,麻烦帮忙点个赞,谢谢你。



喜欢的朋友记得点赞、收藏、关注哦!!!

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

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

相关文章

三次贝塞尔曲线,二次贝塞尔曲线有什么区别

三次贝塞尔曲线和二次贝塞尔曲线在控制点数量、数学表达式和曲线复杂度上有所不同。以下是它们的主要区别: 1. 控制点数量 二次贝塞尔曲线:由3 个点定义(起点、终点和 1 个控制点)。三次贝塞尔曲线:由4 个点定义&…

springboot集成dubbo

BeanDefinitionRegistryPostProcessor public interface BeanDefinitionRegistryPostProcessor extends BeanFactoryPostProcessor {/*** 允许开发者在Spring容器加载Bean定义(BeanDefinition)后,实例化Bean之前,动态修改或注册新的BeanDefinition* 该接…

Seata 全面深入学习指南

Seata 全面深入学习指南 学习目录 第一部分:Seata 基础篇 分布式事务基础概念Seata 概述与核心架构Seata 部署与快速入门第二部分:Seata 核心机制 Seata 事务模式详解 AT 模式TCC 模式SAGA 模式XA 模式Seata 事务协调机制Seata 高可用设计第三部分:Seata 高级特性 Seata 配…

【Linux】基于策略模式的简单日志设计

📝前言: 这篇文章我们来讲讲Linux——基于策略模式的简单日志设计 🎬个人简介:努力学习ing 📋个人专栏:Linux 🎀CSDN主页 愚润求学 🌄其他专栏:C学习笔记,C语…

C#引用传递代码记录

using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Threading.Tasks;namespace 值传递和引用传递 {internal class Program{static void Main(string[] args){person P1new person();P1.name "张三";person P2 …

React动态渲染:如何用map循环渲染一个列表(List)

React动态渲染:如何用map循环渲染一个列表(List)? 系列回顾: 在上一篇中,我们学习了如何通过onClick等事件处理,让React应用响应用户的操作。现在我们的组件已经能“听懂话”了。但是,目前为止我们展示的内…

React Native【实战范例】水平滚动分类 FlatList

import React from "react"; import { FlatList, SafeAreaView, StyleSheet, Text, View } from "react-native"; interface itemType {id: string;title: string;icon: string; } // 水平滚动数据 const horizontalData: itemType[] [{ id: "1"…

iOS swiftUI的实用举例

SwiftUI 是 Apple 推出的声明式 UI 框架,以下是一些实用技巧和最佳实践,可以帮助你更高效地开发 iOS/macOS/watchOS/tvOS 应用。 1. 布局技巧 灵活的空间占用 // 使用 Spacer 填充可用空间 HStack {Text("Left")Spacer() // 填充中间空间 …

SpringMVC异步处理Servlet

使用SpringMVC异步处理Servlet解决的问题 可以不阻塞有限的tomcat 线程(默认是200~250个,springboot3是200个),确保网络请求可以持续响应特定业务使用自定义线程池,可以处理的业务量更大对上层业务完全无感知&#xf…

同步与异步编程范式全景研究——从CPU时钟周期到云原生架构的范式演进

第一章 时空观的根本分歧 1.1 物理时间的约束性 同步操作的本质是对牛顿绝对时间的服从,其阻塞特性源于冯诺依曼体系下指令顺序执行的基因。现代CPU的流水线技术(如Intel Hyper-Threading)通过指令级并行实现伪异步,但开发者仍需…

【零散技术】5分钟完成Odoo18 登陆页面全自定义

序言:时间是我们最宝贵的财富,珍惜手上的每个时分 从最初的tinyERP到Open ERP,再由OpenERP到Odoo,虽然UI已经过了多次大改,Odoo登录界面依旧丑陋,同时还有各种Odoo版权信息,对于定制项目而言是不友好的。 今天以Odoo18…

Vue3 + TypeScript + Element Plus + el-pagination 分页查询实例分享

前端技术栈&#xff1a;Vue3 TypeScript Element Plus el-pagination 后端技术栈&#xff1a;Java Spring Boot Mybatis 应用异常情况说明&#xff1a;点击页码2&#xff0c;会发送两次请求&#xff0c;并且自动跳回页码1 代码&#xff1a; Reagent.vue <script set…

LoadRunner 2023 安装部署

下载地址&#xff1a;链接: https://caiyun.139.com/w/i/2nQQRYCZ1Ssjl 提取码:3gz0 复制内容打开139-云盘 主要下载Micro_Focus_LoadRunner_2023_Community_Edition.exe来安装就可以。 如要汉化&#xff0c;则再下载安装Language_Packs.exe的安装包 说明&#xff1a;LoadR…

ABC410 : F - Balanced Rectangles

https://atcoder.jp/contests/abc410/tasks/abc410_fhttps://atcoder.jp/contests/abc410/tasks/abc410_f首先可以一眼看出暴力 &#xff1a;枚举左上角和右下角&#xff0c;用前缀和算出矩形中#的数量&#xff0c;判断即可 但这样是,爆!!! 考虑优化&#xff0c;我们可以枚举…

嵌入式学习笔记 - HAL库对外设的封装

一 外设封装结构 HAL库对外设的封装使用了xx_HandleTypeDef类型的外设句柄结构体&#xff0c;这个句柄结构体的第一个成员Instance(xx_TypeDef类型)一般为该外设的所有寄存器的起始基地址&#xff0c;第二个成员Init&#xff08;xx_InitTypeDef类型&#xff09;一般为该外设的设…

高精度模板

加法 P1601 AB Problem&#xff08;高精&#xff09; #include<iostream>using namespace std; const int N 1e6 10; int a[N],b[N],c[N]; int len1,len2,lenMax; //长度要提前定义在全局&#xff0c;在函数中要使用 void add(int c[],int a[],int b[]) {for(int i0…

monorepo使用指北

|  WARN  node_modules is present. Lockfile only installation will make it out-of-date  ERR_PNPM_FETCH_404  GET https://registry.npmjs.org/common%2Fcommon: Not Found - 404 This error happened while installing a direct dependency of G:\monorepo\vue3 comm…

Java八股文——Spring「MyBatis篇」

与传统的JDBC相比&#xff0c;MyBatis的优点&#xff1f; 面试官您好&#xff0c;MyBatis相比于传统的JDBC&#xff0c;它并不是要完全颠覆JDBC&#xff0c;而是作为JDBC的一个强大的“增强框架”。它的核心价值在于&#xff0c;在保留了SQL最大灵活性的前提下&#xff0c;极大…

JavaScript基础-常用的鼠标事件

一、前言 在前端开发中&#xff0c;鼠标事件 是实现用户交互的重要手段之一。通过监听用户的点击、移动、悬停等操作&#xff0c;我们可以构建出丰富而灵活的网页交互体验。 本文将带你深入了解&#xff1a; JavaScript 中常见的鼠标事件&#xff1b;各类鼠标事件的触发时机…

windows录频软件

一.很反感有些做软件的&#xff0c;把别人开源的改个界面收费&#xff0c;所以我找了一个开源免费的。 二.准备工具 一台电脑&#xff0c; Captura:完全开源免费的录频软件。 ffmpeg&#xff1a;音频格式转换软件&#xff0c;这可是非常大名鼎鼎的工具。 三.安装Captura 网址…