对于初学者来说,学习Java的根本动力就是分布式开发,特别是apache下面的hadoop、hdfs、hbase,这些基本是分布式开发的标配。那么这篇文章就来和大家一起聊聊分布式吧!

一、什么是分布式系统?

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

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

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

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

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

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

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

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

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

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

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

5、系统扩展性更高。

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

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

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

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

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

二、什么是Java分布式应用?

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

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

三、实现分布式主要的方式

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

缺点:就是会增加技术的复杂度。基于消息的系统通信方式,主要是利用的网络协议,比如TCP/IP协议。系统间的通信还需要对数据进行处理,比如同步IO和异步IO。

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

基于Java自身技术实现消息方式的系统间通信:

基于Java自身包实现消息方式的系统间通信的方式有:

TCP/IP+BIO、TCP/IP+NIO、UDP/IP+BIO以及UDP/IP+NIO 4种方式。

TCP/IP+BIO在Java中可基于Socket、ServerSocket来实现TCP/IP+BIO的系统间通信。

Socket主要用于实现建立连接及网络IO的操作,ServerSocket主要用于实现服务器端端口的监听及Socket对象的获取。

多个客户端访问服务器端的情况下,会遇到两个问题:建立多个socket的,占用过多的本地资源,服务器端要承受巨大的来访量;创建过多的socket,占用过多的资源,影响性能。

通常解决这种问题的办法是,使用连接池,既能限制连接的数量,又能避免创建的过程,可以很大的提高性的问题。缺点就是竞争量大的时候造成激烈的竞争和等待。需要注意的是,要设置超时时间,如果不这样的话,会造成无限制的等待。

为了解决这个问题,采用一连接一线程的方式,同时也会带来副作用,内存占用过多。

TCP/IP异步通信:Java NIO通道技术实现。

以上就是对Java分布式的理解了。希望看完这篇文章大家对Java分布式有更深层次的认识。
————————————————
版权声明:本文为CSDN博主「戏精程序媛」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/xiaoxijing/article/details/99865038

什么是Java分布式?相关推荐

  1. java分布式锁解决方案 redisson or ZooKeeper

    redis 分布式锁 Redisson 是 redis 官方推荐的Java分布式锁第三方框架. 高效分布式锁 当我们在设计分布式锁的时候,我们应该考虑分布式锁至少要满足的一些条件,同时考虑如何高效的设 ...

  2. 5个强大的Java分布式缓存框架推荐

    2019独角兽企业重金招聘Python工程师标准>>> 在开发中大型Java软件项目时,很多Java架构师都会遇到数据库读写瓶颈,如果你在系统架构时并没有将缓存策略考虑进去,或者并没 ...

  3. 5个强大的Java分布式缓存框架

    5个强大的Java分布式缓存框架 在开发中大型Java软件项目时,很多Java架构师都会遇到数据库读写瓶颈,如果你在系统架构时并没有将缓存策略考虑进去,或者并没有选择更优的缓存策略,那么到时候重构起来 ...

  4. java分布式对象——远程方法中的参数和返回值+远程对象激活

    [0]README 1)本文文字描述转自 core java volume 2, 旨在学习 java分布式对象--远程方法中的参数和返回值+远程对象激活 的相关知识: [1]远程方法中的参数和返回值 ...

  5. java分布式对象(RMI+部署使用RMI的程序)

    [0]README 1)本文文字转自 core java volume 2, 旨在学习 java 分布式对象的相关知识: 2) RMI 的实例程序为原创: 3) RMI部署步骤的测试用例,参见 htt ...

  6. Java分布式篇6——RabbitMQ

    Java分布式篇6--RabbitMQ 1.MQ(Message Queue)消息队列 消息队列中间件,是分布式系统中的重要组件 主要解决,异步处理,应用解耦,流量削峰等问题 实现高性能,高可用,可伸 ...

  7. Java分布式篇5——FastDFS

    Java分布式篇5--FastDFS 分布式文件系统 1.主流的分布式文件系统 1.1. HDFS (Hadoop Distributed File System)Hadoop 分布式文件系统 高容错 ...

  8. Java分布式篇4——Redis

    Java分布式篇4--Redis 1.互联网架构的演变历程 1.1.第一阶段 数据访问量不大,简单的架构即可搞定! 1.2.第二阶段 数据访问量大,使用缓存技术来缓解数据库的压力 不同的业务访问不同的 ...

  9. JAVA分布式篇3——Dubbo

    JAVA分布式篇3--Dubbo 1.架构演变 1.1.单应用架构 当网站流量很小时,只需要一个应用,将所有的功能部署到一起(所有业务都放在一个tomcat 里),从而减少部署节点和成本 用于简化 增 ...

  10. JAVA分布式篇2——Zookeeper

    JAVA分布式篇2--Zookeeper 1.简介 Zookeeper是一个开源的分布式(多台服务器干一件事)的,为分布式应用提供协调服务的 Apache项目 2.工作机制 Zookeeper从设计模 ...

最新文章

  1. 通过示波器数据进行正弦信号参数估计
  2. 设置session失效的几种方法
  3. 底部菜单_css实现移动端底部导航菜单隆起效果
  4. MySQL中获取天、周、月等数据
  5. SAP SD数据库表一览
  6. 在关于测试高速光纤链路的BICSI会前研讨会上获得3个CEC
  7. Linux和Windows下查看、设置环境变量的比较
  8. ora-00119和ora-00132解决方案
  9. jvisualvm插件安装
  10. 股票软件c++源代码
  11. 地震数据的获取与处理
  12. PICKIT3与ICD2比较。正在等待PICKIT3到货。
  13. MATLAB ttest和ttest2
  14. 分布式架构中的八大谬误
  15. 广播动态注册和静态注册的区别
  16. 以太坊Dapp通过web3js部署调用智能合约
  17. 联考素描头像怎么才能画到高分?联考新手必看!
  18. 【惊呼】微信最多可以加多少好友,真正原因可能出乎你的想象!
  19. 吃肉的时候一桌人,洗碗的时候一个人,这个世界,总有一些没良心的人,吃肉的时候夸肉香,洗碗的时候嫌碗脏;
  20. 小飞鱼通达二开 ERP发送通达OA消息接口开发(图文)

热门文章

  1. U-Boot源码之串口驱动
  2. 学生DW网页设计作业成品——电商购物网站设计(55页) 电商网页设计制作 简单静态HTML网页作品 购物网页作业成品 学生商城网站模板
  3. sql casewhen
  4. flexbuilder 4.6破解
  5. 计算机语言栏不能添加,电脑电脑输入法添加不了怎么办
  6. python爬取谷歌图片_Python 爬取谷歌街景图片
  7. C++视频分解和图片合成视频代码
  8. WebService框架简介
  9. ProCAD.2D/3D.Designer.v2008.1 1CD(最大程度地提高管道设计效率)\
  10. Protel 99 SE库文件添加时“file is not recognized”