java面试题网

普通会员

72

帖子

7

回复

31

积分

楼主
发表于 2018-04-19 17:48:38 | 查看: 5042| 回复: 0

对Java分布式架构的理解

所谓分布式,无非就是”将一个系统拆分成多个子系统并散布到不同设备“的过程而已。

本质上而言,实现一个分布式系统,最核心的部分无非有两点:

如何拆分——可以有很多方式,核心依据一是业务需求,二是成本限制。这是实践中构建分布式系统时最主要的设计依据。

如何连接——光把系统拆开成 Process 还不够,关键是拆开后的 Process 之间还要能通信,因此涉及通信协议设计的问题,需要考虑的因素很多,好消息是这部分其实成熟方案很多。


三步变成分布式

  1. 1、将你的整个软件视为一个系统(不管它有多复杂)

  2. 2、将整个系统分割为一系列的 Process(进程), 每个 Process 完成一定的功能

  3. 3、将这些 Process 分散到不同的机器上。分散后,选择若干种(没错一种可能不够)通信协议把他们连接起来


分布式不等于并行计算

分布式系统和并行计算一定可以并行吗?实际上并不一定,这是很多人在认识上的误区。

拆分+链接是分布式系统的本质


分布式的作用

  1. 扩展性能。系统负载高,单台机器无法承载,希望通过多台机器来提高系统地负载能力,这个时候分布式就可以发挥作用了。

  2. 增强可靠性。软件,网络,机器随时都可能会出错,为了避免故障,需要将业务分散开。增强可靠性。

实现分布不难,难的在于如何选择正确分布方案

通常会有很多种分布方案摆在你面前,为了正确解决问题,你需要对每一种方案进行了解,评估,从而选择最大程度符合需求的方案。
选择不同的方案,有时对整个系统影响不大,有时会影响系统其他部分的工作方式甚至用户界面中用户操作的流程。


分布式入门学习主要包括以下知识点:

  1. Process(进程)。进程是分布式系统中的基本单元。

  2. 通信协议。进程间需要配合来完成工作,所以通信协议就成为了最基本要解决的问题。这部分涉及面很广,但是核心就有两点:一是存在哪些需求;二是各协议如何满足这些需求;

  3. 协作。为什么要通信?因为要协作,协作最基本的问题是同步问题,而聊同步问题就会聊到“锁”,这里又包括了锁的实现,加锁,解锁等问题,这里就不一一展开了;

  4. 命名法。通信当然需要有名字称呼,就像人和人之间的交流一样,所以进程需要有名字,可以是数字,也可以是结构化的符串;

了解了这些就算入门了,如果要进阶,就需要接着了解下面的知识点:

1、一致性。数据存储时最基本的问题。

2、容错。冗余是容错的基础,但并不是全部,分布式本身为实现容错提供了一些便利,这也是设计系统时常常需要考虑的问题。


分布式学习书单

《大型分布式网站架构设计与实践》

《大型网站技术架构:核心原理与案例分析》

《大型网站系统与Java中间件实践》

《分布式Java应用:基础与实践》

《分布式Java应用:基础与实践》


必须会的分布式缓存框架

1、Ehcache – Java分布式缓存框架

Ehcache是一个Java实现的开源分布式缓存框架,EhCache 可以有效地减轻数据库的负载,可以让数据保存在不同服务器的内

存中,在需要数据的时候可以快速存取。

2、Voldemort – 基于键-值(key-value)的缓存框架

Voldemort是一款基于Java开发的分布式键-值缓存系统,像JBossCache一样,Voldemort同样支持多台服务器之间的缓存同步

,以增强系统的可靠性和读取性能。

3、JBoss Cache – 基于事物的Java缓存框架

JBoss Cache是一款基于Java的事务处理缓存系统,它的目标是构建一个以Java框架为基础的集群解决方案,可以是服务器应

用,也可以是Java SE应用。

4、Cacheonix – 高性能Java分布式缓存系统

Cacheonix同样也是一个基于Java的分布式集群缓存系统,它同样可以帮助你实现分布式缓存的部署。

5、ASimpleCache – 轻量级Android缓存框架

ASimpleCache是一款基于Android的轻量级缓存框架,它只有一个Java文件,ASimpleCache基本可以缓存常用的Android对象

,包括普通字符串、JSON对象、经过序列化的Java对象、字节数组等。





文章来自www.wityx.com,转载请注明出处!原文地址http://www.wityx.com/post/375_1_1.html

超级管理员"admin"于2019-05-30 21:01:16将帖子设置精华1
您需要登录后才可以回帖 登录 | 立即注册

java面试题网www.wuliaokankan.cnjava建站系统提供技术支持V2.1 网站地图 © 2016-2018