大型网站架构设计学习笔记 1

挑战与架构目标

大型网站的主要挑战是:大容量(请求量大/数据量大[海量数据])、高并发(峰值并发大)、高可用(724业务不中断)、强安全*!!!

  • 高可用:availability;永不停机,一直可用、可正常使用,特殊情况下部分关键功能可用、或功能的主要能力可用!站在系统角度,部分客户可用!特殊情况不可用了,要能快速恢复可用!

    • 灾备、集群、分中心&分区隔离保障
    • 降级、限流、熔断
    • 灰度发布
  • 高性能:performance;系统响应(低时延)、吞吐量(同等资源下支持并发请求多)

    • 缓存、分布式&集群(分区/分表/分片/分库、集群&无状态)、异步
    • 算法
    • 可扩展
  • 强安全:security;数据无泄露、隐私被保护、攻击能防住、操作有审计

    • 网络安全、系统安全、应用安全
  • 可扩展:scalability;XYZ扩展;

  • 易伸缩:?

熔断(服务级、网关)

  1. 熔断指当系统中的某个服务出现异常,如调用超时不可用时,熔断对该服务的调用、并且后续调用直接返回,待该服务恢复后再恢复调用的机制。

    • 如5秒内20次调用失败即启动熔断机制
    • 每隔5秒放通部分调用,如果服务恢复正常则恢复所有调用
  2. 熔断是系统异常情况下的一种自动保护机制,防止系统雪崩。熔断由系统实时检测,满足条件自动触发。

    • 扇出:A调B、调C,B和C又调其他服务
    • 雪崩:如果扇出的链路上某个微服务的调用响应时间过长或者不可用,对微服务A的调用就会占用越来越多的系统资源,进而引起系统崩溃,即所谓的“雪崩效应”。
  3. 主要特征:

    • 框架级实现,每个微服务都需要
    • 系统自动检测、自动触发执行、自动恢复
    • 熔断一般是某个服务故障引起

降级

  1. 指在特殊场景下(系统资源有限、处理能力不足等),主动降低业务(页面)或服务的功能范围,对非核心关键功能停止提供,如页面的某些功能(如商品详情页的评论记录只返回10条、库存不再实时查询等)或服务的某些能力,以保证核心关键部分功能可用的策略。

  2. 降级通常由人工手动触发(配置开关支持),相应方案需要针对性设计,并通常具有代码侵入性

  3. 主要特征:

    • 人工触发执行与恢复
    • 针对性的方案设计,代码侵入性
    • 对业务由层级之分,从最外围服务开始降级
    • 降级一般是从整体负荷考虑

限流

  1. 指对目标系统、服务、节点(如网关)、资源(如数据库、缓存)限制请求流量,以保护其正常可靠运行的机制。

  2. 限流通过对并发访问/请求进行限速或者一个时间窗口内的的请求进行限速来保护系统,一旦达到限制速率则可以拒绝服务(定向到错误页或告知资源没有了)、排队或等待(比如秒杀、评论、下单)、降级(返回兜底数据或默认数据,如商品详情页库存默认有货)。

  3. 一般开发高并发系统常见的限流有:限制总并发数(比如数据库连接池、线程池)、限制瞬时并发数(如nginx的limit_conn模块,用来限制瞬时并发连接数)、限制时间窗口内的平均速率(如Guava的RateLimiter、nginx的limit_req模块,限制每秒的平均速率);其他还有如限制远程接口调用速率、限制MQ的消费速率。另外还可以根据网络连接数、网络流量、CPU或内存负载等来限流。

  4. 常见限流算法:漏桶、令牌桶。

注:有些场景并不能用缓存和降级来解决,比如稀缺资源(秒杀、抢购)、写服务(如评论、下单)、频繁的复杂查询(评论的最后几页),因此需有一种手段来限制这些场景的并发/请求量,即限流。

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

推荐阅读更多精彩内容