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

news/2024/5/11 21:19:32/文章来源:https://blog.csdn.net/weixin_34301307/article/details/92652585

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/592272

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

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

相关文章

Linux上创建web网站

一.搭建静态网站-----基于http协议的静态网站服务器端: 在Linux上面实现网页服务器需要Apache这套服务器软件,httpd提供Apache主程序。 1.静态网站:要求搭建的web网站基于IP访问,当前web网站的根目录为/openlab&#x…

打开页面直接调用f11_烟台网站建设如何提升网站打开速度?

摘要:烟台网站建设网友上网都不喜欢用太多的时间等待网页的打开,等待得越长,用户可能会直接关闭网页,这样就会损失很多流量!其次,关键字的排名与网页的打开速度也有关系,这个主要体现搜索引擎对…

php网站数据备份,PHP网站备份方法-手动备份PHP网站

因网站修改过程中可能会误删或出错需要在做到一个关键阶段时对网站内容进行备份,在网站上线运行一段时间,出于空间安全考虑也需要定期备份,每季或半年对网站进行备份。有些空间自带一键备份的功能,如乐道主机的cPanel和Directadmi…

支撑200并发_从入门到高手,高并发网站成神之路!

高并发网站,不是设计出来的,是一步步调整出来的。一,什么是高并发高并发是互联网分布式系统架构设计中必须考虑的因素之一,通常指:通过设计保证能够同时并行处理很多请求。高并发指标:响应时间:…

怎么用python自己写个网站_如何用Python搭建一个网站?

原标题:如何用Python搭建一个网站? 首先呢,你只有Python语言基础,现在想使用Python搭建一个网站。网站类似于豆瓣读书http://book.douban.com/,具体功能不需要豆瓣读书那么多。实话跟你说吧,有点难度,毕竟…

mysql建站工具_解说 Navicat for MySQL 创建工具

Navicat for MySQL 是一套管理和开发 MySQL 或 MariaDB 的理想解决方案,支持单一程序,可同时连接到 MySQL和MariaDB。这个功能齐备的前端软件为数据库管理、开发和维护提供了直观而强大的图形界面,给 MySQL 或 MariaDB 新手以及专业人士提供了…

Vue-cli seo 使用prerender-spa-plugin插件预渲染

使用vue-cli打包项目一般为spa项目,众所周知单页面应用不利于SEO,有ssr(服务端渲染)和预渲染两种解决方案,这里我们只讨论预渲染 vue-cli有2.0和3.0版本,解决方法是不一样的,我们要分开讨论。 vue-cli2.0版本 1.安装…

ASP.NET网站开发——用户控件与HttpHandle

用户控件与HttpHandle 一、用户控件 含义:用户控件是能够在其中放置标记和web服务器控件的容器,可以被看作一个独立的单元,拥有自己的属性和方法,并可被放入到ASPX页面上,其工作原理与ASP.NET页面非常相似。也可以这样…

ASP.NET网站开发——成员资格和角色管理

成员资格和角色管理 一、成员资格简介 ASP.NET成员资格支持下列功能: (1)创建新用户和密码。 (2)将成员资格信息(用户名、密码和支持数据)存储在Mixrosoft SQL ActiveDirectory或其他数据存储区。 &#xf…

ASP.NET网站开发——个性化用户配置概述

个性化用户配置概述 一、<profile>配置节 设置<profile>配置节时&#xff0c;经常对其中的三部分进行配置&#xff1a; 1.<profile>自身属性设置 2.<profile>配置节的字节<properties>属性设置 3.<profile>配置节的子节点<providers>…

ASP.NET网站开发——安全验证

安全验证 一、ASP.NET的安全模式 1.安全的必要性&#xff1a; &#xff08;1&#xff09;构造特殊的链接地址&#xff0c;导致文件内的数据泄漏。 &#xff08;2&#xff09;数据库泄露。 &#xff08;3&#xff09;安全防范的首要策略&#xff1a;所有的HTTP访问都要经过IIS&a…

ASP.NET网站开发——数据缓存技术

数据缓存技术 缓存概念&#xff1a;缓存是一种在计算机中广泛用来提高性能的技术。在web应用程序的上下文中&#xff0c;缓存用于在Http请求间保留页或者数据&#xff0c;并在无需多创建的情况下多次使用它们。 目的&#xff1a;节省应用程序处理时间和资源 缓存体系&#xff1…

毕业设计-电子商务网站(一)

个人觉的毕业设计对自己编码水平有很大的磨练&#xff0c;建议大家独立完整的完成自己的毕业设计&#xff0c;即使多花一些时间也无所谓。 设计毕业设计的时候建议大家先设计页面&#xff0c;再解决数据交互上的问题。 接下来我将为大家展示我的毕业设计&#xff0c;希望对大…

毕业设计-电子商务网站(二)

个人觉的毕业设计对自己编码水平有很大的磨练&#xff0c;建议大家独立完整的完成自己的毕业设计&#xff0c;即使多花一些时间也无所谓。 设计毕业设计的时候建议大家先设计页面&#xff0c;再解决数据交互上的问题。 接下来我将为大家展示我的毕业设计&#xff0c;希望对大…

网站跨域问题思维导图总结

自己学习总结了一些思维导图(持续更新中)&#xff0c;后面附有GitHub链接 ,分享给大家。https://github.com/panjianlong13/MindMapSummary

写个自己比较满意的用户注册系统(未来网站的一部分)(一)

学了那么久&#xff0c;是时候做一个可以让自己觉得满意的网站。但是因为要考四级&#xff0c;没太多时间&#xff0c;所以先写一部分。决定先写个用户注册系统。只是把想要复习的都用上&#xff0c;并没有考虑什么性能效率&#xff0c;也许不会打算用到的技术有c# &#xff0c…

18岁少女创社交网站成全球最年轻亿万富翁

“美女创业家”凯瑟琳库克 MyYearbook.com网站页面 网站在全美青少年中人气第一&#xff0c;广告年收入千万美元 现年18岁的美国少女凯瑟琳库克再度创造网络神话。目前&#xff0c;由她于3年前创建的MyYearbook.com网站成为全美第三大社交网站&#xff0c;并在全美校园少男少女…

[Debug实践]windbg解决网站服务器高CPU问题 转

[Debug实践]windbg解决网站服务器高CPU问题 高CPU是网站服务器常见的一种故障&#xff0c;很多windbg教程中都拿高CPU做例子。3月份我在公司服务器上也碰到一次&#xff0c;整个debug过程十分顺利且常规&#xff0c;但最终找到的原因却很有意思&#xff0c;与一个挂马行为有关。…

让个人pc上的iis网站可以在Internet上访问

背景&#xff1a; 相信很多人&#xff08;学生、工作的程序员&#xff09;都遇到过这种情况&#xff0c;自己做了个小网站&#xff08;给客户的演示项目、小的测试网站等&#xff09;&#xff0c;想让让局域网意外的人可以通过Internet访问你的网站&#xff0c;想让他们给你提点…

网站DIV+css弹性+固宽布局案例

当今用户的显示器越来越大的今天&#xff0c;之前的1024*768固宽布局有点越来越不合时宜&#xff0c;对大屏幕的用户而言&#xff0c;两侧空空的留白给人第一眼的印象是严重的屏幕浪费&#xff0c;作为网页设计师的你有责任给这一批用户一个良好的用户界面。 当然为了减少这种屏…