微服务项目搭建之技术选型

1、什么是微服务

Java微服务是一种架构风格,通过将单个Spring Boot应用程序拆分为一组小型、独立的Spring Boot服务来构建分布式系统。每个微服务都运行在自己的进程中,并使用轻量级通信机制(如HTTP或消息队列)来进行相互之间的通信。微服务的设计目标是提高系统的灵活性、可伸缩性和可维护性。通过将应用程序拆分为多个微服务,可以实现更好的团队协作和并行开发。每个微服务都可以由不同的开发团队负责开发和维护,因此可以快速迭代和部署,而不会对整个系统产生太大的影响。

拆分微服务的特点:

  • 独立部署:每个微服务都可以独立部署,因为它们是独立的进程。这意味着当某个微服务需要进行更改或调整时,只需重新部署该微服务,而不需要重新部署整个系统。

  • 松耦合:由于微服务之间使用轻量级通信机制进行通信,它们可以相对独立地演化和扩展。每个微服务都可以根据需要进行扩展,而不会对其他微服务造成影响。

  • 垂直划分:微服务架构鼓励将应用程序按业务领域划分为多个微服务。这种垂直划分使得每个微服务都可以专注于解决特定的业务问题,提高开发和维护的效率。

  • 弹性和容错:微服务架构使用一些弹性和容错机制来提高系统的稳定性。例如,可以使用负载均衡、熔断器和容错机制来处理异常情况,并保护系统免受单个微服务的故障影响。

  • 中心化治理:微服务架构通常使用一些中心化的工具和组件来处理服务注册和发现、负载均衡、监控和日志等功能。

微服务的弊端:

  • 分布式系统复杂性:拆分成多个微服务后,系统的复杂性得到加剧。需要考虑服务之间的通信、数据一致性、服务调用链的监控等问题。因此,微服务架构需要更高的开发和运维技术水平,同时也需要投入更多的成本和资源进行管理和维护。

  • 服务调用开销:由于微服务之间需要进行网络通信,会带来一定的性能开销。每个服务调用都需要经过网络传输,并可能受到网络延迟和故障的影响。因此,需要在设计和实现中考虑减少服务之间的调用次数,以提高性能和可靠性。

  • 数据管理复杂性:由于数据在不同的微服务中被分散存储,数据一致性和事务处理变得更加困难。需要采用一些分布式数据管理策略,如事件驱动架构或分布式事务,来确保数据的一致性和可靠性。

总体而言,Java微服务架构使得开发人员可以更好地构建、部署和维护分布式系统。通过拆分应用程序为多个小型服务,并使用适当的工具和模式来管理这些服务之间的通信和协调,提高系统的弹性、可伸缩性和可维护性。但是在决定将单体应用程序转换为微服务时,需要仔细评估和权衡成本和利益,确保有足够的资源和技术能力来应对微服务架构所带来的挑战。微服务架构带来的分布式系统的复杂性,包括服务发现、通信、数据一致性等方面的问题还是值得我们去谨慎考虑的。

2、微服务常见组件和功能

Spring Cloud是一个用于构建分布式系统的开发工具集合,基于Spring框架,提供了一系列的解决方案和工具,使得开发者能够更轻松地构建、部署和管理分布式系统中的微服务。一套完整的微服务架构需要以下相关组件:

  • 注册中心:服务的注册与发现,服务可以注册自己的信息到注册中心,并且可以从注册中心获取其他服务的信息,从而实现服务之间的通信和协作。

  • 配置中心:集中式的配置管理解决方案,可以实现对分布式系统中各个微服务的配置进行集中管理,实现配置的动态刷新。

  • 网关: 统一的接口访问路径,实现请求的转发、鉴权、限流、请求转换等功能。

  • 负载均衡: 使得服务能够根据负载情况自动分配流量,并提供了一些策略和配置选项来实现高效的负载均衡。

  • 远程调用:远程调用是微服务架构中的重要部分,它使得服务之间可以相互协作并提供复杂的业务功能。

  • 熔断器:熔断器可以防止分布式系统中的故障蔓延,通过快速失败和回退机制,保护调用方免受故障影响。

  • 链路追踪: 实现分布式系统中的链路追踪和请求跟踪。通过链路追踪,可以跟踪请求在分布式系统中的传递和处理路径,便于故障排查和性能优化。

  • 消息队列: 消息队列可以用于在微服务之间进行消息的传递和通信,实现解耦和异步通信。

  • 任务调度:对定时任务进行管理和调度的过程。任务调度涉及到确定任务的执行时间、执行频率、任务优先级以及任务间的依赖关系等。帮助我们管理和调度任务,提高系统的效率和可靠性。

  • 服务监控:用于监控微服务的性能指标、错误和故障信息。常用监控工具:Prometheus和Grafana 。

  • 容器化和编排:容器化和编排工具用于将微服务部署到容器中,并管理容器化应用程序的生命周期。Docker和Kubernetes是常见的容器化和编排工具。

以上就是微服务常见组件和功能,实际上,微服务技术栈可以根据特定的需求和技术栈进行灵活的组合和扩展。选择正确的微服务栈组件取决于应用程序的要求、团队的技术能力和可用的资源。

总的来说微服务分为服务核心组件和服务治理两个方面,架构图如下:

通过使用五大核心组件,微服务已经搭建成功了,但并不算是一个完整的微服务。如果没有服务治理方面的组件,很难确保系统稳定性、安全性和可扩展性的。

3、微服务技术栈

现在微服务有两套实现分别为Spring Cloud Netflix和Spring Cloud Alibaba两个大版本。Spring Cloud Netflix版一些重要组件如注册中心Euraka、Ribbon、Zuul、Feign已经不再迭代更新了,而Spring Cloud Alibaba已经慢慢的孵化出了一套自己的相关组件。

3.1、Spring Cloud Netflix相关组件说明

主要由:Eureka、Ribbon、Feign、Hystrix、Zuul|Gateway、Config等组件组成。还有一些补充组件Spring Cloud Config(分布式配置管理)、Spring Cloud Bus(消息总线)、Spring Cloud Security(安全管理)等。

  • Eureka:Eureka是一个服务注册和发现组件。服务提供者可以将自己注册到Eureka服务器,而服务消费者可以从Eureka服务器中获取可用的服务列表。Eureka提供了负载均衡和故障转移的能力。

  • Spring Cloud Config:配置中心,集中式的配置管理解决方案。

  • Feign:Feign是一个声明式的HTTP客户端。它简化了对其他微服务的调用,比如使用Feign可以轻松地定义RESTful接口并将其映射到实际的服务调用。Feign集成了Ribbon和Hystrix,提供了负载均衡和容错的能力。目前Feign已经不迭代更新,可以使用OpenFeign。

  • Ribbon:Ribbon是一个客户端负载均衡组件。它可以根据配置的负载均衡策略,从服务注册中心(如Eureka)获取可用服务列表,并将请求分发给这些服务实例。Ribbon支持多种负载均衡算法,并提供了灵活的配置选项。

  • Hystrix:Hystrix是一个容错和延迟容忍的库。它可以防止分布式系统中的故障导致级联故障。Hystrix通过使用断路器模式,可以在服务调用失败时提供回退机制,并提供了实时的监控和度量指标。

  • Zuul:Zuul是一个网关组件,可以实现请求的路由、过滤和负载均衡等功能。它可以作为一个单一入口点,代理客户端请求并将其路由到后端的微服务。同时,Zuul还支持动态路由配置和服务的自动发现。服务网关,多个服务提供唯一的访问接口。目前Zuul不迭代更新,可以使用Gateway。

总之,Spring Cloud Netflix提供了一套完整的、基于Netflix OSS的分布式系统解决方案。通过使用这些组件,可以更轻松地构建和管理微服务架构,并提供负载均衡、容错和服务发现等核心功能。但是由于许多组件已经不再迭代更新了,所以不推荐全部使用基于Netflix的一套微服务解决方案。需要通过别的组件配合使用。

3.2 Spring Cloud Alibaba相关组件说明

Spring Cloud Alibaba是Spring Cloud的一套拓展框架,它提供了一系列与阿里巴巴生态系统集成的组件,用于构建微服务架构。主要由:Nacos、Sentinel、Seata、RocketMQ、Dubbo等组件组成。目前RocketMQ、Dubbo和Seata这三个项目都已经捐赠给了Apache软件基金会(Apache Software Foundation)。

  • Nacos:Nacos是一个服务发现和配置管理的平台,可以实现服务注册、发现、配置和管理。Nacos可以作为一个类似于Eureka和Spring Cloud Config的解决方案,同时还提供了更丰富的配置管理能力。有图形化界面,简化了微服务架构的复杂度。

  • Sentinel:Sentinel是一个轻量级的流量控制和熔断降级框架。它可以实时监控应用的流量和系统状态,并提供实时的流量控制、熔断降级和系统负载保护等功能。多个维度保护服务的稳定性。

  • Seata:高性能微服务分布式事务解决方案。

  • RocketMQ:RocketMQ是阿里巴巴开源的分布式消息队列系统。它提供了低延时、高可靠性、高吞吐量的消息传递服务,适用于大规模分布式系统的消息通信。

  • Dubbo:高性能 RPC 框架。类似于OpenFeign。

  • Alibaba Cloud OSS(Object Storage Service):是阿里云提供的海量、安全、低成本、高可靠的云存储服务。Spring Cloud Alibaba支持将OSS作为文件存储和对象存储的解决方案,并提供了便利的API和工具,用于在微服务中使用OSS进行文件上传、下载和存储操作。

  • Alibaba Cloud SMS(Short Message Service):是阿里云提供的短信服务。Spring Cloud Alibaba提供了集成SMS的组件,可以轻松地发送短信通知和验证码等消息。覆盖全球的短信服务,友好、高效、智能的互联化通讯能力,帮助企业迅速搭建客户触达通道。

  • Alibaba Cloud SchedulerX:阿里中间件团队开发的一款分布式任务调度产品,提供秒级、精准、高可靠、高可用的定时(基于 Cron 表达式)任务调度服务。

OSS、SMS、SchedulerX等主要是阿里云的商业化产品,需要付费才能够使用。总之阿里巴巴生态系统的组件集成,为我们提供了更多的选择和功能。可以轻松地构建阿里巴巴风格的微服务应用,并利用阿里巴巴生态系统的资源进行扩展和集成。也是目前最流行的一套微服务架构解决方案。

4、微服务技术选择

通过上面我们了解到微服务使用的相关技术栈,我们可以通过结合Spring Cloud Netflix和Spring Cloud Alibaba相关组件。选择出一套基于自己想要搭建的微服务技术栈:

  • 注册中心和配置中心:使用Spring Cloud Alibaba Nacos

  • 负载均衡:使用LoadBalancer。Spring Cloud LoadBalancer是Spring Cloud官方推荐的负载均衡器,这是一个全新的负载均衡解决方案。它提供了多种负载均衡算法(如轮询、随机等),并支持与服务注册中心集成,以获取服务实例列表。

  • 服务调用:使用OpenFeign或者Dubbo,OpenFeign是声明式的HTTP客户端,Dubbo是RPC框架。

  • 熔断降级:使用Spring Cloud Alibaba Sentinel

  • 消息队列:使用RocketMQ

  • 分布式事务:使用Spring Cloud Alibaba Seata

  • API网关:使用Gateway。Spring Cloud Gateway是一个高性能、可扩展的API网关,用于路由、转发和过滤进入的HTTP请求。

  • 任务调度:使用xxl-job, xxl-job是一个功能丰富、易用的分布式任务调度平台,可以实现定时任务的调度和执行。它可以作为一个独立的服务集群,对任务进行统一的管理和调度,并支持任务的动态添加、修改和删除, 适用于各种定时任务的场景.

  • 链路追踪 : 使用Zipkin ,Zipkin是一个开源的分布式系统跟踪系统,用于收集、检索和展示微服务架构中的请求链路信息。它可以追踪和分析请求路径,识别性能问题和排查故障。

  • 服务监控:使用Prometheus和Grafana ,Prometheus和Grafana是两个常用的监控和可视化工具,常用于对系统和应用程序进行监控和数据可视化。

以上就是搭建微服务项目技术栈所需要的组件。另外也可以把注册中心替换为Eureka,配置中心使用携程开源的分布式配置中心Apollo,它们都是不错的选择,具体实现可以根据特定的需求进行灵活的组合和扩展。具体使用组件取决于应用程序的要求、团队的技术能力和可用的资源。通过这些以选择正确的微服务技术栈。

5、总结

总之,希望我们在搭建微服务的过程中,不要盲目的去使用任何一个组件,更不要因为那个组件比较流行就使用那个组件。每个微服务组件都有它们的使用场景,也有它们的利与弊。在使用之前一定要考虑它的使用成本以及是否有足够的资源支撑和团队的技术能力是否达标。如果满足所有条件,在考虑使用它。最后希望不管是企业使用也好还是个人自己使用,都可以正确的选择一套适用于自己或者企业的微服务技术实践方案。

文章转载自:sowler 

原文链接:https://www.cnblogs.com/sowler/p/18216528

体验地址:引迈 - JNPF快速开发平台_低代码开发平台_零代码开发平台_流程设计器_表单引擎_工作流引擎_软件架构

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

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

相关文章

【C++】从零开始构建红黑树 —— 节点设计,插入函数的处理 ,旋转的设计

送给大家一句话: 日子没劲,就过得特别慢,但凡有那么一点劲,就哗哗的跟瀑布似的拦不住。 – 巫哲 《撒野》 🌋🌋🌋🌋🌋🌋🌋🌋 ⛰️⛰️…

Vue组件通讯$attrs和$listeners例子

在Vue中,$attrs 和 $listeners 是两个非常有用的特性,它们允许你更轻松地实现组件间的通讯,特别是当你需要创建可复用的组件时。 $attrs 包含了父组件中未被子组件声明的属性 (class 和 style 除外)。当你不想在子组件中逐个声明父组件传递的…

在豆包这事上,字节看得很明白

大数据产业创新服务媒体 ——聚焦数据 改变商业 导语: 1.基于豆包的话炉/猫箱APP市场反响一般 2.价格战对于豆包来说是副产物 3.价格战对大模型市场是良性的 4.豆包接下来会推广至国际社会 因为宣称价格比行业便宜99.3%,豆包成功出圈了。根据火山引擎公…

笔试强训week6

day1 Q1 难度⭐⭐ 小红的口罩_牛客小白月赛41 (nowcoder.com) 题目: 疫情来了,小红网购了 n 个口罩。 众所周知,戴口罩是很不舒服的。小红每个口罩戴一天的初始不舒适度为 ai​。 小红有时候会将口罩重复使用(注:…

【Linux】数据链路层协议+ICMP协议+NAT技术

欢迎来到Cefler的博客😁 🕌博客主页:折纸花满衣 🏠个人专栏:Linux 目录 👉🏻数据链路层👉🏻以太网以太网帧格式网卡Mac地址对比ip地址 👉🏻MTUMTU…

gtest的使用和简单例子

首先需要安装gtest的库,命令如下: git clone https://github.com/google/googletest.git cd googletest mkdir build cd build cmake .. sudo make install后续就可以直接包含gtest头文件进行测试了。 这里给出一个测试的简单例子,这里使用…

温度传感器安装热套管介绍

热套管(Thermowell)是一段末端封闭的金属管,主要通过焊接、螺纹或法兰连接的方式安装到过程容器或管线上,可保护温度传感器免受流致应力、高压和腐蚀性化学品等严苛工况的影响。此外,热套管使传感器可以轻松方便地拆下…

介绍图片懒加载的几种实现方法

在 JavaScript 中,懒加载(Lazy Loading)主要用于延迟加载资源,例如图片、视频、音频、脚本等,直到它们真正需要时才加载。这样可以提高页面的加载速度和性能。 以下是几种常见的 JavaScript 懒加载实现方式&#xff1…

【管理咨询宝藏116】某大型国有集团公司战略落地保障方案

本报告首发于公号“管理咨询宝藏”,如需阅读完整版报告内容,请查阅公号“管理咨询宝藏”。 【管理咨询宝藏116】某大型国有集团公司战略落地保障方案 【格式】PDF版本 【关键词】战略落地、大型国企、战略报告 【核心观点】 - 资产规模以提高资产质量、…

第三部分:领域驱动设计之通过重构得到更深层的理解

通过重构得到更深层的理解 通过重构得到更深层的理解是一个涉及很多方面的过程。有三件事情是必须要关注的: 以领域为本;用一种不同的方式来看待事物;始终坚持与领域专家对话。 开始重构 获得深层理解的重构可能出现在很多方面。一开始有可能是为了解决代码中的问题——一段…

Linux的线程状态

在Linux中,每个进程都有一个当前的状态,这个状态用于标识进程当前正在做什么。你可以通过ps命令配合不同的选项来查看进程的状态。以下是常见的进程状态及其含义: R (running or runnable): 进程正在运行或在运行队列中等待运行。这并不是说进程正在CPU上执行,而是说它处于…

项目十三:搜狗——python爬虫实战案例

根据文章项目十二:简单的python基础爬虫训练-CSDN博客的简单应用,这一次来升级我们的技术,那么继续往下看,希望对技术有好运。 还是老样子,按流程走,一条龙服务,嘿嘿。 第一步:导入…

华为诺亚等发布MagicDrive3D:自动驾驶街景中任意视图渲染的可控3D生成

文章链接:https://arxiv.org/pdf/2405.14475 项目链接:https://flymin.github.io/magicdrive3d 虽然可控生成模型在图像和视频方面取得了显著成功,但在自动驾驶等无限场景中,高质量的3D场景生成模型仍然发展不足,主…

Neo4J中构建的知识图谱,如何使用推理算法

在Neo4j中构建的知识图谱中,推理算法的使用可以极大地增强数据分析和洞察能力。Neo4j提供了多种推理和查询工具,主要通过Cypher查询语言和内置的图算法库来实现。以下是几种常见的推理算法和使用场景: 1. 规则推理(Rule-based Re…

2951. 找出峰值 Easy

给你一个下标从 0 开始的数组 mountain 。你的任务是找出数组 mountain 中的所有 峰值。 以数组形式返回给定数组中 峰值 的下标,顺序不限 。 注意: 峰值 是指一个严格大于其相邻元素的元素。 数组的第一个和最后一个元素 不 是峰值。 示例 1&#xf…

关于宏的理解

关于宏的理解, 用宏函数举例 宏会把我们的内容编程一段代码,但是我们宏用的一切都不是变量,就是一个构建代码的符号。 比如下面的例子 char str1[] "1234"; const char* str2 "1234"; char st3[5] { 1,2,3,4,\0 };…

Linux网络编程:应用层协议|HTTP

前言: 我们知道OSI模型上层分为应用层、会话层和表示层,我们接下来要讲的是主流的应用层协议HTTP,为什么需要这个协议呢,因为在应用层由于操作系统的不同、开发人员使用的语言类型不同,当我们在传输结构化数据时&…

【全开源】宇鹿家政系统(FastAdmin+ThinkPHP+原生微信小程序)

:助力家政行业数字化升级 一、引言:家政服务的新篇章 随着移动互联网的普及和人们生活水平的提高,家政服务的需求日益增长。为了满足这一市场需求,并推动家政行业的数字化升级,我们特别推出了家政小程序系统源码。这…

excel 点击单元格的内容 跳转到其他sheet设置

如图点击1处跳转到2 按照如下图步骤操作即可

oracle 分区表常用语句(2)

给分区表增加分区 第一种不存在MAXVALUE(直接添加即可) ALTER TABLE T6 ADD PARTITION P5 VALUES LESS THAN(TO_DATE( 2018-08-01 00:00:00, SYYYY-MM-DD HH24:MI:SS, NLS_CALENDARGREGORIAN));第二种存在MAXVALUE alter table T6 split PARTITION P4 at(TO_DAT…