微服务入门篇:技术栈概述,服务演变,服务拆分(远程调用)

news/2024/7/4 7:47:47 标签: 微服务, 架构, 云原生

目录

1.微服务技术栈

总览图:
在这里插入图片描述
分模块学习:
在这里插入图片描述

2.服务架构的演变

1.单体架构

将业务的所有功能集中在一个项目中开发,打成一个包部署。

①优点:
架构简单
部署成本低
②缺点:
耦合度高

2.分布式架构

根据业务功能对系统进行拆分,每个业务模块作为独立项目开发,称为一个服务。

优点:
降低服务耦合
有利于服务升级拓展

3.微服务

微服务一种经过良好架构设计的分布式架构方案,微服务架构特征:
单一职责:微服务拆分粒度更小,每一个服务都对应唯一的业务能力,做到单一职责,避免重复业务开发
面向服务:微服务对外暴露业务接口
自治:团队独立、技术独立、数据独立、部署独立
隔离性强:服务调用做好隔离、容错、降级,避免出现级联问题

3.微服务技术对比

在这里插入图片描述

4.企业需求

在这里插入图片描述

5.服务拆分

1.注意事项

1.不同微服务,不要重复开发相同业务
2.微服务数据独立,不要访问其它微服务的数据库
3.微服务可以将自己的业务暴露为接口,供其它微服务调用

2.远程调用

http请求做远程调用是与语言无关的调用,只要知道对方的ip、端口、接口路径、请求参数即可。

基于RestTemplate发起的HTTP请求实现远程调用的过程如下:

  1. 创建RestTemplate对象:首先,需要创建一个RestTemplate对象来发起HTTP请求。
    可以通过直接实例化RestTemplate类或者使用依赖注入的方式创建RestTemplate对象。
    在这里插入图片描述
  1. 构造请求URL:根据需要调用的远程API的URL,构造一个完整的请求URL。
    可以使用字符串拼接的方式构造URL,也可以使用UriComponentsBuilder类来构造URL。
  2. 设置请求头:根据需要设置一些请求头参数,例如Content-Type、Authorization等。
    可以使用RestTemplate的header()方法来设置请求头。
  3. 设置请求体:如果需要传递请求体数据,可以使用RestTemplate的postForObject()、postForEntity()等方法来设置请求体。
  4. 发送请求并获取响应:根据具体的需求,选择合适的RestTemplate方法来发送请求并获取响应。例如可以使用getForObject()、getForEntity()、postForObject()、postForEntity()等方法。
    在这里插入图片描述
  1. 处理响应数据:根据接口返回的数据类型,使用相应的方法来处理返回的响应数据。
    例如可以使用ResponseEntity类来获取响应的状态码、头部信息以及响应体数据。

需要注意的是,在使用RestTemplate发起HTTP请求时,需要确保引入了相关的依赖,例如Spring Web和Jackson等。
此外,还需考虑异常处理、超时设置、重试机制等。


http://www.niftyadmin.cn/n/5348819.html

相关文章

数据结构(绪论+算法的基本概念)

文章目录 一、绪论1.1、数据结构的基本概念1.2、数据结构三要素1.2.1、逻辑结构1.2.2、数据的运算1.2.3、物理结构(存储结构)1.2.4、数据类型和抽象数据类型 二、算法的基本概念2.1、算法的特性2.2、“好”算法的特质2.2.1、算法时间复杂度2.2.2、算法空…

react hooks 的useState:

React 的 useState Hook 是一种用于在函数组件中管理状态的机制。它可以让函数组件具有类似于类组件的状态管理能力。 useState Hook 接收一个初始值作为参数,并返回一个包含状态值和更新状态值的数组。 import { useState } from react;const [state, setState] …

5G时代下的融合CDN新风口

近年来,随着网络技术的飞速发展,互联网流量视频化的趋势日益明显,视频应用使互联网的可扩展性、可演进性、服务质量和网络安全面临诸多挑战。为克服传统IP网络在服务视频应用当中的不足,内容分发网络CDN被提出,并迅速成…

Mysql-日志介绍 日志配置

环境部署 docker run -d -p 3306:3306 --privilegedtrue -v $(pwd)/logs:/var/lib/logs -v $(pwd)/conf:/etc/mysql/conf.d -v $(pwd)/data:/var/lib/mysql -e MYSQL_ROOT_PASSWORD654321 --name mysql mysql:5.7运行指令的目录下新建好这些文件: 日志类型 日…

.NET高级面试指南专题一【委托和事件】

在C#中,委托(Delegate)和事件(Event)是两个重要的概念,它们通常用于实现事件驱动编程和回调机制。 委托定义: 委托是一个类,它定义了方法的类型,使得可以将方法当作另一个…

老旧小区火灾频发,LoRa无线系统筑牢安全防线

近日,全国各地多个老旧小区火灾事故频发,从安微合肥南二环一老旧小区居民楼起火、上海金山区一小区居民楼火灾,到1月24日江西新余市特大火灾......都造成了不同程度的人员伤亡和财产损失,令人扼腕痛惜,教训十分深刻。 …

蓝桥杯备赛 week 4 —— DP 背包问题

目录 🌈前言🌈: 📁 01背包问题 分析: dp数组求解: 优化:滚动数组: 📁 完全背包问题 📁 总结 🌈前言🌈: 这篇文章主…

SpringBoot系列之JPA实现按年月日查询

SpringBoot系列之JPA实现按年月日查询 通过例子的方式介绍Springboot集成Spring Data JPA的方法,进行实验,要先创建一个Initializer工程,如图: 选择,需要的jdk版本,maven项目 选择需要的maven配置&#x…