(2)弹力设计篇之“隔离设计”

概要:系统的分离有两种方式,以服务、以用户来做分离;隔离设计的重点:

一、按服务的种类来做分离

系统分成了用户、商品、社区三个版块。使用不同的域名、服务器和数据库,从接入层到应用层再到数据层三层完全隔离。每个服务都有自己的一个数据库,保存相关业务的数据和相应的处理状态。每个服务对外暴露。微服务所推荐的架构方式。

隔离存在以下一些问题:

1.调用多个服务(同时获得多个板块数据),会降低性能。性能指的是响应时间,而不是吞吐量(这种架构下,吞吐量可以得到提高)。所以不要在一个页面上获得所有的数据,好在手机页面小。

2.增加了数据合并的复杂度。需要一个框架、间件来对数据进行相应的抽取。

3.导致整体业务故障,如果业务流程跨版块的话,所以业务流程Step-by-Step 的方式,交互的每一步都可以保存,以便故障恢复后继续执行,而不是从头执行。

4.跨版块复杂。高可用并持久化的消息中间件(类似Pub/Sub),打通各个版块的数据和信息交换。

5.多版块分布式事务问题。采用“二阶段提交”方案。亚马逊使用的是 Plan – Reserve – Commit/Cancel 模式。也就是说,先做一个 plan 的 API 调用,各个子系统 reserve 住相应的资源,成功Commit;一个失败体 Cancel。很像阿里的 TCC – try confirm/cancel。引入大量的异步处理模型。

二·、按用户的请求来做分离

这样系统挂掉时,只影响一部分。

“多租户”模式:大客户,设置专门独立服务实例,或是服务集群与其他客户隔离开来,小用户,共享一个服务实例。

“多租户”架构来引入复杂度。完全隔离,资源浪费,共享,程序设计复杂。

多租户的做法有三种:

(1)完全独立的设计。每个租户有自己完全独立的服务和数据。

(2)独立的数据分区,共享的服务。多租户的服务是共享的,但数据是分开隔离的

(3)共享的服务,共享的数据分区。每个租户的数据和服务都是共享的。

这三种方案各有优缺点,如图所示。

在虚拟化技术非常成熟的今天,我们完全可以使用“完全独立”(完全隔离)的方案,通过底层的虚拟化技术(Hypervisor 的技术,如 KVM,或是 Linux Container 的技术,如Docker)来实现物理资源的共享和成本的节约。

三、隔离设计的重点:

定义好隔离业务的大小和粒度,不过大过小。业务上的需求和系统分析。

考虑系统的复杂度、成本、性能、资源使用的问题,无论是做系统版块还是多租户的隔离,定义好要什么和不要什么,一个合适的均衡方案/分布实施的方案尤其重要,。

配置高可用、重试、异步、消息中间件,流控、熔断等配套使用。

自动化运维的工具:使用像容器或是虚拟机更方便地管理

看到所有服务的监控系统

评论:

我们目前系统中采用隔离的点包括:

1、服务集群隔离,我们可以配置不同的请求访问不同的服务集群,我们通过服务别名来区分

2、数据存储隔离,包括数据库隔离、缓存集群隔离。数据库隔离一般通过分库分表,读写分离

3、线程池隔离,在同一个应用中,不同的任务处理通过线程池隔离

4、网络带宽隔离

隔离的本质是当系统出尽现故障时,将影响范围降到最低。

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,588评论 6 496
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,456评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,146评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,387评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,481评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,510评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,522评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,296评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,745评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,039评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,202评论 1 343
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,901评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,538评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,165评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,415评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,081评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,085评论 2 352

推荐阅读更多精彩内容

  • 关于Mongodb的全面总结 MongoDB的内部构造《MongoDB The Definitive Guide》...
    中v中阅读 31,916评论 2 89
  • 概念:微服务就是一些可独立运行、可协同工作的小的服务。微服务是现在特别流行的服务,微服务的字面意思是大家都很好理解...
    程序员技术圈阅读 3,341评论 2 47
  • 目录 ·大型网站软件系统的特点 ·大型网站架构演化发展历程 ·初始阶段的网站架构 ·需求/解决问题 ·架构 ·应用...
    zhyang0918阅读 2,652评论 0 16
  • 【0325能量按钮】 3344-施小施 推荐人:二连老铁进阶蜗牛 这是一部关于人性的6分钟短片《雇佣人生》,全片没...
    施小施阅读 205评论 0 1
  • 炎炎此夏,最美如你。 你是夏日初临时的一张照片,照片中有你湖水般澄澈的眼睛,时过境迁,那初逢时的感情会始终不变。还...
    白壁阅读 470评论 8 11