热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

java微服务架构有哪些,微服务是分布式架构吗

java微服务架构有哪些,微服务是分布式架构吗最近axddy项目的结构越来越

  java微服务架构有哪些,微服务是分布式架构吗

  最近axddy项目的结构越来越大,维护起来非常困难。领导建议对项目进行改造,在工作中把原项目改造成微服务架构。所以,学习微服务的相关知识,记录在这里,可以作为笔记,也可以启发你。今天就来说说微服务。

  单应用在聊微服之前,我先整理一下什么是适合你的单应用。不知道单一应用的痛苦,就不会深刻理解微服务的价值。

  上图是我的axddy项目架构,包含四个模块。可以看出,我们项目的架构属于传统的MVC架构,所有子系统都集成在一个复杂的JVM流程中。

  优点

  这种单片架构的优点是易于管理,所有代码都在同一个项目中,但是当需求越来越大,项目规模越来越大的时候,它的缺点就很明显了。

  缺点

  项目过于臃肿,部署效率低下。当大大小小的功能模块都集中在同一个项目中时,整个项目必然会变得臃肿,开发者很难维护。单一的应用程序代码越来越多,依赖的资源也越来越多,所以一次编译、打包、部署、测试应用程序是需要时间的。

  系统高可用性差,资源无法隔离。整个单一系统的每个功能模块都依赖于相同的资源,如数据库和内存。一旦某个功能模块对资源利用不当,整个系统都会被拖垮。

  开发成本高早期只有两三个团队开发人员,协作修改代码,打包部署,更新发布,完全可控。但是团队一旦扩大,还是按照早期的方法发展。如果在测试阶段有一个函数出现问题,它必须重新编译并打包以便部署。所有开发者都要参与其中,效率低,成本高。

  无法灵活扩展。当访问系统的次数增加时,单个系统可以水平扩展,并部署在多台机器上,形成一个集群:

  但是这种扩张是不灵活的。比如我们目前的性能瓶颈是支付模块,希望只能横向扩展支付模块,这在单一系统中是做不到的。因此,迫切需要一种方法来解耦应用程序的不同模块,从而降低开发和部署成本。

  要解决上述单一应用的问题,必须引入服务的概念。

  什么是服务?用通俗的语言来说,服务就是将传统单一应用中JAR包依赖产生的本地方法调用转化为RPC接口产生的远程方法调用。这些服务围绕业务功能构建,可以通过全自动部署机制独立部署。这些服务具有最少的集中管理,可以用不同的编程语言编写,并使用不同的数据存储技术。

  以我们的项目为例。这个项目中的四个模块是相互依赖的。当这些模块的代码耦合在一起时,就需要加载各个模块的代码,连接资源。任何一个出了问题,整个应用都会受到影响。

  因此,耦合度高的模块,独立的数据源,可以作为服务独立部署,以RPC接口的形式对外提供服务。例如,订单模块和用户模块:

  由此可见,应用扩展单一、团队开发耦合度高、协作效率低等问题都可以通过服务来解决。

  什么是微服务?简而言之,微服务架构风格(microservice architecture style)是一种将单个应用程序开发为一组小服务的方法,每个应用程序在自己的进程中运行,并与一种轻量级机制(通常是HTTP资源API)进行通信。得益于以Docker为代表的容器化技术的成熟和DevOps文化的兴起,服务的思想进一步演变为我们今天所熟悉的微服务。

  说了这么多概念,微服务的具体特点是什么?

  拆分服务粒度更细的微服务,可以说是维度更细的服务,小到一个子模块。只要这个模块所依赖的资源与其他模块无关,就可以拆分成一个微服务。

  服务的独立部署传统的单一架构是由整个系统部署,而微服务是由各个独立的组件(如用户服务、商品服务)部署。

  用一张经典图片来展示一下,大概是这样的:

  你什么意思?比如按照每个服务的吞吐量,支付服务需要部署100台机器,用户服务需要部署30台机器,商品服务只需要部署10台机器。这种灵活部署只能通过微服务架构来实现。

  服务独立维护,分工明确。每个微服务都可以由一个小团队开发、测试、维护和部署,并负责整个生命周期。例如,在单一申请阶段,我们的R&D团队采用传统的水平结构,如下图所示:

  在微服期,我们可以根据其思路将团队划分为垂直组织结构:

  当然,这种垂直划分只是一种理想的结构。其实团队的组织结构在企业中不会那么绝对。

  上一篇文章介绍了微服务的发展起源,从单一应用发展到服务拆分部署。后期随着移动互联网的不断拓展,敏捷开发、持续交付、DevOps理论的发展和实践,以及基于Docker的容器技术的成熟,微服务架构开始流行,逐渐成为应用架构未来的演进方向。

  这就是我对微服务的理解。希望对你有帮助。最后,如果你对Python和Java感兴趣,请长按二维码关注一波,我会尽力为你带来价值。如果你觉得这篇文章对你有什么帮助,请给我点个赞。

  付晓,如果你看到这个并喜欢这篇文章,请好好看看。一个优秀的废人搜索微信,关注后回复电子书。我送你1000本编程电子书,包括C,C,Java,Python,GO,Linux,Git,数据库,设计模式,前端,人工智能,面试相关,数据结构与算法,计算机基础。详见下图。回复1024送你全套java视频教程。



推荐阅读
  • mysql 分库分表策略_【数据库】分库分表策略
    关系型数据库本身比较容易成为系统瓶颈,单机存储容量、连接数、处理能力都有限。当单表的数据量达到1000W或100G以后,由于查询维度较多, ... [详细]
  • 本文探讨了缓存系统中的两个关键问题——缓存穿透与缓存失效时的雪崩效应,以及这些问题的解决方案。此外,文章还介绍了数据处理、数据库拆分策略、缓存优化、拆分策略、应用架构演进及通信协议的选择等内容。 ... [详细]
  • 微服务架构详解及其入门指南
    本文详细介绍了微服务的基本概念、发展历程、与传统架构的区别及优势,并探讨了适合采用微服务架构的场景。此外,文章还深入分析了几个主流的微服务开发框架,特别是Spring Cloud的组成和特点。 ... [详细]
  • 本文通过一个具体的用户管理项目,详细介绍如何使用Spring MVC框架进行开发。从用户实体类的设计到控制器的实现,再到视图层的展示,全面解析Spring MVC的核心功能与实现细节。 ... [详细]
  • 本文旨在分享将Hadoop集群从Windows环境迁移到Linux环境过程中遇到的技术难题及其解决方案,以帮助同行或未来的学习者避免类似问题。 ... [详细]
  • 开发笔记:三分钟快速搭建分布式高可用的Redis集群
    开发笔记:三分钟快速搭建分布式高可用的Redis集群 ... [详细]
  • RabbitMQ消息分发策略与确认机制
    本文详细介绍了RabbitMQ的消息分发轮询机制以及消息确认(Message Acknowledgment)功能,通过实例演示了如何确保消息可靠传递。 ... [详细]
  • 全面解读Apache Flink的核心架构与优势
    Apache Flink作为大数据处理领域的新兴力量,凭借其独特的流处理能力和高效的批处理性能,迅速获得了广泛的关注。本文旨在深入探讨Flink的关键技术特点及其应用场景,为大数据处理提供新的视角。 ... [详细]
  • 在上一章【第三十九章:基于SpringBoot&Quartz完成定时任务分布式单节点持久化】中我们已经完成了任务的持久化,当我们创建一个任务时任务会被quartz定时任务框架自动持 ... [详细]
  • 深入解析ZooKeeper:Java组件化开发必备技能
    本文详细介绍了ZooKeeper作为分布式服务协调框架的核心功能与应用场景,包括其数据一致性解决方案、数据结构特点、监听通知机制及选举机制等,帮助开发者更好地理解和应用ZooKeeper。 ... [详细]
  • 本文探讨了Java异常处理的本质,提出了设计模式以优化异常处理,并分析了在AOP模型中异常处理的应用。文章强调了正确使用Java异常对于提升代码质量和维护性的关键作用。 ... [详细]
  • 深入解析Hcash的PoW+PoS混合共识机制优势
    本文探讨了Hcash项目如何通过结合工作量证明(PoW)和权益证明(PoS)两种共识机制,有效解决了单一机制下的诸多问题,如资源浪费、决策集中及安全风险等,实现了更广泛的社区参与和更高的安全性。 ... [详细]
  • 深入理解SAP Fiori及其核心概念
    本文详细介绍了SAP Fiori的基本概念、发展历程、核心特性、应用类型、运行环境以及开发工具等,旨在帮助读者全面了解SAP Fiori的技术框架和应用场景。 ... [详细]
  • 成为一名高效的Java架构师不仅需要掌握高级Java编程技巧,还需深入理解JVM的工作原理及其优化方法。此外,对池技术(包括对象池、连接池和线程池)的应用、多线程处理、集合对象的内部机制、以及常用的数据结构和算法的精通也是必不可少的。同时,熟悉Linux操作系统、TCP/IP协议栈、HTTP协议等基础知识,对于构建高效稳定的系统同样重要。 ... [详细]
  • J2EE平台集成了多种服务、API和协议,旨在支持基于Web的多层应用开发。本文将详细介绍J2EE平台中的13项关键技术规范,涵盖从数据库连接到事务处理等多个方面。 ... [详细]
author-avatar
ngzhaicai9672364
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有