首页 Java Java入门 java 什么是分布式

java 什么是分布式

Nov 14, 2019 pm 05:10 PM
java 分布式

java 什么是分布式

什么是分布式系统?

要理解分布式系统,主要需要明白一下2个方面:

1.分布式系统一定是由多个节点组成的系统。

其中,节点指的是计算机服务器,而且这些节点一般不是孤立的,而是互通的。

2.这些连通的节点上部署了我们的节点,并且相互的操作会有协同。

分布式系统对于用户而言,他们面对的就是一个服务器,提供用户需要的服务而已,而实际上这些服务是通过背后的众多服务器组成的一个分布式系统,因此分布式系统看起来像是一个超级计算机一样。

例如淘宝,平时大家都会使用,它本身就是一个分布式系统,我们通过浏览器访问淘宝网站时,这个请求的背后就是一个庞大的分布式系统在为我们提供服务,整个系统中有的负责请求处理,有的负责存储,有的负责计算,最终他们相互协调把最后的结果返回并呈现给用户。

328a29d7734b7c4682f1737cc84022f.png

使用分布式系统主要有特点:

1.增大系统容量。 我们的业务量越来越大,而要能应对越来越大的业务量,一台机器的性能已经无法满足了,我们需要多台机器才能应对大规模的应用场景。所以,我们需要垂直或是水平拆分业务系统,让其变成一个分布式的架构。

2.加强系统可用。 我们的业务越来越关键,需要提高整个系统架构的可用性,这就意味着架构中不能存在单点故障。这样,整个系统不会因为一台机器出故障而导致整体不可用。所以,需要通过分布式架构来冗余系统以消除单点故障,从而提高系统的可用性。

3.因为模块化,所以系统模块重用度更高。

4.因为软件服务模块被拆分,开发和发布速度可以并行而变得更快。

5.系统扩展性更高。

6.团队协作流程也会得到改善。

分布式系统的类型有三种:

1.分布式处理,但只有一个总数据库,没有局部数据库。

2.分层式处理,每一层都有自己的数据库。

3.充分分散的分布式网络,没有中央控制部分,各节点之间的联系方式又可以有多种,如松散的联接,紧密的联接,动态的联接,广播通知式的联接等。

什么是 JAVA 分布式应用?

一个大型的系统往往被分为几个子系统来做,一个子系统可以部署在一台机器的多个 JVM 上,也可以部署在多台机器上。但是每一个系统不是独立的,不是完全独立的。需要相互通信,共同实现业务功能。

一句话来说:分布式就是通过计算机网络将后端工作分布到多台主机上,多个主机一起协同完成工作。

实现分布式主要的方式

分布式应用用到的技术: 网络通信,基于消息方式的系统间通信和基于远程调用的系统间通信。

缺点:就是会增加技术的复杂度。

基于消息的系统通信方式,主要是利用的网络协议,比如 TCP/IP 协议。

系统间的通信还需要对数据进行处理,比如同步 IO 和异步 IO。

远程调用实现系统间的通信:通过调用本地的java接口的方法来透明的调用远程java的实现。具体的细节有框架来实现。

众多java培训视频,尽在PHP中文网,欢迎在线学习!

以上是java 什么是分布式的详细内容。更多信息请关注PHP中文网其他相关文章!

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Clothoff.io

Clothoff.io

AI脱衣机

Video Face Swap

Video Face Swap

使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

热门话题

PHP教程
1511
276
python argparse需要参数示例 python argparse需要参数示例 Aug 11, 2025 pm 09:42 PM

在使用argparse模块时,必须提供的参数可通过设置required=True来实现,1.使用required=True可将可选参数(如--input)设为必填,运行脚本时若未提供会报错;2.位置参数默认必填,无需设置required=True;3.建议必要参数使用位置参数,偶尔必须的配置再使用required=True的可选参数,以保持灵活性;4.required=True是控制参数必填最直接的方式,使用后用户调用脚本时必须提供对应参数,否则程序将提示错误并退出。

Java开发的最佳IDE:比较评论 Java开发的最佳IDE:比较评论 Aug 12, 2025 pm 02:55 PM

ThebestJavaIDEin2024dependsonyourneeds:1.ChooseIntelliJIDEAforprofessional,enterprise,orfull-stackdevelopmentduetoitssuperiorcodeintelligence,frameworkintegration,andtooling.2.UseEclipseforhighextensibility,legacyprojects,orwhenopen-sourcecustomizati

Java的评论是什么? Java的评论是什么? Aug 12, 2025 am 08:20 AM

评论Incominjavaareignoredbythecompilereranded forexplanation,notes,OrdisablingCode.thereareThreetypes:1)单位linecommentsStartWith // andlastuntiltheEndoftheline; 2)Multi-lineCommentsBebeNWITH/ANDENCOMMENTBEMEMENT/ANDENDWITH/ANDENDWITH/ANDENDWITH/ANDENDWITH/ANDENDWITH/ANDENDWITH/ANDENDWITH/ANDCANSPANMELTIPLICEMENTS; 3)文档

如何比较爪哇的弦 如何比较爪哇的弦 Aug 12, 2025 am 10:00 AM

使用.equals()比较字符串内容,因为==仅比较对象引用而非实际字符;2.进行忽略大小写的比较时使用.equalsIgnoreCase();3.需要按字母顺序排序时使用.compareTo(),忽略大小写则用.compareToIgnoreCase();4.避免对可能为null的字符串调用.equals(),应使用"literal".equals(variable)或Objects.equals(str1,str2)来安全处理null值;总之,始终关注内容比较而非引用,确

如何在Java中使用httpclient API 如何在Java中使用httpclient API Aug 12, 2025 pm 02:27 PM

使用JavaHttpClientAPI的核心是创建HttpClient、构建HttpRequest并处理HttpResponse。1.使用HttpClient.newHttpClient()或HttpClient.newBuilder()配置超时、代理等创建客户端;2.使用HttpRequest.newBuilder()设置URI、方法、头和体来构建请求;3.通过client.send()发送同步请求或client.sendAsync()发送异步请求;4.使用BodyHandlers.ofStr

Java中的LinkedList是什么? Java中的LinkedList是什么? Aug 12, 2025 pm 12:14 PM

LinkedList在Java中是一个双向链表,实现了List和Deque接口,适用于频繁插入和删除元素的场景,尤其在列表两端操作时效率高,但随机访问性能较差,时间复杂度为O(n),而插入和删除在已知位置时可达到O(1),因此适合用于实现栈、队列或需要动态修改结构的场合,而不适合频繁按索引访问的读密集型操作,最终结论是LinkedList在修改频繁但访问较少时优于ArrayList。

边缘不保存历史记录 边缘不保存历史记录 Aug 12, 2025 pm 05:20 PM

首先,Checkif“ ClearBrowsingDataOnclose” IsturnedonInsettingsandTurnitOfftoensureHistoryIsSaved.2.Confirmyou'renotusinginprivateMode,asitdoesnotsavehistorybydesign.3.disborextimentsextionsextionsextionsextementsextionsextionsextionsextextiensextextionsporextiensporextiensporlyTorluleuleuleuleOutInterferfereframprivacyOrad bacyorad blockingtoo

Excel查找并更换不工作 Excel查找并更换不工作 Aug 13, 2025 pm 04:49 PM

checkSearchSettingStingsTike“ matchentirecellcontents”和“ matchcase” byExpandingOptionsInfindReplace,确保“ lookin” insettovaluesand和“ tocorrectScope”中的“ Issettovaluesand”; 2. look forhiddenChindChareChideCharacterSorformattingTingTingTingBycopyBycopyingByingTextDextDirectly

See all articles