热门标签 | 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视频教程。



推荐阅读
  • 本文探讨了如何在 PHP 的 Eloquent ORM 中实现数据表之间的关联查询,并通过具体示例详细解释了如何将关联数据嵌入到查询结果中。这不仅提高了数据查询的效率,还简化了代码逻辑。 ... [详细]
  • 本文作者分享了在阿里巴巴获得实习offer的经历,包括五轮面试的详细内容和经验总结。其中四轮为技术面试,一轮为HR面试,涵盖了大量的Java技术和项目实践经验。 ... [详细]
  • 1.如何在运行状态查看源代码?查看函数的源代码,我们通常会使用IDE来完成。比如在PyCharm中,你可以Ctrl+鼠标点击进入函数的源代码。那如果没有IDE呢?当我们想使用一个函 ... [详细]
  • 本文详细介绍了Java编程语言中的核心概念和常见面试问题,包括集合类、数据结构、线程处理、Java虚拟机(JVM)、HTTP协议以及Git操作等方面的内容。通过深入分析每个主题,帮助读者更好地理解Java的关键特性和最佳实践。 ... [详细]
  • Java项目分层架构设计与实践
    本文探讨了Java项目中应用分层的最佳实践,不仅介绍了常见的三层架构(Controller、Service、DAO),还深入分析了各层的职责划分及优化建议。通过合理的分层设计,可以提高代码的可维护性、扩展性和团队协作效率。 ... [详细]
  • PHP 5.2.5 安装与配置指南
    本文详细介绍了 PHP 5.2.5 的安装和配置步骤,帮助开发者解决常见的环境配置问题,特别是上传图片时遇到的错误。通过本教程,您可以顺利搭建并优化 PHP 运行环境。 ... [详细]
  • Python自动化处理:从Word文档提取内容并生成带水印的PDF
    本文介绍如何利用Python实现从特定网站下载Word文档,去除水印并添加自定义水印,最终将文档转换为PDF格式。该方法适用于批量处理和自动化需求。 ... [详细]
  • 本文详细介绍了macOS系统的核心组件,包括如何管理其安全特性——系统完整性保护(SIP),并探讨了不同版本的更新亮点。对于使用macOS系统的用户来说,了解这些信息有助于更好地管理和优化系统性能。 ... [详细]
  • 从 .NET 转 Java 的自学之路:IO 流基础篇
    本文详细介绍了 Java 中的 IO 流,包括字节流和字符流的基本概念及其操作方式。探讨了如何处理不同类型的文件数据,并结合编码机制确保字符数据的正确读写。同时,文中还涵盖了装饰设计模式的应用,以及多种常见的 IO 操作实例。 ... [详细]
  • Hadoop入门与核心组件详解
    本文详细介绍了Hadoop的基础知识及其核心组件,包括HDFS、MapReduce和YARN。通过本文,读者可以全面了解Hadoop的生态系统及应用场景。 ... [详细]
  • 本文详细介绍了MicroATX(也称Mini ATX)和MATX主板规格,探讨了它们的结构特点、应用场景及对电脑系统成本和性能的影响。同时,文章还涵盖了相关操作系统的实用技巧,如蓝牙设备图标删除、磁盘管理等。 ... [详细]
  • 本文探讨了领域驱动设计(DDD)的核心概念、应用场景及其实现方式,详细介绍了其在企业级软件开发中的优势和挑战。通过对比事务脚本与领域模型,展示了DDD如何提升系统的可维护性和扩展性。 ... [详细]
  • 本文将深入探讨PHP编程语言的基本概念,并解释PHP概念股的含义。通过详细解析,帮助读者理解PHP在Web开发和股票市场中的重要性。 ... [详细]
  • 深入理解Vue.js:从入门到精通
    本文详细介绍了Vue.js的基础知识、安装方法、核心概念及实战案例,帮助开发者全面掌握这一流行的前端框架。 ... [详细]
  • Redux入门指南
    本文介绍Redux的基本概念和工作原理,帮助初学者理解如何使用Redux管理应用程序的状态。Redux是一个用于JavaScript应用的状态管理库,特别适用于React项目。 ... [详细]
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社区 版权所有