前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >专栏 >笔记 | 大型网站的特点与设计宗旨

笔记 | 大型网站的特点与设计宗旨

作者头像
阿凯
发布于 2019-11-10 15:20:02
发布于 2019-11-10 15:20:02
7152
举报
文章被收录于专栏:程序员阿凯程序员阿凯

阅读文本大概需要 4 分钟。

大型网站的9大特点

1. 高并发,流量大 2. 高可用 3. 大数据 4. 敏捷开发,迭代快 5. 用户量庞大 6. 可持续升级 7. 安全级别高 8. 可弹性伸缩 9. 吞吐量高


高并发,流量大 网站的请求量大:

  • 百度日均访问量50亿+;
  • QQ早就突破1亿用户同时在线;
  • 淘宝双十一惊人的并发量

高可用

假设服务器宕机了,用户就无法访问 我们就必须保证网站稳定的向用户提供7*24小时不间断的服务 哪怕有服务器节点宕机了,依然用备用集确保服务正常访问

大数据

通过大量服务器已经存储系统管理海量数据

敏捷开发,迭代快

需求快速变更,发布频繁 提高用户体验,优化各种操作,形形色色的需求快速迭代, 一般大型网站,1~2周迭代一次,中小型网站发布更为频繁

用户量庞大

用户分布广,分散的用户个体,分布在全国(全球)各地 网络情况复杂,各大运营商网络互通困难

可持续升级

所有的大型网站都是从小网站,一步一步从初创不断发展到今天 逐步演变,单体,集群,分布式,微服务,

安全级别高

互联网的开放性,使得更容易受到攻击 树大招风,你越牛X,就愈会有黑客和同行来攻击你 服务器安全漏洞,后台代码判断,API接口暴露,可执行脚本上传….

可弹性伸缩

服务器可以动态的增加,不需要的时候可以适当的减少

吞吐量高

要保证用户每次的请求响应速度是最快的

大型网站的设计宗旨

合久必分 缓存和页面静态化 集群 CDN 分布式系统 异步 NoSQL 数据库优化

合久必分

  • 分层是最常见的架构模式 MVC,便于代码的解耦和工作的合理分配
  • 应用和静态资源分离 将图片,视频,css,js等资源文件,放置到专门的服务器上。通过专门的域名去访问 存放静态资源的服务器,一般都使用Nginx提供反向代理,理论上单个Nginx可以承受5万并发
  • 业务分离 分类各个业务模块,独立出一个子系统或子服务

缓存和页面静态化

  • 缓存是数据量大最直接的解决方案。

缓存可以在第一次获取数据的时候创建,也可以在程序启动和缓存失效之后立即创建。

  • 内存缓存:主要是 ConcurrentHashMap
  • 缓存框架:常用的有Ehcache,Memcache和redis等。

  • 页面静态化,原理跟缓存非常类似。

缓存是保存数据,而页面静态化是保存带数据的页面。

使用模板技术生成,如 thymeleaf,freemaker等。

集群

  • 高可用和负载均衡的手段
  • 多台服务器部署相同的应用构成一个集群
  • 保证负载均衡的同时提升系统的可用性,互相灾备

CDN

  • 集群页面缓存服务器,每个节点直接返回缓存的页面
  • 网站发展到很庞大的时候,用户分散全国各地
  • 采用CDN,用户可以访问到最近的服务节点(联通,电信,北京,上海)

分布式系统

  • 多系统,多模块,多中间件,多服务器共同协作整合的一个整体
  • 将不同的业务放到不同的服务器中,处理一个请求可能用到多台服务器
  • 分布式架构,分布式文件系统分布式数据库,分布式锁,分布式事务,分布式配置,分布式限流,日志收集

异步

  • 异步解耦,生产者和消费者,消息队列
  • 在高并发时进行流量削峰
  • 批量读取 与 延迟修改

NoSQL

  • NoSQL在处理海量数据的速度效率都是关系型数据库无法匹敌的。
  • 并且他的灵活性使网站的伸缩性得以很好的保证

数据库优化

  • 数据备份 - 定期为数据库做好冷热备份,不能因为节点宕机而导致数据丢失
  • 表结构优化 - 通过引擎,字段的选择
  • SQL语句优化 - 记录,分析,查找,优化
  • 索引优化 - 提升查询速度,也降低了增删改的效率
  • 分区 - 分区后,表面上还是一张表,但数据散列到多个位置了
  • 分表 - 子表,将一个大表按照一定的规则,分解成多张具有独立存储空间的实体表
  • 做好主从,读写分离,高可用……
本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2019-11-06,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 程序员阿凯 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
2 条评论
热度
最新
路过学习
路过学习
回复回复点赞举报
学习了,感谢分享
学习了,感谢分享
回复回复点赞举报
推荐阅读
编辑精选文章
换一批
javaScript 函数节流
什么是javascript函数节流?从其字面意思可以大概猜到是一种为提升函数调用执行性能的一种方法。javascript函数节流就是针对调用频率高的函数,通过设置定时器,使其在执行后间隔一段时间,才进行下一次的执行,避免重复频繁的调用导致的浏览器性能以及ajax重复调用问题。 函数节流的经典应用场景:onresize,scroll,mousemove ,mousehover等事件回调函数的无间断执行。其主要实现思路就是通过setTimeout定时器,通过设置缓冲时间,在第一次调用时,创建定时器,并在定时时间
用户1097444
2022/06/29
4890
javaScript 函数节流
节流函数和防抖函数的注意事项
关于防抖和节流函数的详细分析请看以下两篇文章,此处不再重述,本文章主要讲述运用过程中出现的问题
IT人一直在路上
2019/09/18
7420
javaScript 函数节流
IMWeb前端团队
2018/01/08
9340
javaScript 函数节流
函数去抖(debounce)& 函数节流(throttle)总结
让某个函数在一定 事件间隔条件(去抖debounce) 或 时间间隔条件(节流throttle) 下才会去执行,避免快速多次执行函数(操作DOM,加载资源等等)给内存带来大量的消耗从而一定程度上降低性能问题。
全栈程序员站长
2022/09/06
2.6K0
函数去抖(debounce)& 函数节流(throttle)总结
JavaScript 高频函数优化-函数防抖&函数节流
什么是高频函数? oninput(实时获取输入的数据) onscroll(监听页面的滚动) onresize(监听浏览器可视区域的变化) onmousemove(移动端监听手指在屏幕的滑动) 什么是函
前端小tips
2021/11/24
3700
JavaScript 高频函数优化-函数防抖&函数节流
函数节流与函数防抖
函数节流与函数防抖的目的都是为了减少用户对服务器不必要的请求次数,以此提高服务器性能的函数。节流是在一段时间内,只向服务器请求一次。防抖则是在频繁触发相同请求时,若任务之间间隔小于指定时间,那么只会执行最后一次请求。
_kyle
2020/08/22
5370
JavaScript函数节流和函数防抖之间的区别
函数节流和函数防抖,两者都是优化高频率执行js代码的一种手段。  大家大概都知道旧款电视机的工作原理,就是一行行得扫描出色彩到屏幕上,然后组成一张张图片。由于肉眼只能分辨出一定频率的变化,当高频率的扫描,人类是感觉不出来的。反而形成一种视觉效果,就是一张图。就像高速旋转的风扇,你看不到扇叶,只看到了一个圆一样。  同理,可以类推到js代码。在一定时间内,代码执行的次数不一定要非常多。达到一定频率就足够了。因为跑得越多,带来的效果也是一样。倒不如,把js代码的执行次数控制在合理的范围。既能节省浏览器CPU资源,又能让页面浏览更加顺畅,不会因为js的执行而发生卡顿。这就是函数节流和函数防抖要做的事。
我是leon
2019/08/28
1.1K0
JavaScript函数节流和函数防抖之间的区别
JS函数节流和函数防抖
之所以返回一个函数,因为防抖本身更像是一个函数修饰,所以就做了一次函数柯里化。里面也用到了闭包,闭包的变量是timer。
用户1437675
2019/07/19
1.1K0
【JS】javaScript 函数节流
什么是javascript函数节流?从其字面意思可以大概猜到是一种为提升函数调用执行性能的一种方法。javascript函数节流就是针对调用频率高的函数,通过设置定时器,使其在执行后间隔一段时间,才进行下一次的执行,避免重复频繁的调用导致的浏览器性能以及ajax重复调用问题。
Ning@
2021/11/10
1.1K0
谈谈JS中的函数节流
好吧,一直在秋招中,都没怎么写博客了。。。今天赶紧来补一补才行。。。我发现,在面试中,讲到函数节流好像可以加分,尽管这并不是特别高深的技术,下面就聊聊吧! ^_^ 备注:以下内容部分来自《JavaScript高级程序设计》 函数节流的目的 从字面上就可以理解,函数节流就是用来节流函数从而一定程度上优化性能的。例如,DOM 操作比起非DOM 交互需要更多的内存和CPU时间。连续尝试进行过多的DOM 相关操作可能会导致浏览器挂起,有时候甚至会崩溃。尤其在IE 中使用onresize 事件处理程序的时候容易发生,
用户1667431
2018/04/18
1.5K0
谈谈JS中的函数节流
javascript函数防抖节流,适用于搜索多次触发请求等场景。
可以看到,我们只要输入一个字符,就会触发这次ajax请求。不仅从资源上来说是很浪费的行为,而且实际应用中,用户也是输出完整的字符后,才会请求。下面我们优化一下:
江一铭
2022/06/17
1.2K0
javascript函数防抖节流,适用于搜索多次触发请求等场景。
JavaScript中的函数防抖与函数节流
函数防抖(debounce)当调用动作过n毫秒后,才会执行该动作,若在这n毫秒内又调用此动作则将重新计算执行时间。
刘亦枫
2020/03/19
5880
JavaScript网页性能优化(函数防抖与函数节流)
b.输入框事件:验证手机号或者邮箱,用户输入时不断触发键盘事件,应该等用户结束输入之后,以最后一次输入为准
帅的一麻皮
2020/05/16
1.4K0
函数节流
函数节流的定义: 规定的单位时间内只执行一次,如果在单位时间内执行了多次,那么最后也只会执行一次。
用户4344670
2020/06/28
5910
大厂高频面试精选
key 的作用是为了在 diff 算法执行时更快的找到对应的节点,提高 diff 速度。
grain先森
2019/03/28
8110
大厂高频面试精选
js中的防抖和节流
原理:设置一个定时器,如果在设定的时间间隔内事件再次触发,就会清除上一次的定时器并重新设置和计时,直到指定时间间隔内没有再次触发,才会执行函数
前端小tips
2021/11/24
1.6K0
js中的防抖和节流
JavaScript防抖节流
f1保存的是return function(){console.log(n)}这个匿名函数所在堆地址的引用,并不是赋值。
ymktchic
2022/01/18
5160
JavaScript防抖节流
微信小程序 函数防抖和函数节流
函数节流是减少函数的触发频率;函数防抖是延迟函数执行,且不管触发多少次都只执行最后一次
peng_tianyu
2022/12/15
1.4K0
简单复习下什么是JavaScript的防抖和节流
使用场景:click、onMouseOver,onMouseMove,resize,input,scroll等
前端达人
2021/06/16
5160
带你“深入”节流
比如说吃饭。吃饭说明规定,五个小时吃一次。吃了一次饭,小狗蹦蹦哒哒地玩了五个小时。五个小时一到, 小狗再回来吃饭。依次类推,每五小时回来吃一次饭。
ClyingDeng
2023/03/04
7040
带你“深入”节流
相关推荐
javaScript 函数节流
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
查看详情【社区公告】 技术创作特训营有奖征文