到底什么是分布式系统?

分布式系统背景

说分布式系统必须要说集中式系统,集中式系统中整个项目就是一个独立的应用,整个应用也就是整个项目,所有的东西都在一个应用里面。

如下图所示

image.png

如一个网站就是一个应用,最后是多个增加多台服务器或者多个容器来达到负载均衡的避免单点故障的目的,当然,数据库是可以分开部署的。

集中式很明显的优点就是开发测试运维会比较方便,不用为考虑复杂的分布式环境。

集中式很明显的弊端就是不易扩展,每次更新都必须更新所有的应用。而且,一个有问题意味着所有的应用都有问题。当系统越来越大,集中式将是系统最大的瓶颈。

什么是分布式系统?

分布式系统是若干独立计算机的集合,这计算机对用户来说就像单个相关系统。

以上定义摘自<<分布式系统原理与范型>>一书。

也就是说分布式系统背后是由一系列的计算机组成的,但用户感知不到背后的逻辑,就像访问单个计算机一样。

说的有点绕,我们可以来简单看下分布式系统图。

image.png

分布式系统利弊

在分布式系统中:

1、应用可以按业务类型拆分成多个应用,再按结构分成接口层、服务层;我们也可以按访问入口分,如移动端、PC端等定义不同的接口应用;

2、数据库可以按业务类型拆分成多个实例,还可以对单表进行分库分表;

3、增加分布式缓存、搜索、文件、消息队列、非关系型数据库等中间件;

很明显,分布式系统可以解决集中式不便扩展的弊端,我们可以很方便的在任何一个环节扩展应用,就算一个应用出现问题也不会影响到别的应用。

随着微服务Spring Cloud & Docker的大热,及国内开源分布式Dubbo框架的重生,分布式技术发展非常迅速。

分布式系统虽好,也带来了系统的复杂性,如分布式事务、分布式锁、分布式session、数据一致性等都是现在分布式系统中需要解决的难题,虽然已经有很多成熟的方案,但都不完美。分布式系统也增加了开发测试运维成本,工作量增加,分布式系统管理不好反而会变成一种负担。

如果你对分布式技术有更好的见解,或者对本文有异议,欢迎在下方留言。

推荐阅读


资料:成为架构师的十阶段学习资料!

教程:史上最强 Spring Boot & Cloud 教程汇总

工具:推荐一款在线创作流程图、思维导图软件

扫描关注我们的微信公众号,回复 “666” 可获取一套Java并发编程高清视频教程。

image

<p> <span style="font-size:16px;">本课程是一门具有很强实践性质的“项目实战”课程,即“</span><span style="font-size:16px;">企业中台系统实战</span><span style="font-size:16px;">”,其中主要包含三大块核心内容,如下图所示(右键可以在新标签页中打开图片放大查看):</span><span></span> </p> <p> <span style="font-size:16px;"><img src="https://img-bss.csdn.net/201912071527496867.jpg" alt="" /><br /> </span> </p> <p style="text-align:center;"> <span style="font-size:16px;"></span> </p> <p> <span style="font-size:16px;">即主要包含以下三大块内容:</span><span><br /> <span style="font-size:16px;"> ① </span></span><span style="font-size:16px;">企业内部应用系统菜单资源和操作权限的统一管理;</span><span></span> </p> <p> <span style="font-size:16px;">② 分布式应用系统通信时的统一授权,即基于</span><span style="font-size:16px;">AccessToken</span><span style="font-size:16px;">的授权与认证;</span><span></span> </p> <p> <span style="font-size:16px;">③ 分布式服务</span><span style="font-size:16px;">/</span><span style="font-size:16px;">系统通信时的两大方式(基于</span><span style="font-size:16px;">dubbo rpc</span><span style="font-size:16px;">协议和基于</span><span style="font-size:16px;">http</span><span style="font-size:16px;">协议的</span><span style="font-size:16px;">restful api</span><span style="font-size:16px;">实战)。</span><span></span> </p> <p> <span style="font-size:16px;"> </span> </p> <p> <span style="font-size:16px;">值得一提的是,这套中台系统由于讲解了如何统一管理企业内部各大应用系统的“菜单资源列表”、“操作权限”,故而本门课程的“代码实战”是建立在之前</span><span style="font-size:16px;">debug</span><span style="font-size:16px;">录制的“企业权限管理平台”这套课程的基础之上的,故而在这里</span><span style="font-size:16px;">debug</span><span style="font-size:16px;">建议没有项目开发基础的小伙伴可以先去学习我的那套“企业权限管理平台”的实战课程,之后再来学习我的这套中台系统的实战才不会很吃力</span><span style="font-size:16px;">(</span><span style="font-size:16px;">课程链接:</span><span><a href="http://www.fightjava.com/web/index/course/detail/8"><span style="font-size:16px;"></span></a><span style="font-size:16px;">)</span></span> </p> <p> <span style="font-size:16px;"> </span> </p> <p> <span style="font-size:16px;">本课程的课程大纲如下图所示<span style="font-size:16px;">(右键可以在新标签页中打开图片放大查看)</span>:</span><span></span> </p> <p style="text-align:center;"> <img src="https://img-bss.csdn.net/201912071528406564.png" alt="" /> </p> <p> <span style="font-size:16px;"> </span> </p> <p> <span style="font-size:16px;">除此之外,这套“中台系统”由于统一管理了企业内部各大应用系统的“菜单资源和操作权限”以及“应用系统之间通信时的统一授权”,故而难免需要涉及到“中台系统”与“中台子系统”、“中台子系统”与“中台子系统”之间的通信(即分布式服务之间的通信),在这里我们是采用“</span><span style="font-size:16px;">dubbo + zookeeper</span><span style="font-size:16px;">”的方式加以落地实现的,详情如下图所示<span style="font-size:16px;">(右键可以在新标签页中打开图片放大查看)</span>:</span><span></span> </p> <p style="text-align:center;"> <img src="https://img-bss.csdn.net/201912071529091933.png" alt="" /> </p> <p> <span style="font-size:16px;"> </span> </p> <p> <span style="font-size:16px;">而众所周知,作为一款知名以及相当流行的分布式服务调度中间件</span><span style="font-size:16px;">,dubbo</span><span style="font-size:16px;">现如今已经晋升为</span><span style="font-size:16px;">Apache</span><span style="font-size:16px;">顶级的开源项目,未来也仍将成为“分布式系统”开发实战的一大利器,如下图所示为</span><span style="font-size:16px;">dubbo</span><span style="font-size:16px;">底层核心系统架构图<span style="font-size:16px;">(右键可以在新标签页中打开图片放大查看)</span>:</span><span></span> </p> <p style="text-align:center;"> <img src="https://img-bss.csdn.net/201912071529213194.png" alt="" /> </p> <p> <span style="font-size:16px;">而在这门“中台系统实战”的课程中,我们也将始终贯彻、落地</span><span style="font-size:16px;">dubbo</span><span style="font-size:16px;">的这一核心系统架构图,即如何将中台系统开发的服务注册</span><span style="font-size:16px;">/</span><span style="font-size:16px;">发布到注册中心</span><span style="font-size:16px;">zookeeper</span><span style="font-size:16px;">,中台子系统如何订阅</span><span style="font-size:16px;">/</span><span style="font-size:16px;">消费</span><span style="font-size:16px;">/</span><span style="font-size:16px;">调度中台系统发布在</span><span style="font-size:16px;">zookeeper</span><span style="font-size:16px;">的接口服务,中台子系统在走</span><span style="font-size:16px;">http</span><span style="font-size:16px;">协议调度通信时</span><span style="font-size:16px;">dubbo</span><span style="font-size:16px;">如何进行拦截、基于</span><span style="font-size:16px;">token</span><span style="font-size:16px;">认证接口的调用者等等,这些内容我们在课程中将一一得到代码层面的实战落地!</span><span></span> </p> <p> <span style="font-size:16px;"> </span> </p> <p> <span style="font-size:16px;">下图为本课程中涉及到的分布式系统</span><span style="font-size:16px;">/</span><span style="font-size:16px;">服务之间 采用“</span><span style="font-size:16px;">http</span><span style="font-size:16px;">协议</span><span style="font-size:16px;">restful api</span><span style="font-size:16px;">”方式通信时的</span><span style="font-size:16px;">Token</span><span style="font-size:16px;">授权、认证的流程图<span style="font-size:16px;">(右键可以在新标签页中打开图片放大查看)</span></span><span style="font-size:16px;">:</span> </p> <p style="text-align:center;"> <img src="https://img-bss.csdn.net/201912071529314254.png" alt="" /> </p> <p> <span style="font-size:16px;">而不夸张地说,</span><span style="font-size:16px;">基于</span><span style="font-size:16px;">AccessToken</span><span style="font-size:16px;">的授权、认证方式</span><span style="font-size:16px;">在现如今微服务、分布式时代系统与系统在通信期间最为常用的“授权方式”了,可想而知,掌握其中的流程思想是多么的重要!</span><span></span> </p> <p> <span style="font-size:16px;"> </span> </p> <p> <span style="font-size:16px;">以下为本门课程的部分截图<span style="font-size:16px;">(右键可以在新标签页中打开图片放大查看)</span>:</span><span></span> </p> <p style="text-align:center;"> <img src="https://img-bss.csdn.net/201912071529555340.png" alt="" /> </p> <p> <span style="font-size:16px;"> <img src="https://img-bss.csdn.net/201912071530115079.png" alt="" /></span> </p> <p> <span style="font-size:16px;"> <img src="https://img-bss.csdn.net/201912071530297642.png" alt="" /></span> </p> <p> <span style="font-size:16px;"><img src="https://img-bss.csdn.net/201912071530495573.png" alt="" /><br /> </span> </p> <p> <span style="font-size:16px;">核心技术列表</span><span style="font-size:16px;">:</span> </p> <p> <span style="font-size:16px;">值得一提的是,由于本门课程是一门真正介绍“中台思想”以及将“中台思想”和“分布式系统开发实战”相结合落地的课程,故而在学完本门课程之后,可以掌握到的核心技术自然是相当多的。主要由</span><span style="font-size:16px;">SpringBoot2.0</span><span style="font-size:16px;">、</span><span style="font-size:16px;">SpringMVC</span><span style="font-size:16px;">、</span><span style="font-size:16px;">Mybatis</span><span style="font-size:16px;">、</span><span style="font-size:16px;">Dubbo</span><span style="font-size:16px;">、</span><span style="font-size:16px;">ZooKeeper</span><span style="font-size:16px;">、</span><span style="font-size:16px;">Redis</span><span style="font-size:16px;">、</span><span style="font-size:16px;">OkHttp3</span><span style="font-size:16px;">、</span><span style="font-size:16px;">Guava-Retrying</span><span style="font-size:16px;">重试机制、</span><span style="font-size:16px;">JWT(Json Web Token)</span><span style="font-size:16px;">、</span><span style="font-size:16px;">Shiro</span><span style="font-size:16px;">、分布式集群</span><span style="font-size:16px;">session</span><span style="font-size:16px;">共享、</span><span style="font-size:16px;">Lombok</span><span style="font-size:16px;">、</span><span style="font-size:16px;">Stream API</span><span style="font-size:16px;">、</span><span style="font-size:16px;">Dubbo-Filter</span><span style="font-size:16px;">以及</span><span style="font-size:16px;">ServiceBean</span><span style="font-size:16px;">等等。如下图所示<span style="font-size:16px;">(右键可以在新标签页中打开图片放大查看)</span>:</span><span></span> </p> <img src="https://img-bss.csdn.net/201912071531014403.jpg" alt="" /><br />
相关推荐
©️2020 CSDN 皮肤主题: 大白 设计师:CSDN官方博客 返回首页