如何解决PHP的高并发和大流量的问题

如何解决PHP的高并发和大流量的问题

内容导读

收集整理的这篇技术教程文章主要介绍了如何解决PHP的高并发和大流量的问题,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含2652字,纯文字阅读大概需要4分钟

内容图文

这篇文章主要介绍了关于如何解决PHP的高并发和大流量的问题,有着一定的参考价值,现在分享给大家,有需要的朋友可以参考一下

基础知识

  TFS : 吞吐量 (吞吐量是指系统在单位时间内处理请求的数量)

  RT : 响应时间 (从请求发出到收到响应时间)

  并发数 : 在一段时间内同时访问站点的用户数

  QPS : 每秒查询率 (每秒请求或者相应数,在互联网领域,值每秒相应请求数(值HTTP请求))

  PV : page view 页面访问量

  UV : user view 用户访问量

一般来说,日pv(访问量)大于1000万就可以算做高并发

日网站带宽 = PV / 统计时间 (秒) * 页面平均大小(KB) * 8

压力测试

推荐使用apache自带的压力测试工具 ab

使用方法:进入apache目录,在当前目录下运行(windows):

ab.exe -n 总请求量 -c 并发请求量
http://请求地址

请求结束后我们可以得到数据:

Server Software:



Apache/2.4.18	服务器类型Server Hostname:



eko.xiao.com

域名Server Port:





80				端口Document Path:




/index.html
	请求文件Document Length:



529 bytes		文件大小Concurrency Level:


100				并发数Time taken for tests:
 1.240 seconds	总响应时间Complete requests:


1000			请求数Failed requests:



0				失败次数Total transferred:


800000 bytes	总共传输数据量HTML transferred:


 529000 bytes	Requests per second:

806.41 [#/sec] (mean)	QPS(每秒查询率)Time per request:


 124.007 [ms] (mean)		平均响应时间Time per request:


 1.240 [ms] (mean, across all concurrent requests)Transfer rate:




630.00 [Kbytes/sec] receivedConnection Times (ms)






min
mean[+/-sd] median
 maxConnect:



0

1
 1.4


1


38Processing:

42
114
34.2

103

 204Waiting:


 41
113
33.9

102

 204Total:



 43
115
34.5

104

 207Percentage of the requests served within a certain time (ms)
50%

104
66%

117
75%

133
80%

136
90%

173
95%

197
98%

204
99%

204 100%

207 (longest request)  

优化

随着QPS增长,每个阶段需要做不同的优化措施,优化的方案也与硬件,网络条件相关

QPS达到50

  无需优化

QPS达到100(数据库层)

  假设数据库每次查询0.01S,每个页面只有一个sql查询,那么此时已经是数据库极限

  优化措施:数据库缓存,数据库负载均衡,redis,memcache

QPS达到800 (网络带宽)

  假设每个页面只有10K,那么在800QPS下,带宽已经耗尽

  优化措施:CDN加速 负载均衡

QPS达到1000

  优化措施:静态页面

流量优化:

  防盗链处理

前端优化:

  减少HTTP请求

  添加异步请求

  启用浏览器缓存

服务器优化:

  页面静态化

  并发处理

  队列处理

数据库优化:

  数据库缓存

  分库分表,分区操作

以上就是本文的全部内容,希望对大家的学习有所帮助,更多相关内容请关注PHP中文网!

相关推荐:

php大牛分享:php代码编写的规范,总结的很全

PHP的安装以及与apache整合的介绍

以上就是如何解决PHP的高并发和大流量的问题的详细内容,更多请关注Gxl网其它相关文章!

内容总结

以上是为您收集整理的如何解决PHP的高并发和大流量的问题全部内容,希望文章能够帮你解决如何解决PHP的高并发和大流量的问题所遇到的程序开发问题。 如果觉得技术教程内容还不错,欢迎将网站推荐给程序员好友。

内容备注

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。


本文关键词:

联系我们

在线咨询:点击这里给我发消息

邮件:w420220301@qq.com