当前位置: 首页 > news >正文

微服务1--服务架构

系统架构

单体应用架构

  • 特点:所有功能集中在一个应用中(如传统的 Spring Boot WAR 包)。

  • 适用场景:小型项目、快速验证阶段。

  • 优缺点

    • ✅ 开发简单,部署方便。

    • ❌ 扩展性差,技术栈耦合。

集群应用架构

  • 实现:

    • 无状态服务水平扩展

      • 通过负载均衡(Nginx/LVS)将流量分发到多个单体实例。

      • Session共享:Redis存储用户会话。

    • 数据库主从分离

      • 主库写,从库读(MySQL Replication)。

  • 优缺点

    • ✅ 提高并发能力,避免应用层单点故障

    • ❌ 代码仍为单体,维护复杂,数据主库压力大

 垂直应用架构

演进动机

  • 解决集群架构中业务耦合问题,按功能拆分独立应用。

实现方式

  • 垂直拆分:将单体按业务线拆分为多个独立应用(如电商拆分为用户中心、订单系统、商品系统)。

  • 每个应用有自己的数据库,避免全表扫描压力。

优缺点 

  • ✅ 业务解耦,数据库压力分散

  • ❌ 重复构建,跨系统调用复杂

微服务架构 

微服务架构是服务化思想的最佳时间方向和服务治理不断完善和交付链路逐步成熟后的自然产物。

微服务 

概念名词

服务治理

服务治理就是进行服务的自动化管理,其核心是服务的自动注册与发现。 

        服务注册:服务实例将自身服务信息注册到注册中心。 

        服务发现:服务实例通过注册中心获取到其中的服务实例的信息,通过这些信息去请求他们提供服务。

        服务剔除:服务注册中心将出问题的服务自动剔除到可用列表之外,使其不会被调用到。

服务调用

服务调用是指一个软件系统通过某种通信协议请求另一个软件系统提供特定服务的过程。

目前主流的远程调用技术有基于 HTTP 的 RESTful 接口以及基于 TCP 的 RPC协议。

服务网关

随着微服务的不断增多,不同的微服务一般会有不同的网络地址,外部客户端可能需要调用多个服务接口才能完成一个业务需求,如果让客户端直接与各个服务之间进行通信就会出现一系列的问题(跨域,认证)。

网关是一种在微服务架构中使用的服务器端组件,用于管理请求的转发和路由。API网关将API调用统一接入API网关层,由网关层统一接入和输出。

一个网关的基本功能有:统一接入、安全防护、协议适配、流量管控、长短链接支持、容错能力。

服务容错

服务容错是确保系统在部分服务出现故障时仍能继续运行的能力。

在微服务当中,一个请求经常会涉及到调用几个服务,如果其中某个服务不可用,没有做服务容错 的话,极有可能会造成一连串的服务不可用,这就是雪崩效应。 我们没法预防雪崩效应的发生,只能尽可能去做好容错。

链路追踪

随着微服务架构的流行,服务按照不同的维度进行拆分,一次请求往往需要涉及到多个服务。互联 网应用构建在不同的软件模块集上,这些软件模块,有可能是由不同的团队开发、可能使用不同的编程 语言来实现、有可能布在了几 千台服务器,横跨多个不同的数据中心。因此,就需要 对一次请求涉及的 多个服务链路进行日志记录,性能监控即链路追踪.

微服务调用

以商城系统为例:客户想订单服务发起一个下订单请求,这时在保存订单之前就需要先调用商品服务查询商品信息。
一般把服务的主动调用方称为服务消费者,把服务的被调用方称为服务提供者。

在这种情况下,订单订单微服务就是一个服务消费者, 商品微服务就是一个服务提供者。

实现方式

使用 RestTemplate 使用 http 方式远程访问
这种方式存在诸多问题:
1.一旦服务提供者地址变化,就要手动修改代码
2.如果是多个服务提供者,无法实现负载均衡
3.服务过多,人工维护调用关系困难且成本巨大。
@RestController
@RequestMapping("/order")
public class OrderController{@AutowiredOrderService orderService;@AutowiredRestTemplate restTemplate;@RequestMapping("/create/{pid}/{uid}/{num}")public Order createOrder(@PathVariable("pid") int pid, @PathVariable("uid")int uid, @PathVariable("num") int num){//核心代码Product p = restTemplate.getForObject("http://127.0.0.1:8091/product/get/"+pid, Product.class);User u = restTemplate.getForObject("http://127.0.0.1:8081/user/get/"+uid, User.class);Order order= null;if(p!=null){if(p.getStock()>=num){if(u!=null){order = orderService.saveorder(pid,uid,num);}}}return order;}
}

相关文章:

微服务1--服务架构

系统架构 单体应用架构 特点:所有功能集中在一个应用中(如传统的 Spring Boot WAR 包)。 适用场景:小型项目、快速验证阶段。 优缺点: ✅ 开发简单,部署方便。 ❌ 扩展性差,技术栈耦合。 …...

鸿蒙应用元服务开发-Account Kit配置登录权限

一、场景介绍 华为账号登录是基于OAuth 2.0协议标准和OpenID Connect协议标准构建的OAuth2.0 授权登录系统,元服务可以方便地获取华为账号用户的身份标识,快速建立元服务内的用户体系。 用户打开元服务时,不需要用户点击登录/注册按钮&#…...

zg-docker详解与部署微服务实战与k8s

一. Docker课程 Docker简介 Docker是一个开源的容器引擎,有助于快速开发,docker更快地打包、测试以及部署应用程序,并可以缩短从编写到部署运行代码的周期。 使用宿主机的网络:即使用宿主机的网段。 联合文件系统-一个镜像,启动了多个容器,对于镜像中的文件a,多个容器…...

【含文档+PPT+源码】基于Python的快递服务管理系统【

毕业作品基于Django和HTML的快递网站设计与实现 课程目标: 教你从零开始部署运行项目,学习环境搭建、项目导入及部署,含项目源码、文档、数据库、软件等资料 课程简介: 本课程演示的是一款基于Python的快递服务管理系统&#x…...

嵌入式WebRTC轻量化SDK压缩至500K-800K ,为嵌入式设备节省Flash资源

一、SDK轻量化的核心技术实现 1、WebRTC库裁剪与模块化设计 EasyRTC针对嵌入式设备的资源限制,对原生WebRTC库进行深度裁剪,仅保留核心通信功能(如信令管理、编解码、网络传输等),移除冗余组件(如部分调试…...

JAVA学习-Stream

Stream Stream也叫Stream流,是Jdk8开始新增的一套API (java.util.stream.*),可以用于操作集合或者数 组的数据。 优势: Stream流大量的结合了Lambda的语法风格来编程,提供了一种更加强大,更加简单的方式 操作集合或者数…...

如何在同一个电脑配置多个jdk版本并随意切换

1.右键此电脑属性 2.点击高级系统配置 3.点击环境变量 4.进去后点击新建 变量名:JAVA_HOME_版本,来进行命名 变量值:jdk的路径即可,比如我的是D:\JAVA\JAVA11 5.创建完你所有的jdk版本之后接着新建 变量名:JAVA_HOME…...

网工_传输层协议概述

2025.02.19:网工老姜&小猿网学习笔记 第22节 传输层协议概述 2.1 进程之间的通信2.2 传输层的两个主要协议2.3 传输层的端口2.3.1 端口号 2.4 本章小结 2.1 进程之间的通信 前三层解决了数据从主机到主机的问题,也就是,我们现在已经可以把…...

《java面试宝典》之java多线程面试题

1:什么是线程? 轻量级的进程 2:线程的三个部分是? 处理机 代码 数据 3:为什么使用多线程 使UI响应更快 利用多处理器系统 简化建模 4:代码示例:Java中实现多线程的两种方式,包括如何…...

5款电脑健康状况监测软件

鲁大师:专业且免费,能检测电脑硬件配置,辨别硬件真伪,检查电脑病毒隐患。可一键清理系统垃圾,提升电脑性能。还能全程监护硬件状态,实时检测硬件温度变化,让用户轻松掌握电脑健康状况。360 安全…...

JWT令牌:实现安全会话跟踪与登录认证的利器

摘要:本文深入探讨了JWT令牌在实现会话跟踪和登录认证方面的应用,详细介绍了JWT令牌的概念、组成、生成与校验方法,以及在实际案例中如何通过JWT令牌进行会话跟踪和登录认证的具体实现步骤,为系统的安全认证机制提供了全面且深入的…...

uni-app/微信小程序接入腾讯位置服务地图选点插件

uni-app/微信小程序接入腾讯位置服务地图选点插件 0、常出现的错误及解决方法0.1插件未授权使用(见步骤1)0.2小程序类目不符合引用该类目插件的要求或主体类型不符合要求(见步骤1)0.3需要在app.json中声明permission scope.userLo…...

3款顶流云电脑与传统电脑性能PK战:START云游戏/无影云/ToDesk云电脑谁更流畅?

这里写目录标题 一、前言二、本地机器配置环境三、START云游戏/无影云/ToDesk云电脑配置对比3.1 START云游戏3.2 无影云个人版3.3 ToDesk云电脑 四、本地电脑与云电脑性能实战4.1 游戏场景体验4.1.1 本地电脑测试4.1.2 云电脑测试英雄联盟黑神话悟空其他游戏 4.2 主流设计场景体…...

WINUI——Background小结

在 ​​WinUI/UWP XAML​​ 中,Background(或其他颜色属性)支持 ​​多种颜色表示方式​​,包括以下三种主流格式: ​​1. RGB 十六进制(不透明)​​ ​​格式​​:#RRGGBB​​特点…...

公司内部自建知识共享的方式分类、详细步骤及表格总结,分为开源(对外公开)和闭源(仅限内部),以及公共(全员可访问)和内部(特定团队/项目组)四个维度

以下是公司内部自建知识共享的方式分类、详细步骤及表格总结,分为开源(对外公开)和闭源(仅限内部),以及公共(全员可访问)和内部(特定团队/项目组)四个维度&am…...

cursor AI编辑器的详细使用

以下是Cursor AI编辑器的详细使用介绍,涵盖核心功能、安装配置、使用技巧、高级应用及常见问题解决方案,结合了多个权威来源的实践指南和最新技术动态: 一、Cursor AI简介与核心功能 定位与架构 Cursor是基于Visual Studio Code(V…...

js逆向入门实战某某观察网响应数据解密

(base64解码 base64解码)地址:aHR0cHM6Ly93d3cuc3dndWFuY2hhLmNvbS9ob21lL2NpdHktZGV0YWlsP2NvZGU9MzEwMTAw 分析过程 1.抓数据包,发现响应数据是加密字符串。 ​ 2.对于这种回显数据解密,大概率通过拦截器实现,搜索intercepto…...

Ubuntu安装yum遇到Package ‘yum‘ has no installation candidate

环境说明 Window11,WSL2,Ubuntu24.04 错误描述 rootLAPTOP:~# apt-get install yum Reading package lists... Done Building dependency tree... Done Reading state information... Done Package yum is not available, but is referred to by anot…...

爱普生SG3225EEN低抖动差分晶振在网络通信的应用

在当今数字化时代,网络通信的飞速发展对数据传输的准确性、稳定性和高效性提出了极为严苛的要求。从 5G 通信网络的大规模部署,到数据中心的海量数据交换,再到智能家居系统的互联互通,每一个环节都离不开精准稳定的时钟信号作为支…...

软考教材重点内容 信息安全工程师 第22章 网站安全需求分析与安全保护工程

22.1.1 网站安全概念 网站是一个基于 B/S 技术架构的综合信息服务平台,主要提供网页信息及业务后台对外接口服务。一般网站涉及网络通信、操作系统、数据库、Web 服务器软件、Web 应用、浏览器、域名服务以及 HTML, XML,SSL; Web Services 等相关协议,同…...

数智读书笔记系列029 《代数大脑:揭秘智能背后的逻辑》

《代数大脑:揭秘智能背后的逻辑》书籍简介 作者简介 加里F. 马库斯(Gary F. Marcus)是纽约大学心理学荣休教授、人工智能企业家,曾创立Geometric Intelligence(后被Uber收购)和Robust.AI公司。他在神经科学、语言学和人工智能领域发表了大量论文,并著有《重启AI》等多部…...

UWB技术与5G、物联网结合的应用前景

‌ 一、核心应用场景与优势‌ ‌工业自动化与智能制造‌ ‌高精度设备协同‌:UWB技术(3cm定位精度)与5G(1ms级时延)结合,可实时追踪AGV、机械臂等设备位置,优化生产节拍,提升效率20…...

vue + element-plus自定义表单验证(修改密码业务)

写一个vue组件Password.vue 没有表单验证只有3个表单项 <template><div><el-form><el-form-item label"旧密码"><el-input></el-input></el-form-item><el-form-item label"新密码"><el-input>&l…...

如何将 Vue-FastAPI-Admin 项目的数据库从 SQLite 切换到 MySQL?

近期在github上看到一个开源项目&#xff0c;vue-fastapi-admin。它基于 FastAPI Vue3 Naive UI 的现代化前后端分离开发平台&#xff0c;融合了 RBAC 权限管理、动态路由和 JWT 鉴权&#xff0c;助力中小型应用快速搭建&#xff0c;也可用于学习参考。 由于该项目中数据库用…...

K8S运维实战之集群证书升级与容器运行时更换全记录

第一部分&#xff1a;Kubernetes集群证书升级实战 tips:此博文只演示一个节点作为示范&#xff0c;所有的集群节点步骤都可以参考。 项目背景 某金融业务系统Kubernetes集群即将面临生产证书集中过期风险&#xff08;核心组件证书剩余有效期不足90天&#xff09;&#xff0c…...

idea如何克隆拉取远程git项目到本地

概述 idea如何克隆拉取远程git项目到本地&#xff1f;方法很简单&#xff0c;找到入口&#xff0c;跟着引导窗口下一步下一步即可。 方法 File -> New -> Project from Version Control...然后根据引导窗口&#xff0c;一步一步操作即可...

聚铭网络亮相2025超云产品技术大会,联合发布“铭智安全运营大模型一体机及解决方案”

4月11日&#xff0c;于南京银城皇冠假日酒店举办的2025超云产品技术大会圆满落幕。聚铭网络受邀出席本次大会&#xff0c;并与超云联合发布了“铭智安全运营大模型一体机及解决方案”&#xff0c;为智能安全运营领域带来了全新突破。 会议背景 在全球人工智能技术加速产业化…...

成员访问运算符重载(详解)

目录 成员访问运算符 两层结构下的使用 三层结构下的使用&#xff08;难点&#xff09; 内存分析 成员访问运算符 成员访问运算符包括箭头访问运算符 -> 和解引用运算符 * &#xff0c;它们是指针操作最常用的两个运算符。我们先来看箭头运算符 -> 箭头运算符只能以…...

无感改造,完美监控:Docker 多阶段构建 Go 应用无侵入观测

作者&#xff1a;牧思 背景 随着云原生的普及&#xff0c;Golang 编程语言变得越来越热门。相比 Java&#xff0c;Golang 凭借其轻量&#xff0c;易学习的特点得到了越来越多工程师的青睐&#xff0c;然而由于 Golang 应用需要被编译成二进制文件再进行运行&#xff0c;Golan…...

项目后期发现重大漏洞,如何紧急修复

项目后期发现重大漏洞的紧急修复关键在于&#xff1a; 迅速识别漏洞根本原因、制定修复优先级、协调团队资源、实施快速修复和验证、总结经验防止重复发生。 其中&#xff0c;迅速识别漏洞根本原因是最为关键的一步。找到漏洞的根本原因有助于确保修复措施不仅解决眼前的问题&a…...

设计模式:状态模式 - 复杂状态切换的优雅之道

一、为什么用状态模式&#xff1f; 在开发过程中&#xff0c;你是否遇到过这样的难题&#xff1a;对象需要根据不同的状态执行不同行为&#xff0c;但代码中却充斥着大量的if-else或switch-case语句&#xff1f; 随着状态的增多&#xff0c;代码变得臃肿且难以阅读&#xff0…...

【AI提示词】业务开发经理

提示说明 业务开发经理旨在帮助用户构建一个高效、有洞察力的业务发展角色&#xff0c;能够在竞争激烈的市场中寻找并抓住商机。 提示词 # 角色 业务开发经理专家## 注意 - 业务开发经理应具备强烈的市场洞察力和人际沟通能力。 - 专家设计应考虑业务发展的实际需求和挑战。…...

发电机参数详解

一、发电机参数体系概述 发电机作为将机械能转换为电能的核心设备,其参数体系涵盖电气、机械、结构、性能、控制五大维度,是设备选型、运行维护、故障诊断的重要依据。参数体系的完整性和准确性直接影响电力系统的稳定性与经济性。以下通过思维导图展示发电机参数的整体架构…...

每天五分钟深度学习PyTorch:RNN CELL模型原理以及搭建

本文重点 RNN Cell(循环神经网络单元)是循环神经网络(RNN)的核心组成部分,用于处理序列数据中的每个时间步,并维护隐藏状态以捕获序列中的时间依赖关系。 RNN CELL的结构 RNN是一个循环结构,它可以看作是RNN CELL的循环,RNN CELL的结构如下图所示,RNN CELL不断进行…...

设计和实现一个基于 DDS(直接数字频率合成) 的波形发生器

设计和实现一个基于 DDS&#xff08;直接数字频率合成&#xff09; 的波形发生器 1. 学习和理解IP软核和DDS 关于 IP 核的使用方法 IP 核&#xff1a;在 FPGA 设计中&#xff0c;IP 核&#xff08;Intellectual Property Core&#xff09;是由硬件描述语言&#xff08;HDL&a…...

RCEP框架下eBay日本站选品战略重构:五维解析关税红利机遇

2024年RCEP深化实施背景下&#xff0c;亚太跨境电商生态迎来结构性变革。作为协定核心成员的日本市场&#xff0c;其跨境电商平台正经历新一轮价值重构。本文将聚焦eBay日本站&#xff0c;从政策解读到实操路径&#xff0c;系统拆解跨境卖家的战略机遇。 一、关税递减机制下的…...

使用 Node.js、Express 和 React 构建强大的 API

了解如何使用 Node.js、Express 和 React 创建一个强大且动态的 API。这个综合指南将引导你从设置开发环境开始&#xff0c;到集成 React 前端&#xff0c;并利用 APIPost 进行高效的 API 测试。无论你是初学者还是经验丰富的开发者&#xff0c;这篇文章都适合你。 今天&#…...

如何争取高层对项目的支持

争取高层对项目的支持关键在于明确项目的战略价值、展示其可行性与回报、以及有效的沟通和利益对接。高层管理者通常关注的是项目如何帮助公司实现整体战略目标&#xff0c;如何提高企业的竞争力或收益。在争取支持的过程中&#xff0c;项目经理需要清楚地表达项目的潜在价值&a…...

git合并分支原理

Git合并的原理是基于三方合并&#xff08;three-way merge&#xff09;算法&#xff0c;它通过比较三个快照来合并不同分支上的更改。这三个快照包括两个要合并的分支的最新提交和它们的共同祖先提交。合并过程并不是简单地按照提交时间来进行&#xff0c;而是通过比较这些快照…...

最短路问题

最短路问题 最短路问题 最短路算法&#xff08;Shortest Path Algorithm&#xff09;是用来解决图中两点之间的最短路径的问题。常见的应用包括&#xff1a;地图导航、网络路由、游戏寻路等。根据图的性质&#xff08;有向/无向、是否有负权边&#xff09;和需求&#xff08;…...

ARM Cortex汇编伪指令

在ARM架构&#xff08;尤其是Cortex-M系列MCU&#xff09;的汇编中&#xff0c;伪指令&#xff08;Pseudo-Instructions&#xff09;是由汇编器解释的特殊指令&#xff0c;用于定义数据、符号、代码结构或控制汇编过程。以下是常用的ARM汇编伪指令分类及说明&#xff1a; 一、…...

如何在vue3项目中使用 AbortController取消axios请求

在 Vue3 项目中通过 AbortController 取消 Axios 请求&#xff0c;可以通过以下 结构化步骤 实现。我们结合组合式 API&#xff08;Composition API&#xff09;和现代前端实践演示&#xff1a; 一、基础实现&#xff08;单个请求&#xff09; 1. 创建组件逻辑 <script s…...

Bright+Data网页解锁器在旅游行业的创新实践

引言 随着在线旅游平台的快速发展&#xff0c;网络爬虫技术成为获取旅游数据的重要手段。然而&#xff0c;主流旅游网站&#xff08;如去哪儿网、携程等&#xff09;普遍部署了反爬虫机制&#xff0c;包括IP封禁、验证码验证、请求频率限制等技术手段&#xff0c;严重影响了传…...

SpringMVC 执行流程

前言&#xff1a; 在前后端分离的情况下&#xff0c;SpringMVC 的执行流程主要集中在处理 RESTful 请求和返回 JSON 数据。这里的 Controller 会直接返回数据&#xff0c;而不是视图。我们通常会使用 RestController 和 RequestMapping 来处理请求&#xff0c;ResponseBody 会…...

STM32G0单片机自带RTC

STM32有个自带RTC外设&#xff0c;外接32.768KHz的晶振后可得到相对精确的计时功能。 实测了一个一小时快个1秒多。 1 cubeMX设置了RTC后自动生成的初始化代码如下 static void MX_RTC_Init(void) {/* USER CODE BEGIN RTC_Init 0 *//* USER CODE END RTC_Init 0 */RTC_TimeT…...

Linux(9)Apache

文章目录 Apache1&#xff09;概述2&#xff09;部署方案3&#xff09;yum安装Apache3.1、安装Apache3.2、启动Apache3.4、检查服务是否启动成功3.5、创建一个html页面3.6、yum安装Apache相关配置文件 4&#xff09;源码安装Apache4.1、源码编译口诀4.2、安装Apache4.2.1、获取…...

用DeepSeek AI高效制作专业PPT

在当今职场中,制作精美而有力的PPT是展示想法、汇报工作和赢得机会的关键技能。然而,许多人花费过多时间在格式调整和内容组织上,而非专注于核心信息的传达。DeepSeek AI作为新一代智能助手,能够帮助您将PPT制作效率提升300%,同时显著提高专业度。本文将详细介绍如何利用D…...

C++红黑树

目录 一、红黑树的概念 二、红黑树的定义 三、红黑树的实现 一、红黑树的概念 红黑树&#xff0c;是一种二叉搜索树&#xff0c;但在每个结点上增加一个存储位表示结点的颜色&#xff0c;可以是Red或者Black。通过对任何一条从根到叶子的路径上各个结点着色方式的限制&#…...

Day08 【基于jieba分词实现词嵌入的文本多分类】

基于jieba分词的文本多分类 目标数据准备参数配置数据处理模型构建主程序测试与评估测试结果 目标 本文基于给定的词表&#xff0c;将输入的文本基于jieba分词分割为若干个词&#xff0c;然后将词基于词表进行初步编码&#xff0c;之后经过网络层&#xff0c;输出在已知类别标…...

宝塔面板中解锁Laravel日志查看的奥秘

目录 一、前言二、Laravel 日志基础认知2.1 日志的作用2.2 Laravel 日志的默认配置 三、查找 Laravel 日志文件位置3.1 常规存储路径3.2 自定义路径查找 四、查看 Laravel 日志内容4.1 宝塔面板文件管理器查看4.2 使用命令行查看 五、常见问题及解决方法5.1 权限不足无法查看5.…...