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



推荐阅读
  • 如何实现JDK版本的切换功能,解决开发环境冲突问题
    本文介绍了在开发过程中遇到JDK版本冲突的情况,以及如何通过修改环境变量实现JDK版本的切换功能,解决开发环境冲突的问题。通过合理的切换环境,可以更好地进行项目开发。同时,提醒读者注意不仅限于1.7和1.8版本的转换,还要适应不同项目和个人开发习惯的需求。 ... [详细]
  • Java在运行已编译完成的类时,是通过java虚拟机来装载和执行的,java虚拟机通过操作系统命令JAVA_HOMEbinjava–option来启 ... [详细]
  • 2018年人工智能大数据的爆发,学Java还是Python?
    本文介绍了2018年人工智能大数据的爆发以及学习Java和Python的相关知识。在人工智能和大数据时代,Java和Python这两门编程语言都很优秀且火爆。选择学习哪门语言要根据个人兴趣爱好来决定。Python是一门拥有简洁语法的高级编程语言,容易上手。其特色之一是强制使用空白符作为语句缩进,使得新手可以快速上手。目前,Python在人工智能领域有着广泛的应用。如果对Java、Python或大数据感兴趣,欢迎加入qq群458345782。 ... [详细]
  • C++语言入门:数组的基本知识和应用领域
    本文介绍了C++语言的基本知识和应用领域,包括C++语言与Python语言的区别、C++语言的结构化特点、关键字和控制语句的使用、运算符的种类和表达式的灵活性、各种数据类型的运算以及指针概念的引入。同时,还探讨了C++语言在代码效率方面的优势和与汇编语言的比较。对于想要学习C++语言的初学者来说,本文提供了一个简洁而全面的入门指南。 ... [详细]
  • 本文介绍了在sqoop1.4.*版本中,如何实现自定义分隔符的方法及步骤。通过修改sqoop生成的java文件,并重新编译,可以满足实际开发中对分隔符的需求。具体步骤包括修改java文件中的一行代码,重新编译所需的hadoop包等。详细步骤和编译方法在本文中都有详细说明。 ... [详细]
  • 本文介绍了lua语言中闭包的特性及其在模式匹配、日期处理、编译和模块化等方面的应用。lua中的闭包是严格遵循词法定界的第一类值,函数可以作为变量自由传递,也可以作为参数传递给其他函数。这些特性使得lua语言具有极大的灵活性,为程序开发带来了便利。 ... [详细]
  • 本文是一位90后程序员分享的职业发展经验,从年薪3w到30w的薪资增长过程。文章回顾了自己的青春时光,包括与朋友一起玩DOTA的回忆,并附上了一段纪念DOTA青春的视频链接。作者还提到了一些与程序员相关的名词和团队,如Pis、蛛丝马迹、B神、LGD、EHOME等。通过分享自己的经验,作者希望能够给其他程序员提供一些职业发展的思路和启示。 ... [详细]
  • 本文介绍了Hyperledger Fabric外部链码构建与运行的相关知识,包括在Hyperledger Fabric 2.0版本之前链码构建和运行的困难性,外部构建模式的实现原理以及外部构建和运行API的使用方法。通过本文的介绍,读者可以了解到如何利用外部构建和运行的方式来实现链码的构建和运行,并且不再受限于特定的语言和部署环境。 ... [详细]
  • Java String与StringBuffer的区别及其应用场景
    本文主要介绍了Java中String和StringBuffer的区别,String是不可变的,而StringBuffer是可变的。StringBuffer在进行字符串处理时不生成新的对象,内存使用上要优于String类。因此,在需要频繁对字符串进行修改的情况下,使用StringBuffer更加适合。同时,文章还介绍了String和StringBuffer的应用场景。 ... [详细]
  • 本文介绍了RPC框架Thrift的安装环境变量配置与第一个实例,讲解了RPC的概念以及如何解决跨语言、c++客户端、web服务端、远程调用等需求。Thrift开发方便上手快,性能和稳定性也不错,适合初学者学习和使用。 ... [详细]
  • 本文介绍了计算机网络的定义和通信流程,包括客户端编译文件、二进制转换、三层路由设备等。同时,还介绍了计算机网络中常用的关键词,如MAC地址和IP地址。 ... [详细]
  • 本文介绍了作者在开发过程中遇到的问题,即播放框架内容安全策略设置不起作用的错误。作者通过使用编译时依赖注入的方式解决了这个问题,并分享了解决方案。文章详细描述了问题的出现情况、错误输出内容以及解决方案的具体步骤。如果你也遇到了类似的问题,本文可能对你有一定的参考价值。 ... [详细]
  • 本文探讨了C语言中指针的应用与价值,指针在C语言中具有灵活性和可变性,通过指针可以操作系统内存和控制外部I/O端口。文章介绍了指针变量和指针的指向变量的含义和用法,以及判断变量数据类型和指向变量或成员变量的类型的方法。还讨论了指针访问数组元素和下标法数组元素的等价关系,以及指针作为函数参数可以改变主调函数变量的值的特点。此外,文章还提到了指针在动态存储分配、链表创建和相关操作中的应用,以及类成员指针与外部变量的区分方法。通过本文的阐述,读者可以更好地理解和应用C语言中的指针。 ... [详细]
  • 本文介绍了在Windows环境下如何配置php+apache环境,包括下载php7和apache2.4、安装vc2015运行时环境、启动php7和apache2.4等步骤。希望对需要搭建php7环境的读者有一定的参考价值。摘要长度为169字。 ... [详细]
  • 本文讨论了在shiro java配置中加入Shiro listener后启动失败的问题。作者引入了一系列jar包,并在web.xml中配置了相关内容,但启动后却无法正常运行。文章提供了具体引入的jar包和web.xml的配置内容,并指出可能的错误原因。该问题可能与jar包版本不兼容、web.xml配置错误等有关。 ... [详细]
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社区 版权所有