PHP如何打造一个高可用高性能的网站呢?

news/2024/5/20 12:29:19/文章来源:https://blog.csdn.net/weixin_33910434/article/details/86025768

https://blog.csdn.net/jwq101666/article/details/80162245

1. 说到高可用的话要提一下redis,用过的都知道redis是一个具备数据库特征的nosql,正好弥补了PHP的瓶颈,个人认为PHP的 瓶颈在于数据库,像Apache和Nginx的高级web服务器在承受并发量上面都各有千秋,apache的最大承受并发数可以到三四千个,nginx要是它的10倍,但apache的三四千个是实打实的三四千个,nginx的并发数是要依靠缓存的。高可用高性能系统这些就要求对mysql的掌握程度相当高,包括memcached,这会大大提高PHP的可扩展性。

 

        之前模拟过一个高并发的单进程模型(这个对PHP的其它备用缓存的掌握程度有一定要求,有兴趣的可以自己也试下哦!),在并发数达到一定峰值,PHP的某些小小的缺点就会暴露出来,例如异步并发时数据库反应时间不能及时响应导致PHP的处理时间超时问题,swoole的出现对于PHP来说无异于如虎添翼,再将字符串的值放进redis的队列通过点对点的响应进行异步处理来模拟整个过程,其实也不是特别的简单啦,Linux的强大就在于此处,只要你有想法就一切就可以满足你!

 

好啦,话不多说,我们来分析分析高性能高可用的系统。

简而言之,采用分布式系统,分布式应用和服务,分布式数据和存储,分布式静态资源,分布式计算,分布式配置和分布式锁。负载均衡,故障转移,实现高并发。

1、分层

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

在网站的分层架构中,常见的为3层,即应用层、服务层、数据层。

应用层,具体负责业务和视图的展示;

服务层,为应用层提供服务支持;

数据层,提供数据存储访问服务,如数据库、缓存、文件、搜索引擎等。

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

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

 

2、冗余

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

3、分隔

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

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

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

 

 

PHP秒杀系统-高并发高性能的极致挑战

链接:https://pan.baidu.com/s/1DhFgCEHD4tdEAZ_y-nLWOQ 

提取码:8w6b 

 

4、异步

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

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

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

5、分布式

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

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

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

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

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

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

 

6、安全

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

8、自动化

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

8、集群

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

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

 

9、缓存

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

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

 

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

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

相关文章

怎么修复网站漏洞之metinfo远程SQL注入漏洞修补

2019独角兽企业重金招聘Python工程师标准>>> 2018年11月23日SINE网站安全检测平台,检测到MetInfo最新版本爆出高危漏洞,危害性较大,影响目前MetInfo 5.3版本到最新的 MetInfo 6.1.3版本,该网站漏洞产生的主要原因是Met…

IIS配置和发布网站

一、安装配置IIS 控制面板-》程序和功能-》启用或关闭Windows功能选中“Internet Information Services”,勾选Web管理工具子项,万维网服务子项(万维网中有极少数不用勾选,不做细致描述全部勾选了)。勾选完成后&#x…

资源帖-优秀博客、iOS开发技术文、学习网站

图片发自简书App 一些博客 王巍 Objc中国发起人、Line工程师ibireme YYKit作者bang JSPatch作者唐巧 《iOS开发进阶》作者、猿题库工程师孙源 前百度工程师,现滴滴工程师玉令天下xuyafei张不坏NSHipster中文版glow刚刚在线里脊串Jamin阿毛的蛋疼地zeeyangTian Wei…

关于初创型公司对公司网站的开发与管理内容

WebSite 一、理论和原理二、软件、类库、中间件三、技术相关四、案例分析对于一个网站而言需要知道公司的需求,想要给别人展示的是什么,重点放在哪里,让观众了解或者注重自己的关键点在哪里,方便观众更快更好的了解公司是干什么的…

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

2019独角兽企业重金招聘Python工程师标准>>> 每一个模式描述了一个在我们周围不断重复发生的问题及该问题解决方案的核心。这样,你就能一次又一次地使用该方案而不必做重复工作。 所谓网站架构模式即为了解决大型网站面临的高并发访问、海量数据、高可靠…

电脑服务器显示过期,win10系统提示你的设备存在过期风险怎么办_网站服务器运行维护,win10...

win7系统安装后无网络适配器怎么办_网站服务器运行维护win7系统安装后无网络适配器的解决方法是:1、打开控制面板,进入【设备管理器】;2、右键点击异常的驱动程序,选择【更新驱动程序】;3、选择【浏览我的计算机以查找…

利用java爬取网上信息_java爬取网站信息和url实例

https://blog.csdn.net/weixin_38409425/article/details/78616688(出自此為博主)具體代碼如下:import java.io.BufferedReader;import java.io.File;import java.io.FileWriter;import java.io.IOException;import java.io.InputStreamReader;import java.io.Print…

seo代码优化工具_seo外包的内幕曝光_云一哥

为了让企业网站建好后,用有更好的排名,能更快更好的提高品牌形象和宣传力度,那么要选择一家专业的seo外包公司为企业提供服务。那首先就要知道做seo的工作内容,所以云一哥就和大家分享下SEO外包都有哪些工作内容?seo外…

php linux 缓存文件,Linux下搭建网站提示缓存文件写入失败的处理办法

Linux下建立网站提示缓存文件写入失利时该怎样处理?依据ThinkPHP结构及Linux环境建立的网站,经常会遭受缓存文件写入失利的过错提示,即就是现在盛行的P2P网站程序就是如此,详细处理办法请看下文。缓存文件写入失利常见原因&#x…

springboot做网站_Github点赞接近100k的SpringBoot学习教程+实战推荐!牛批!

很明显的一个现象,除了一些老项目,现在 Java 后端项目基本都是基于 Spring Boot 进行开发,毕竟它这么好用以及天然微服务友好。不夸张的说,Spring Boot 是 Java 后端领域最最最重要的技术之一,熟练掌握它对于 Java 程序…

免费抖音视频解析网站_抖音规则解析:抖音视频为什么能火?推荐规则是什么?【揭秘】...

视频出现之后,又相继出现抖音、西瓜、火山、美拍等短视平台,其中以抖音、快手为主,而各大互联网公司都开始纷纷涉猎短视频领域,那么究竟要怎么要才能玩转短视频平台呢 !今天小编就给大家分析一下抖音短视频的一些玩法规则&#xf…

c#服务器后台搭建_角点科技教你从0开始搭建一个网站

一、注册网站域名域名是网站的访问地址,这个一般大家都是知道的,那么域名是怎么来的呢?域名一般是注册的但是也有的人是购买的,注册和购买都很简单的,按照平台的提示流程走就可以拥有一个域名了,一般价格就…

简单动态网站搭建

如何在windows服务器上配置wordPress和discuz 网站建设中的概念讲解 网站建设的基础操作 网站程序的基础使用 网站程序的优化 简单动态网站搭建 软件部署 域名和主机的购买 域名解析 环境部署 安装程序 软件的使用和优化 wordpress的基础设置和使用 discuz的基础设置…

有些网站打开一半空白_高端定制网站如何设计才显高大上?

在网上常见的网站设计都是模板站,有一部分人对于网站建设要求是很高的,“高端定制网站如何建设才能吸引用户点击”一直是他们常思考的问题。接下来,我们常州互旦科技大家讲讲网站定制开发需要注意的问题:高端定制网站如何设计才显…

爬虫案例 某网站小说下载

由于版权问题,暂不对网站明述。 正常使用xpath进行爬取,没有反爬措施 爬取使用了进度条,说明一下进度条的使用和爬取遇到的问题: \r 表示将光标的位置回退到本行的开头位置 \b表示将光标的位置回退一位 print("\r", e…

江苏高考时间2021成绩查询,小高考时间2021具体时间江苏-江苏小高考成绩查询公布时间及网站...

选择科目测一测我能上哪些大学选择科目领取你的专属报告>选择省份关闭请选择科目确定v>2021年1月,全国多省举行了普通高中学业水平考试,其中江苏的学业水平合格性考试又被本地人称为是“小高考”,备受人们的关注。下面,我就…

仿站和模板建站的区别_企业建站:高价定制并不一定高质!

购买实物产品,如车、手机、衣服等,不考虑性价比的情况下,贵的一般质量会好很多,但建站目前还不是标准产品,信息高度不透明,普通用户没有评判标准,因此“贵的并不一定好”,而且你仔细…

利用cmd和ip入侵电脑_还偷看“不良网站”?这些麻烦都会找上你,难怪手机、电脑变卡了...

移动互联网时代,智能手机的功能性变得十分强大,借助各种APP,我们实现了线上支付、网购和社交等等,非常的便利,但是网络也是有双面性的,正确的利用确实能够带来很多方便,但同时也很容易误入一些“…

退出页面 数据保留_Edge新增Cookies白名单:清除数据时可保留网站登录凭证

基于Chromium的Edge新版在设置中提供了一个选项,允许用户在关闭浏览器的时候清除浏览数据,用户可以对浏览历史、下载历史、Cookies、其他网站数据和自动表单填写数据进行选择。如果你已经配置在关闭浏览器之后自动删除Cookies(也就是在关闭之后登出大部分…

ppt上的倒计时小工具_让你的PPT/论文/报表瞬间高大上的10款数据可视化工具网站推荐...

也许看这篇文章的你依旧身在学校,或者已然奋斗在职场,相信我,PPT绝对是只会迟到但决不会缺席的一个存在。其中数据是PPT当中一个非常重要的内容组成部分,而高效的展示数据的方式就将数据做成可视化的图表形式。柱状图、折线图或者…