分布式面试题

2023-09-20 16:56:11


前言

  1. 大型网站系统的特点
  2. 拆分 VS 集群
  3. 微服务 VS SOA
  4. 前后端完全分离与Rest规范

一、大型网站系统的特点

高并发,大流量
需要面对高并发用户,大流量访问。Google 日均 PV 35 亿,日 IP 访问数 3 亿;腾讯 QQ 的最大在线用户数 1.4 亿(2011年数据)。
高可用
系统 7 x 24 小时不间断服务。
海量数据
需要存储、管理海量数据,需要使用大量服务器。Facebook 每周上传的照片数量接近 10 亿,百度收录的网页数目有数百亿,Google 有近百万台服务器为全球用户提供服务。
用户分布广泛,网络情况复杂
许多大型互联网站都是为全球用户提供服务的,用户分布范围广,各地网络情况千差万别。在国内,还有各个运营商网络互通难的问题。
安全环境恶劣
由于互联网的开放性,使得互联网站更容易受到攻击,大型网站几乎每天都会被黑客攻击。
需求快速变更,发布频繁
和传统软件的版本发布频率不同,互联网产品为快速适应市场,满足用户需求,其产品发布频率极高。一般大型网站的产品每周都有新版本发布上线,中小型网站的发布更频繁,有时候一天会发布几十次。
渐进式发展
几乎所有的大型互联网网站都是从一个小网站开始,渐进地发展起来的。Facebook 是扎克伯格同学在哈佛大学的宿舍里开发的;Google 的第一台服务器部署在斯坦福大学的实验室;阿里巴巴是在马云家的客厅诞生的。好的互联网产品都是慢慢运营出来的,不是一开始就开发好的,这也正好与网站架构的发展演化过程对应。


二、拆分 VS 集群

  1. 拆分:不同的多台服务器上面部署不同的服务模块,模块之间通过RPC通信和调用,用于拆分业务功能,独立
    部署,多个服务器共同组成一个整体对外提供服务。
  2. 集群:不同的多台服务器上面部署相同的服务模块,通过分布式调度软件进行统一的调度,用于分流容灾,
    降低单个服务器的访问压力

三、微服务 VS SOA

创始人:martin fowler https://martinfowler.com/articles/microservices.html
单体应用:ALL IN ONE
微服务是一种架构风格,一个大型复杂软件应用由一个或多个微服务组成。系统中的各个微服务可被独立部署,各个微服务之间是松耦合的。每个微服务仅关注于完成一件任务并很好地完成该任务。在所有情况下,每个任务代表着一个小的业务能力
微服务,从本质意义上看,还是 SOA 架构。但内涵有所不同,微服务并不绑定某种特殊的技术,在一个微服务的系统中,可以有 Java 编写的服务,也可以有 Python编写的服务,他们是靠Restful架构风格统一成一个系统的。所以微服务本身与具体技术实现无关,扩展性强


四、前后端完全分离与Rest规范

http是目前在互联网上使用最多的协议,没有之一。可是http的创始人一直都觉得,在过去10几年来,所有的人都在错误的使用Http。
这句话怎么说呢?如果说你要删除一个数据,以往的做法通常是 delete/{id},如果你要更新一个数据,可能是Post
数据放Body,然后方法是 update/{id}, 或者是artichle/{id}?method=update。
这种做法让我很暴燥,我觉得这个世界不该这样的,所有的人都在误解而且在严重错误的误解Http的设计初衷,好比是发明了火药却只用它来做烟花爆竹。
那么正确的使用方式是什么呢?如果你要看Rest各种特性,你恐怕真的很难理解Rest,但是如果你看错误的使用http的人倒底儿了哪些错,什么是Rest就特别容易理解了。
第一条,混乱。一万个人心里有一万个Url的命名规则,Url是统一资源定位符,重点是资源。而很多人却把它当成了万金油,每一个独立的虚拟的网页都可以随意使用,各种操作都能够迭加。这是混乱的来源之一。
第二条,贪婪。有状态和无状态全部混在一起。特别是在购物车或者是登录的应用中,经常刷新就丢失带来的用户体验简直棒棒哒。每一个请求并不能单独的响应一些功能,很多的功能混杂在一起里。这是人性贪婪的本质,也是各种Hack的起源,只要能够把问题解决掉,总会有人用他认为最方便的方式去解决问题,比如说汽车门把手坏掉了直接系根绳子当把手,emmmm这样确实很棒啊。
第三条,无序。返回的结果往往是很随意,各种错误信息本来就是用Http的状态码构成的,可是很多人还是喜欢把错误信息返回在返回值中。最常见的就是Code和Message,当然对于这一点,我个人是保留疑问的,我的观点是,Http本身的错误和服务器的内部错误还是需要在不断层面分开的,不能混在一起。可是在大神眼里并非如此,这个再议。


总结

  1. 大型网站系统的特点
  2. 拆分 VS 集群
  3. 微服务 VS SOA
  4. 前后端完全分离与Rest规范
更多推荐

三维展示技术让未来项目更加裸眼3D可视化展示在观众面前

三维展示系统分为三维虚拟模型和三维实体模型,三维虚拟模型多为软件制图和后期成像进行展示供人们观赏,三维实体模型为采用各种可塑性材料根据三维虚拟模型制作出的实物,相比三维虚拟模型,三维实体模型更具有收藏与展示的价值,三维实体模型可用于楼盘展示,车型展示与人物艺术展示。现有技术中三维实体模型中的三维模型展示只有简单的保护罩

云原生Kubernetes:K8S存储卷

目录一、理论1.存储卷2.emptyDir存储卷3.hostPath卷4.NFS共享存储二、实验1.emptyDir存储卷2.hostPath卷3.NFS共享存储三、问题1.生成pod一直pending四、总结一、理论1.存储卷(1)概念容器磁盘上的文件的生命周期是短暂的,这就使得在容器中运行重要应用时会出现一些问题。

[2023.09.13]: Rust Lang,避不开的所有权问题

Rust的所有权问题,在我学Rust的时候就跳过了,因为我知道这玩意儿没有场景就不好理解。没想到场景很快就出现了。在开发Yew应用组件的时候,涉及到了事件,闭包,自然就引出了所有权问题。话不多说,下面让我们直接进入代码场景,去体验并了解Rust的所有权机制吧。下面这段代码是能够正常工作的。这段代码的逻辑意图也很简单,这

Linux MQTT智能家居项目(网络基础知识)

文章目录前言一、IP和端口的作用1.IP2.端口二、路由器的转发作用三、MQTT概念总结前言本篇文章带大家来做一个LinuxMQTT智能家居项目,这个项目将会讲解到网络的基础知识和MQTT协议一些相关的知识。一、IP和端口的作用1.IPIP(InternetProtocol):IP是一种网络层协议,它负责在互联网中标识

Redis 面试题

Redis面试题Q:Redis有哪些优势?速度快,因为数据存在内存中支持丰富数据类型,支持string,list,set,sortedset,hash支持事务,操作都是原子性,所谓的原子性就是对数据的更改要么全部执行,要么全部不执行丰富的特性:可用于缓存,消息,按key设置过期时间,过期后将会自动删除单线程,单进程,采

机器学习(17)---支持向量机(SVM)

支持向量机一、概述1.1介绍1.2工作原理1.3三层理解二、sklearn.svm.SVC2.1查看数据集2.2contour函数2.3画决策边界:制作网格2.4建模画图三、非线性情况推广3.1查看数据集3.2线性画图3.3为非线性数据增加维度并绘制3D图像四、核函数一、概述1.1介绍1.支持向量机(SVM,也称为支持

【新版】系统架构设计师 - 案例分析 - 数据库设计

个人总结,仅供参考,欢迎加好友一起讨论文章目录架构-案例分析-数据库设计数据库基础数据库设计概述E-R模型概念结构设计逻辑结构设计规范化(范式)反规范化技术数据库事务并发控制索引视图物化视图存储过程触发器数据库性能优化分布式数据库系统分布式数据库特点分布透明性两阶段提交协议2PC分区分表分库分区技术数据库主从复制步骤b

Jumia、Shein流量逐渐上升,测评自养号如何实现订单突破?

Jumia是全球领先的非洲跨境电商平台,也是非洲第一家在美国主板上市的非洲科技企业。作为100%面向非洲市场的互联网公司,业务范围覆盖尼日利亚、肯尼亚等11个非洲国家。Shein是一家全球领先的时尚和生活方式在线零售商,通过按需生产的模式赋能供应商共同打造敏捷柔性供应链,从而减少浪费,并向全球消费者提供丰富且具有性价比

分布式锁的三种实现方式!

分布式锁是一种用于保证分布式系统中多个进程或线程同步访问共享资源的技术。同时它又是面试中的常见问题,所以我们本文就重点来看分布式锁的具体实现(含实现代码)。在分布式系统中,由于各个节点之间的网络通信延迟、故障等原因,可能会导致数据不一致的问题。分布式锁通过协调多个节点的行为,保证在任何时刻只有一个节点可以访问共享资源,

IntelliJ IDEA 2023.2新特性详解第二弹!

4性能分析器4.1从Run(运行)工具窗口使用分析功能2023.2中,可直接从Run(运行)工具窗口轻松访问IntelliJ分析器的功能。使用新按钮,点击即可调用:AttachIntelliJProfiler(附加IntelliJ分析器)CaptureMemorySnapshot(捕获内存快照)无需打开Profiler

IntelliJ IDEA 2023.2 主要更新了什么?(纯文本介绍版)

🌷🍁博主猫头虎带您GotoNewWorld.✨🍁🦄博客首页——猫头虎的博客🎐🐳《面试题大全专栏》文章图文并茂🦕生动形象🦖简单易学!欢迎大家来踩踩~🌺🌊《IDEA开发秘籍专栏》学会IDEA常用操作,工作效率翻倍~💐🌊《100天精通Golang(基础入门篇)》学会Golang语言,畅玩云原生,走遍大

热文推荐