大型网站技术架构(二)架构模式

news/2024/5/16 23:04:06/文章来源:https://blog.csdn.net/weixin_34402090/article/details/92648287

2019独角兽企业重金招聘Python工程师标准>>> hot3.png

 每一个模式描述了一个在我们周围不断重复发生的问题及该问题解决方案的核心。这样,你就能一次又一次地使用该方案而不必做重复工作。

          所谓网站架构模式即为了解决大型网站面临的高并发访问、海量数据、高可靠运行灯一系列问题与挑战。为此,在实践中提出了许多解决方案,以实现网站高性能、高可靠性、易伸缩、可扩展、安全等各种技术架构目标。

1、分层

        分词是企业应用系统中最常见的一种架构牧师,将系统在横向维度上切分成几个部分,每个部分负责一部分相对简单并比较单一的职责,然后通过上层对下层的依赖和调度组成一个完整的系统。

        在网站的分层架构中,常见的为3层,即应用层、服务层、数据层。应用层具体负责业务和视图的展示;服务层为应用层提供服务支持;数据库提供数据存储访问服务,如数据库、缓存、文件、搜索引擎等。

       分层架构是逻辑上的,在物理部署上,三层架构可以部署在同一个物理机器上,但是随着网站业务的发展,必然需要对已经分层的模块分离部署,即三层结构分别部署在不同的服务器上,是网站拥有更多的计算资源以应对越来越多的用户访问。

      所以虽然分层架构模式最初的目的是规划软件清晰的逻辑结构以便于开发维护,但在网站的发展过程中,分层结构对网站支持高并发向分布式方向的发展至关重要

2、分隔

       如果说分层是将软件在横向方面进行切分,那么分隔就是在纵向方面对软件进行切分。

       网站越大,功能越复杂,服务和数据处理的种类也越多,将这些不同的功能和服务分隔开来,包装成高内聚低耦合的模块单元,不仅有助于软件的开发维护也便于不同模块的分布式部署,提高网站的并发处理能力和功能扩展能力。

      大型网站分隔的粒度可能会很小。比如在应用层,将不同业务进行分隔,例如将购物、论坛、搜索、广告分隔成不同的应用,有对立的团队负责,部署在不同的服务器上。

3、分布式

       对于大型网站,分层和分隔的一个主要目的是为了切分后的模块便于分布式部署,即将不同模块部署在不同的服务器上,通过远程调用协同工作。分布式意味着可以使用更多的计算机完同样的工作,计算机越多,CPU、内存、存储资源就越多,能过处理的并发访问和数据量就越大,进而能够为更多的用户提供服务。

       在网站应用中,常用的分布式方案有一下几种.

       分布式应用和服务:将分层和分隔后的应用和服务模块分布式部署,可以改善网站性能和并发性、加快开发和发布速度、减少数据库连接资源消耗。

       分布式静态资源:网站的静态资源如JS、CSS、Logo图片等资源对立分布式部署,并采用独立的域名,即人们常说的动静分离。静态资源分布式部署可以减轻应用服务器的负载压力;通过使用独立域名加快浏览器并发加载的速度。

       分布式数据和存储:大型网站需要处理以P为单位的海量数据,单台计算机无法提供如此大的存储空间,这些数据库需要分布式存储。

       分布式计算:目前网站普遍使用Hadoop和MapReduce分布式计算框架进行此类批处理计算,其特点是移动计算而不是移动数据,将计算程序分发到数据所在的位置以加速计算和分布式计算。

4、集群

       对于用户访问集中的模块需要将独立部署的服务器集群化,即多台服务器部署相同的应用构成一个集群,通过负载均衡设备共同对外提供服务。

       服务器集群能够为相同的服务提供更多的并发支持,因此当有更多的用户访问时,只需要向集群中加入新的机器即可;另外可以实现当其中的某台服务器发生故障时,可以通过负载均衡的失效转移机制将请求转移至集群中其他的服务器上,因此可以提高系统的可用性

5、缓存

       缓存目的就是减轻服务器的计算,使数据直接返回给用户。在现在的软件设计中,缓存已经无处不在。具体实现有CDN、反向代理、本地缓存、分布式缓存等。

       使用缓存有两个条件:访问数据热点不均衡,即某些频繁访问的数据需要放在缓存中;数据在某个时间段内有效,不过很快过期,否在会因为数据过期而脏读,影响数据的正确性。

6、异步

      使用异步,业务之间的消息传递不是同步调用,而是将一个业务操作分成多个阶段,每个阶段之间通过共享数据的方法异步执行进行协作。

      具体实现则在单一服务器内部可用通过多线程共享内存对了的方式处理;在分布式系统中可用通过分布式消息队列来实现异步。

      异步架构的典型就是生产者消费者方式,两者不存在直接调用。

7、冗余

      网站需要7×24小时连续运行,那么就得有相应的冗余机制,以防某台机器宕掉时无法访问,而冗余则可以通过部署至少两台服务器构成一个集群实现服务高可用。数据库除了定期备份还需要实现冷热备份。甚至可以在全球范围内部署灾备数据中心。

8、自动化

      具体有自动化发布过程,自动化代码管理、自动化测试、自动化安全检测、自动化部署、自动化监控、自动化报警、自动化失效转移、自动化失效恢复等。

9、安全

      网站在安全架构方面有许多模式:通过密码和手机校验码进行身份认证;登录、交易需要对网络通信进行加密;为了防止机器人程序滥用资源,需要使用验证码进行识别;对常见的XSS攻击、SQL注入需要编码转换;垃圾信息需要过滤等。

转载于:https://my.oschina.net/zhanghaiyang/blog/594281

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.luyixian.cn/news_show_725877.aspx

如若内容造成侵权/违法违规/事实不符,请联系dt猫网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

自己的网站实现windows live writer离线写博客

昨天在博客园看到可以用windows live writer离线来写博客,OMG!感觉微软真的太牛逼啦!偶孤陋寡闻,现在才知道有这么个好东东,那就赶紧在偶的网站上也实现一下吧 ps:偶的网站www.bantool.cn 额,感觉不错~呵呵…

高效网站记录1

高效网站记录1 一些能提高效率的网站 目录高效网站记录1网站文档格式转换online-convert迅捷PDF转换器笔记Nation百度脑图拾光分享网网站 文档格式转换online-convert online-convert 网站的一些功能 支持多种格式相互转换;没有很多网站的20MB文件大小限制&#…

seo_meta

根据w3c所定义,"meta标签允许html作者告诉来访的机器人文件是否可能索引,或来获取更多的链接。没有服务器管理员需要采取行动。" 主要的搜索引擎普遍指令: meta与robots.txt的区别: robots.txt是域级别的操作&#xf…

WordPress主题DUX6.3源码 多功能网站源码

介绍: 源码功能蛮多的 源码说明: 这里主要在现有的 DUX6.3 的基础上,除了集成之前版本的全部的功能外,额外新增加下面这些功能: 新增 WordPress 自带的文章密码保护美化页面新增 Share.js 集成到主题,替…

新版QQ秒强制聊天网站源码

介绍: 源码仅供技术参考,严禁商业用途! 输入对方QQ号即可聊天 网盘下载地址: http://kekewl.org/WTxzkyQhBjQ 图片:

汉字笔顺字帖在线生成器网站源码

介绍: 田字格笔顺生成,字帖生成器php版源码 ,共收录9574个常用汉字! 网盘下载地址: http://kekewl.cc/jlpEwT4f6x7 图片:

网站跳转其他页面PHP代码

介绍: 使用方法: 下载后将压缩包内go.php文件打开编辑 (把http://www.####.com链接改成自己的网站地址) 如何调用:你的网站域名/go.php/?url跳转到别人的网站地址 网盘下载地址: http://kekewl.net/K…

清新UI美化技术导航网网站源码

介绍: 【清新UI技术导航网美化网站源码】无后台直接上传你的任何空间服务器都可以使用 这款源码无后台,直接上传你的任何空间服务器都可以使用,打开HTML文件修改内容,做导航很不错! 网盘下载地址: http:/…

超好看的简洁导航网站模板

介绍: 今天我就分享自己在用的极简导航,也是模仿其他站的, 如有侵权可以联系删除! 功能:可换背景,可定义搜索 网盘下载地址: http://kekewl.org/EVRpQgZaxPb 图片:

emlog仿某火资源网网站源码

介绍: 首先需要安装好emlog系统,登录后台直接上传模板应用即可! 网盘下载地址: http://kekewl.cc/q06RAsD3MTa 图片:

中关村等oss在线图床网站源码 带画廊

介绍: 中关村等oss在线图床网站源码 带画廊 网盘下载地址: http://kekewl.cc/vLN2rxh0MTP 图片:

PHP星辰网址缩短网站源码

介绍: URLshorting,星辰网址缩短源码,支持缩短时显示二维码, 独创密语功能 可通过短域向别人传达信息,感兴趣的下载! 网盘下载地址: http://kekewangLuo.net/4StOjSv46aH 图片:

音乐网站搭建源码Sourcecode

介绍: 准备:域名,服务器或者主机,源码,模板 搭建教程: 1.上传源码,虚拟主机解压源码,解压到wwwroot或者web根目录,php版本建议最好是7.0或以上版本 2绑定域名 3直接点击域名打开即可 网盘下载…

小程序自动一键生成系统网站源码+安装教程

介绍: PHP源码_小程序自动一键生成系统网站源码安装教程 前台演示账号可自行注册 后台登录地址:http://xxx.com/admin 网盘下载地址: http://kekewangLuo.cc/YdiFfCFyXfl0 图片:

滚石导航网站源码v3.0 织梦模板+测试版+非常适合网址导航网站使用

介绍: 滚石导航网站源码v3.0织梦模板已经测试啦织梦 CMS滚石导航网v3.0 模板,基于织梦开发,非常适合网址导航网站使用,织梦 CMS 为数不多的网站导航模板了。 模板使用说明 1、网站站长亲测、整站源码,恢复直接可用。 …

高考倒计时全屏竖向滑动网站HTML源码

简介: 全屏竖向滑动效果 自适应多终端 高考倒计时 音乐自动播放 背景图片:img 目录下替换 bg.jpg 背景音乐:audio 目录下替换 song.mp3 网盘下载地址: http://kekewl.org/FM2yUlG2Qtn0 图片:

网站赞助打shang单页HTML源码

简介: 这是一款网站赞助打shang单页源码,支持3种支付打shang赞助,可以部署在自己的博客或者网站上面进行打shang,还有打shang名单公布!喜欢的可以自行下载! 网盘下载地址: http://kekewl.cc/k…

3款简约好看的EMLOG后台登录网站模板

简介: 将下载的文件上传至服务器根目录./admin/views下替换即可,替换之前请先备份views目录下的login.php文件,以免到时候你不想用使用,再替换回去即可! 使用说明: 修改头像:在login.php文件第20行代码中…

LYCMS–PHP自动采集影视视频程序网站源码

介绍: 一款基于ThinkPHP5快速开发的管理CMS,完全放开双手自动采集影视的程序。主要特色:低门栏 / 灵活 / 清爽 / 极简的一款影视程序源码! 安装说明: 修改 【application/database.php】数据库信息 设置网站根目录为【public】 …

WordPress简约的单栏响应式itheme网站主题

介绍: itheme是一款单栏主题,以rouvin为原型的一款wordpress主题,响应式设计,良好的用户交互。它比以往的单栏的展示效果要丰富得多,个人博客属性极强的一款wordpress模板;这款wordpress模板拥有的特点&am…