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

news/2024/5/9 18:35:48/文章来源:https://blog.csdn.net/weixin_33671935/article/details/92651330

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

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

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

相关文章

使用github+hexo搭建自己的博客网站--入门篇

前言 这一篇主要介绍如何使用搭建GitHub.io网站 我自己的网站:https://lijie-1024.github.io 使用hexonext主题GitHub搭建,具体问题可以留言问我。 本篇所包含的内容如下: 正文 一、申请github.io网站 github注册我就不讲了。。。能想到这…

网站服务器改数据库密码忘记了怎么办,服务器数据库密码忘记了怎么办

服务器数据库密码忘记了怎么办 内容精选换一换FTP/SFTP连接适用于从线下文件服务器或ECS服务器上迁移文件到OBS或数据库。当前仅支持Linux操作系统的FTP 服务器。连接FTP或SFTP服务器时,他们的连接参数相同,如表1所示。FTP/SFTP连接参数参数名说明取值样…

python过滤违禁词_网站全站敏感词检测、广告违禁词查询很简单,一个python脚本轻松搞定...

做网站的同学都有一个共同的苦恼:就是自己辛辛苦苦经营的网站,如果内容中涉及色情、暴恐涉政、恶意推广、辱骂、违反广告法、涉及违禁品等文本内容,小则被搜索引擎处罚,严重的可能还会被请去喝茶。还有很多企业站因为编辑的不小心…

echarts案例大全,echarts的Demo网站有哪些

很多开发人员用到echarts做大屏展示,一般常用的网站是 Apache Echarts,但是这个一个网站的demo不一定满足我们,那么除了Apache Echarts还有哪些我们可以用的echarts网站呢? 1.分享你我 网站:分享你我 – ECharts 作…

黑苹果未能与恢复服务器_淘客新事件 09.24 1、某千万用户淘客APP内部腐败案 2、误会,大淘客网站疑似被黑!...

1、某千万用户淘客APP内部腐败案评:某淘客APP在昨天公布了他们自家的内部腐败案!大概就是有离职员工后进入竞品公司,还把原公司开发的云发单源码拷贝复制成自己的软件,并且推广到市场!当然这个不算什么,主要…

python 图片文件_初学Python-只需4步,爬取网站图片(附py文件)

很多人学习Python很重要的一个原因是,可以很简单的把一个网站的数据爬下来。尤其是做我们这一行,产品经理,电商行业。领导:弄一个买卖游戏周边商品的交易APP出来。我:行,那我们卖什么呀?领导&am…

程序员入门必备网站 (技术云集的网站)tutorialspoint

https://www.tutorialspoint.com/index.htm 这个网站是印度的一个IT教学网站 前后端技术,应有尽有,还有数据库学习,这个网站很棒,大家,加油~

轻文章-使用URL Rewrite实现网站伪静态

文章目录基础介绍案例代码urlrewrite.xmluserinf.jsp验证结果注意事项参考文档案例来源:《轻量级Java EE企业应用实战(第4版)-Struts2Spring4Hibernate整合开发》,李刚编著 基础介绍 伪静态的作用:将*.jsp、*.php这种…

阿里云服务器Linux主机搭建网站环境

首先准备好连接linux服务器的工具,推荐用xshell和xftp。 xshell 是一个强大的安全终端模拟软件,它支持SSH1, SSH2, 以及Microsoft Windows 平台的TELNET 协议。 下载地址:http://www.newhua.com/soft/36383.htmXftp 是一个基于 MS windows 平…

linux 画直线 c程序,绘制直线 - Ubuntu+OpenGL程序设计_Linux编程_Linux公社-Linux系统门户网站...

这次主要学习的是关于在opengl中绘制直线,也比较简单现上图吧这图乍一看上去是不是像是一条条弯曲的直线???我开始就把他看成这样了,不过这是个视觉问题,仔细看过起,其实还是一个同心的直线&…

如何得到一个网站的后台地址

一、猜测常见的网站后台 1、http://你的网址/login.asp 2、http://你的网址/admin/login.asp 3、http://你的网址/admin/ /admini/ 二、查看该网站的robots.txt 如:网站为:http://www.mmfi.net/ 在后面添加:robots.txt 得到: …

Eclipse添加J2EE开发功能(网站开发)

添加J2EE 其实很简单啦: 1、打开Eclipse,点击Help 2、选择Install New Software 3、在work with中输入网址:http://download.eclipse.org/releases/ 在下面出现的选项选择自己的Eclipse版本 4、在下面框框中选择“Web,XML,Java EE and OSG…

手机沙盒隔离软件_手机怎么安全无病毒的访问风险网站和APP

很多小伙伴,总会在夜深人静的时候不由自主的打开浏览器,登上一些不可描述的网站,不经意访问一些风险网站,或者在不知情的情况下下载了一些流氓APP。经常会有一些可恶的木马、病毒也会在这些网站和APP上,它们防不胜防&a…

网站页面左右_网站SEO优化基础入门与教程

掌握SEO基础知识,是我们进行简单的网站建设必备条件之一,没有子弹,如何打鸟呢?今天小编将给各位分享一下关于网站seo优化的基础知识与seo教程,希望新手SEO们认真看完以下内容,相信会给你带来帮助。一、SEO入门基础&am…

php和seo有关系吗_php seo 优化之文章的字数和SEO的关系

文章内容字数与seo的有关系的,下面就来和小编一起了解一下文章字数与SEO的联系,一起来了解一下吧。一篇文章多少字数更有利于收录,有利于网站的优化,从大的方面来讲,有几个共识的点。1、第一考虑用户的需求是什么&…

php同学录网站设计_php校友录网站设计

校友录系统站我们使用 PHP开发工具,利用其提供的各种面向对象的开发工具,尤其是数据窗口这一能方便而简洁操纵数据库的智能化对象,首先在短时间内建立系统应用原型,然后,对初始原型系统进行需求迭代,不断修…

一些网站

考试资源 考试163:www.test163.com大量的资格认证考试试题,计算机,英语视听材料 IT认证考试资源网:www.itexamprep.com大量IT认证考试题库 中国大学生网:www.chinadaxuesheng.com题库模拟题以及论文 中国考试网&am…

软件测试大型网站如何进行压力测试及性能调优优化方案

性能测试在大型网站系统的设计和开发中非常重要,通常会和容量预估等工作结合在一起,穿插在系统开发的不同方案。性能测试可以帮助我们及时发现系统的性能短板,评估系统的能 性能测试在大型网站系统的设计和开发中非常重要,通常会…

经典网页设计:20个美味的餐馆和食品网站

餐馆和食品网站设计目标是吸引更多的人到他们的店中消费或者购买他们的食品,这类网站通常都会搭配美味的食物图片,吊人胃口。有的网站也会应用视差滚动特效和大背景布局设计来吸引消费者。下面分享的这20个精心设计的餐馆和食品网站案例看起来就让人充满…

SEO知识结构

引一张图片待续转载于:https://www.cnblogs.com/mackxu/archive/2012/10/30/2746211.html