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

news/2024/5/20 10:48:01/文章来源:https://blog.csdn.net/weixin_34306676/article/details/92649092

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

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

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

相关文章

PHP集成环境-windows系统下PHP集成环境高并发网站解决方案

PHPCUSTOM再度更新,动态界面引擎酷炫华丽,WIN系统高承压首选PHP环境   功能大全添加了网页克隆,以及新的承压模块,后期我会制作出更多实用功能 官方下载地址:http://www.lccee.com/content-185.html  下图界面特效…

SEO之如何建立良好的内部链接

随着百度,Google等搜索引擎慢慢成为网民上网的入口,SEO(Search Engine Optimizition)搜索引擎优化,慢慢成为了网络营销的一种强有力的手段。网上有很多文章,教程,也有很多相关博客(如…

mysql服务器优化加速_如何通过宝塔面板优化服务器来加快网站运行速度

最近码云笔记对网站进行了一次大的优化改版,不仅在风格上,而且由原先的虚拟主机换到了服务器并使用了宝塔面板,在网站加载速度上提升了一个质的飞跃。我也相信现在有不少的个人站长的服务器都使用了宝塔面板,因为不仅能很方面的配…

杂草丛生HTML5网站模板

杂草丛生HTML5个人网站模板是一款野草到处生长的HTML5网站模板下载。 模板地址:http://www.huiyi8.com/sc/8780.html 转载于:https://www.cnblogs.com/xkzy/p/3765298.html

url格式一定只有一个问号_如何建设一个更易于搜索引擎关键词优化的企业网站...

网站规划设计阶段就必须考虑SEO优化,网站建设过程中涉及到的栏目结构、程序代码等都必须符合SEO规范,有助于加快网站关键词排名上首页的速度,也有利于关键词排名稳定度。然而,网站的初步规划和设计需要大量的深入讨论、沟通和合作…

SEO的艺术

comScore数据分析,数据很多,举个最新的例子 导航型搜索信息型搜索 找地方买东西调查研究交易型搜索 网上贸易用户搜索周期 用户实现大部分时间集中在左上角阴影最深的地方 搜索引擎工作原理 任务本身的复杂度 访问网上所有页面的爬行器算法的限制 …

Angular4搭建在线可竞拍网站

安装依赖包 –save-dev 是你开发时候依赖的东西,–save 是你发布之后还依赖的东西。 npm install jquery --save npm install bootstrap --save 安装类型描述文件,因为是js,ts无法识别 npm install types/jquery --save npm install types/…

利用jsoup爬虫优酷、土豆等视频网站rss利用solr创建索引

1、前提: 了解jsoup、solr等相关的技术、会搭建solr 2、我将爬虫的网站都写在一个xml中,所以先要解析这个xml,得到其网址,然后定时去爬虫 [java] view plaincopyprint?package com.tmzs.pc.jsoup; import java.io.File; im…

解决此请求已被阻止,因为当用在 GET 请求中时,会将敏感信息透漏给第三方网站的问题...

在ASP.NET MVC项目中,使用AJAX向控制器发送GET请求获取JSON数据时,出现这个错误:"此请求已被阻止,因为当用在 GET 请求中时,会将敏感信息透漏给第三方网站。若要允许 GET 请求,请将 JsonRequestBehavi…

SpringCloud实战--新闻门户网站-李熠-专题视频课程

SpringCloud实战--新闻门户网站—149人已学习 课程介绍 本套课程从实战为出发点,带领大家深入了解SpringCloud,摒弃了一些理论知识,一切皆实战。课程收益学习完本套课程的学员都能很容易搭建基于SpringCloud的微服务架构。讲师介绍李熠 更…

利用某网站的SQL注入漏洞getshell

某学校网站存在SQL注入漏洞,可以利用sqlmap对齐进行SQL注入攻击,并获得webshell。 漏洞URL: http://www.xxx.com/news1.php?id1执行攻击命令: sqlmap -u "http://www.xxx.com/news1.php?id1" -p id --current-db -…

某网站登录页面存在用户手机号信息泄露

漏洞利用 输入用户名,界面将弹出手机号,看似手机号被隐藏了,但是通过抓取http包,发现后台其实返回了手机号,由此可知,改手机号只在前端做了隐藏处理。 而且该接口没有做任何校验,可以任意调用&…

使用IWMS的网站打开显示“未能加载文件或程序集”,解决方案

首先,会出现这样的问题原因是: 1、应用程序集里面有些事互相引用的,所以 问题有多种情况,第一、这个应用程序集出问题了; 2、它所依赖的那个程序集出问题了; 3、在项目生成的时候,代码里面有逻辑…

服务器上的php4.0网站连接sql2005服务器连接不上,SQLServer之创建链接服务器

创建链接服务器注意事项当我们要跨本地数据库,访问另外一个数据库表中的数据时,本地数据库中就必须要创建远程数据库的DBLINK,通过DBLINNK数据库可以像访问本地数据库一样访问远程数据库表中的数据。链接服务器允许访问针对OLE DB数据源的分布…

【项目】仿知乎网站项目梳理

GitHub地址:GitHub - vicotorz/zhangdizhihu: 仿“知乎”问答系统 开发流程:DataBase-->Model-->Dao-->Service-->Controller-->Test SQL 建表语句: 评论:comment id int(11), content …

https协议 ppt 下载卷_超全的PPT制作辅助网站和工具

超全的PPT制作辅助网站和工具很多小伙伴在制作 PPT 的时候,常常会遇到不知道该如何入手的问题,特别是对于:图片该如何选用?渐变风格的背景图去哪找?炫光的背景是怎么生成的?手机可以下载高清图片么&#xf…

Nancy之给我们的网站添加自定义图标

Nancy之给我们的网站添加自定义图标 原文:Nancy之给我们的网站添加自定义图标当我们在做一个网站时,可能经常会有这样一个需求,要给我们做的网站添加一个自定义的图标。 在Nancy中,默认是的下面这样 一个妹子的头像,其实也是挺好看…

我的第一个javaweb学习----模仿社区网站(三)

写注册界面的后台 首先得建立一张数据库表,用于存储用户信息的userinfo表,包括注册时间,昵称,签名等 受理注册信息的servlet 然后在servlet包下建立一个注册的Regservlet的Servlet类,用于接收网页传来的信息&#xff0…

什么专业学html css,认识HTML、css的重要性-专业SEO技术教程(27)

认识HTML、css的重要性-专业SEO技术教程(27)通过之前的学习,相信大家已经对SEO有了一定的认识。今天起我们将正式开始SEO的学习。看到这里有些朋友或许有这样的疑问,我们不是要学习SEO吗?为什么要讲解HTML的一些知识呢?这个就要从…

史上最全最新IT网站——你收藏了吗?

快来看看你知道多少 IT网站 1.CSDN 中国专业IT社区CSDN (Chinese Software Developer Network) 创立于1999年,致力于为中国软件开发者提供知识传播、在线学习、职业发展等全生命周期服务。 2.太平洋电脑网 于1999年正式推出,是国内首家以专业电脑市场…