【从零开始学习微服务 | 第一篇】什么是微服务

目录

前言:

架构风格: 

单体架构:

分布式架构:

微服务:

总结:


前言:

        在当今快速发展的软件开发领域,构建大型应用程序已经成为一项巨大的挑战。传统的单体应用架构往往难以满足快速变化的业务需求和不断增长的用户规模。这就引出了微服务架构:一种以服务为中心的解决方案,旨在解决这些问题并提供更灵活、可扩展的应用程序设计。

 

架构风格: 

单体架构:

        在我们以前开发项目的时候,会把所有的功能都集成在一个项目中开发,比如我们之前写的苍穹外卖,我们直接在整个项目内完成了所有的功能。

【苍穹外卖】_我是一盘牛肉的博客-CSDN博客

虽然单体项目的架构简单,部署成本低。但是在大型项目中,我们把所有的功能都内聚到一个项目的时候,就会造成代码的耦合程度高。而如果我们能够把这一个个功能独立的拆分为一个项目(服务),在我其他项目需要使用的时候,直接调用这个服务不就好了?其实这就是分布式架构的思想。

分布式架构:

        分布式架构将系统的不同部分分散到多个独立的计算机节点上,并通过网络连接这些节点进行通信和协作。在分布式架构中,不同的计算节点可以执行不同的任务,彼此交互以实现共同的目标。

常见的分布式架构包括微服务架构SOA架构RPC架构等。这些架构都是基于分布式系统设计的,可以帮助开发人员更好地管理和维护分布式系统。

 

通过分布式架构的设计,我们降低了各个服务之间的耦合度,那么我们的开发人员就可以专注的负责某一个服务模块的开发。而分布式架构项目的问题也很多,例如服务拆分的粒度,各个服务之间如何联系。

也就是说,虽然分布式架构的思路是好的,但分布式架构的设计却是一个难点,如何设计出好的分布式框架呢?

微服务:

        微服务是一种经过良好架构设计的分布式架构方案。

微服务架构的特点包括:

  1. 单一职责:每个微服务只关注一个特定的业务功能,它们之间相互解耦。

  2. 分布式部署:每个微服务都可以独立部署和升级,这样可以提高系统的灵活性和可伸缩性。

  3. 弹性和容错性:由于微服务是独立运行的,当某个微服务发生故障时,不会影响整个系统的运行。

  4. 独立团队开发:每个微服务可以由一个小团队独立开发和维护,使得团队间的沟通和协作更加简单。

  5. 技术多样性:不同的微服务可以使用不同的技术栈,选择最适合的工具来实现自己的功能。

换句话来说,微服务其实就是一套设计成熟的分布式架构设计方案。 

 而这种架构方案当然需要各种技术框架来落地支持,在国内比较知名的就是Spring Cloud和Dubbo。

特性DubboSpring CloudSpring Cloud Alibaba
开发语言JavaJavaJava
服务注册与发现ZooKeeper、Nacos等Eureka、Consul、ZooKeeper等Nacos、Consul等
服务调用方式RPC(远程过程调用)REST(Representational State Transfer)REST
服务网关Zuul、Spring Cloud GatewaySpring Cloud Gateway
配置中心Spring Cloud ConfigNacos Config
负载均衡客户端负载均衡客户端负载均衡(Ribbon)、服务端负载均衡(Spring Cloud LoadBalancer)Ribbon、Spring Cloud LoadBalancer
断路器Hystrix、Resilience4jSentinel
分布式追踪Spring Cloud Sleuth、ZipkinAlibaba Cloud SLS(日志服务)
消息总线Spring Cloud BusRocketMQ
服务熔断SentinelSentinel

总的来说,Dubbo是一个RPC框架,主要用于服务之间的远程调用。Spring Cloud是基于Spring Boot的微服务框架,提供了更丰富的组件和工具,支持服务注册与发现、负载均衡、断路器、配置中心等功能。Spring Cloud Alibaba是Spring Cloud的扩展,集成了阿里巴巴的一些开源组件,如Nacos、Sentinel、RocketMQ等,用于更好地支持云原生应用开发。 

最后,让我们在介绍一下微服务的核心组件:

  1. 服务注册与发现组件:

    • 服务注册:微服务架构中,每个服务都需要向一个注册中心注册自己的地址和元数据。注册中心充当了服务的目录,用于管理和维护服务实例的注册信息。常见的服务注册组件有Eureka、Consul、ZooKeeper和Nacos。
    • 服务发现:其他服务可以通过查询注册中心来发现并调用需要的服务。服务发现组件提供了查询接口,使得服务能够动态地获取到其他服务的地址和元数据。
  2. 负载均衡组件:

    • 负载均衡:微服务架构中的服务通常会有多个实例运行,负载均衡组件用于将请求均匀地分发到这些实例上,以实现负载均衡和高可用性。常见的负载均衡组件有Ribbon、Spring Cloud LoadBalancer和Nginx。
  3. 网关组件:

    • API网关:网关作为微服务架构对外暴露的入口,负责接收和处理外部请求。它可以处理身份验证、权限控制、流量管理、协议转换等功能,并将请求转发到后端的微服务实例。常见的网关组件有Zuul、Spring Cloud Gateway和Nginx。
  4. 配置中心组件:

    • 集中化配置管理:微服务应用中的配置信息通常是分散在各个服务实例中的,配置中心的作用是集中管理这些配置信息。配置中心组件提供了统一的配置管理接口,能够动态地推送配置变更给各个服务实例。常见的配置中心组件有Spring Cloud Config和Nacos Config。
  5. 消息队列组件:

    • 异步通信与解耦:在微服务架构中,服务之间需要进行异步通信,以实现解耦、削峰填谷等目标。消息队列组件提供了可靠的消息传递机制,服务可以将消息发送到消息队列,其他服务可以监听并消费这些消息。常见的消息队列组件有Kafka、RocketMQ和RabbitMQ。
  6. 分布式追踪组件:

    • 监控和调试:微服务架构中的调用链涉及多个服务实例,因此需要一个分布式追踪系统来监控和调试整个调用链。分布式追踪组件能够跟踪请求的流转路径,收集和展示调用链的性能指标和日志。常见的分布式追踪组件有Zipkin、SkyWalking和Jaeger。

由此我们可以看出,学习微服务实际上就是学习构成微服务的各个组件。

总结:

        当今软件开发领域中,微服务架构已成为最受欢迎的设计风格之一。它将应用程序拆分成独立的、可组合的服务单元,通过轻量级通信协议进行交互,从而实现可扩展性、弹性和灵活性等优势。在本文中,我们探讨了微服务架构的基本概念、原则和实践,并介绍了其核心组件,包括服务注册与发现、负载均衡、网关、配置中心、消息队列和分布式追踪等。这些组件共同协作,使得微服务架构具备高可用性、可扩展性和容错性等特性。总之,微服务架构是一种适用于大规模、复杂应用程序的优秀设计风格,值得开发人员深入学习和应用。

如果我的内容对你有帮助,请点赞,评论,收藏。创作不易,大家的支持就是我坚持下去的动力!

 

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

Shiro框架:Shiro内置过滤器源码解析

目录 1. 常见项目中过滤器配置 2.Url访问控制配置解析为内置过滤器 2.1 DefaultFilterChainManager构造并注册内置过滤器 2.2 构造过滤器链 3. Shiro内置过滤器解析 3.1 内置过滤器概览 3.2 公共继承类解析 3.2.1 顶层Filter接口 3.2.2 AbstractFilter 3.2.3 Nameab…

Github上传代码/删除仓库/新建分支的操作流程记录

首先先安装git,安装完git后,看如下操作指令: 输入自己的用户名和邮箱(为注册GITHUB账号时的用户名和邮箱): git config --global user.name "HJX-exoskeleton" git config --global user.email …

扫码看图怎么做轮播效果?多组图片用扫码查看的方法

图片通过二维码来做展示现在是很常见的一种方式,用这种方式可以用于多种图片格式。那么当我们需要将图片做成多个分组的轮播图样式展示时,有什么好的方法能够做成这个效果呢?下面就来教大家使用二维码生成器制作图片二维码的操作方法&#xf…

Halcon边缘滤波器edges_image 算子

Halcon边缘滤波器edges_image 算子 基于Sobel滤波器的边缘滤波方法是比较经典的边缘检测方法。除此之外,Halcon也提供了一些新式的边缘滤波器,如edges_image算子。它使用递归实现的滤波器(如Deriche、Lanser和Shen)检测边缘&…

xtu oj 1475 冰墩墩和冰壶

题目描述 冰壶是被誉为“冰面上的国际象棋”,其计分规则是各自投壶,最后在大本营内,你有几个壶离圆心比对方所有壶离圆心都近就得到几分。 比如红方有两个壶,分别在坐标(1,1),(−2,1);黄方也有两个壶,分别…

python中的Quene使用方法,包含多线程和多进程

在Python中,队列(Queue)是一种抽象的数据类型,它遵循先进先出(FIFO)的原则。队列是一种特殊的线性表,只允许在表的前端(front)进行删除操作,而在表的后端&…

蓝桥杯省赛无忧 STL 课件16 set

01 set集合 修改set比较方法的常见手段&#xff0c;后面的multiset类似 #include<bits/stdc.h> using namespace std; int main() {set<int,greater<int>> myset;myset.insert(25);myset.insert(17);myset.insert(39);myset.insert(42);for(const auto&…

黑马python就业课

文章目录 初级中级高级初级课程分享 初级 中级 高级 初级课程分享 链接&#xff1a;https://pan.baidu.com/s/1aiJHaThezv_mSI1rnV3d7g 提取码&#xff1a;xdpc

小H靶场笔记:Empire-Breakout

Empire&#xff1a;Breakout January 11, 2024 11:54 AM Tags&#xff1a;brainfuck编码&#xff1b;tar解压变更目录权限&#xff1b;Webmin&#xff1b;Usermin Owner&#xff1a;只惠摸鱼 信息收集 使用arp-scan和namp扫描C段存活主机&#xff0c;探测靶机ip&#xff1a;1…

二极管限幅电路理论分析,工作原理+作用

一、限幅是什么意思&#xff1f; 限幅也就是&#xff0c;将电压限制在某个范围内&#xff0c;去除交流信号的一部分但不会对波形的剩余部分造成影响。通常来说&#xff0c;限幅电路主要是由二极管构成&#xff0c;波形的形状取决于电路的配置和设计。二、限幅电路工作原…

软件测试|Python数据可视化神器——pyecharts教程(九)

使用pyecharts绘制K线图进阶版 简介 K线图&#xff08;Kandlestick Chart&#xff09;&#xff0c;又称蜡烛图&#xff0c;是一种用于可视化金融市场价格走势和交易数据的图表类型。它是股票、外汇、期货等金融市场中最常用的技术分析工具之一&#xff0c;可以提供关于价格变…

简单的天天酷跑小游戏实现

初级函数实现人物,背景,小乌龟的移动 #include <graphics.h> #include <iostream> #include <Windows.h> #include "tools.h" #include <mmsystem.h> #include <conio.h> #include <time.h>//时间头文件 #include <cstdlib&g…

ros2+gazebo(ign)激光雷达+摄像头模拟

虽然ign不能模拟雷达&#xff0c;但是摄线头是可以模拟的。 好了现在都不用模拟了&#xff0c;ign摄线头也模拟不了。 ros2ign gazebo无法全部模拟摄线头和雷达。 只能有这样2个解决方法&#xff1a; 方法1&#xff1a;使用ros2 gazebo11 方案2&#xff1a;使用ros2买一个实…

【QT】QMessageBox 弹出消息框,对话确认框(确定/取消)

1.无互动 QMessageBox::information(nullptr,"信息","登陆成功");2.互动&#xff1a;确定、取消 QMessageBox::StandardButton box; box QMessageBox::question(this, "提示", "确定要添加吗?", QMessageBox::Yes|QMessageBox::…

多种格式图片的制作方法,二维码生成器在线使用教学

图片现在通过二维码展示的场景有很多&#xff0c;比如常见的宣传海报、人员资料、信息展示、自拍等类型的图片都可以做成二维码图片查看。那么如果想要制作图片二维码的小伙伴&#xff0c;使用图片二维码生成器来制作会比较的简单快捷&#xff0c;下面就来给大家介绍一下其具体…

uniapp中uview组件库丰富的CountTo 数字滚动使用方法

目录 #平台差异说明 #基本使用 #设置滚动相关参数 #是否显示小数位 #千分位分隔符 #滚动执行的时机 #API #Props #Methods #Event 该组件一般用于需要滚动数字到某一个值的场景&#xff0c;目标要求是一个递增的值。 注意 如果给组件的父元素设置text-align: cente…

NUS CS1101S:SICP JavaScript 描述:前言、序言和致谢

前言 原文&#xff1a;Foreword 译者&#xff1a;飞龙 协议&#xff1a;CC BY-NC-SA 4.0 我有幸在我还是学生的时候见到了了不起的 Alan Perlis&#xff0c;并和他交谈了几次。他和我共同深爱和尊重两种非常不同的编程语言&#xff1a;Lisp 和 APL。跟随他的脚步是一项艰巨的任…

想成为一名C++开发工程师,需要具备哪些条件?

C语言是一门面向过程的、抽象化的通用程序设计语言&#xff0c;广泛应用于底层开发。C语言能以简易的方式编译、处理低级存储器。C语言是仅产生少量的机器语言以及不需要任何运行环境支持便能运行的高效率程序设计语言。尽管C语言提供了许多低级处理的功能&#xff0c;但仍然保…

JVM知识总结(持续更新)

这里写目录标题 java内存区域程序计数器虚拟机栈本地方法栈堆方法区 java内存区域 Java 虚拟机在执行 Java 程序的过程中会把它管理的内存划分成若干个不同的数据区域&#xff1a; 程序计数器虚拟机栈本地方法栈堆方法区 程序计数器 记录下一条需要执行的虚拟机字节码指令…

图像异或加密及唯密文攻击

异或加密 第一种加密方式为异或加密&#xff0c;异或加密的原理是利用异或的可逆性质&#xff0c;原始图像的像素八位bit分别与伪随机二进制序列异或&#xff0c;得到的图像就为加密图像。如下图对lena图像进行加密。 伪随机序列为一系列二进制代码&#xff0c;它受加密秘钥控…