基础知识

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

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

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

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

  PV : page view 页面访问量

  UV : user view 用户访问量

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

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

压力测试

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

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

1

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

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

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

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] received

Connection Times (ms)

              min  mean[+/-sd] median   max

Connect:        0    1   1.4      1      38

Processing:    42  114  34.2    103     204

Waiting:       41  113  33.9    102     204

Total:         43  115  34.5    104     207

Percentage 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的高并发和大流量的问题的更多相关文章

  1. PHP高并发和大流量怎么解决?

    PHP高并发和大流量的解决方案 一 高并发的概念 在互联网时代,并发,高并发通常是指并发访问.也就是在某个时间点,有多少个访问同时到来. 二 高并发架构相关概念 1.QPS (每秒查询率) : 每秒钟 ...

  2. PHP高并发和大流量的解决方案

    第一个要说的就是数据库,首先要有一个很好的架构,查询尽量不用* 避免相关子查询 给经常查询的添加索引 用排序来取代非顺序存取,如果条件允许 ,一般MySQL服务器最好安装在Linux操作系统中 .关于 ...

  3. php高并发,大流量

    一般使用LVS+PHP集群(1000台),就算日均80亿次请求,每秒有10万并发,那分到每台机器的请求只有100个.只要你的PHP程序不是太差,100QPS总没问题吧? 而真正的瓶颈在于数据库和存储系 ...

  4. php 面试考点总结-高并发和大流量解决方案考点

    1.web资源防盗链 盗链概念 盗链是指在自己的页面上展示一些并不在自己服务器的内容 防盗链工作原理 通过referer或者签名,网站可以检测目标网页访问的来源页,一旦检测到来源页不是本站即进行阻止或 ...

  5. 高并发和大流量解决方案--CND加速

    CDN全称 Content Delivery Network,即内容分发网络.其基本思路是尽可能避开互联网上有可能影响数据传输速度和稳定性的瓶颈和环节,使内容传输的更快.更稳定.通过在网络各处放置节点 ...

  6. Sqlserver 高并发和大数据存储方案

    Sqlserver 高并发和大数据存储方案 随着用户的日益递增,日活和峰值的暴涨,数据库处理性能面临着巨大的挑战.下面分享下对实际10万+峰值的平台的数据库优化方案.与大家一起讨论,互相学习提高!   ...

  7. Web网站架构演变—高并发、大数据

    转 Web网站架构演变—高并发.大数据 2018年07月25日 17:27:22 gis_morningsun 阅读数:599   前言 我们以javaweb为例,来搭建一个简单的电商系统,看看这个系 ...

  8. LVS解决高并发,大数据量

    http://www.360doc.com/content/14/0726/00/11962419_397102114.shtml LVS的全称Linux vitual system,是由目前阿里巴巴 ...

  9. 解决跨海高并发崩溃难题?so easy

    近年来随着互联网强势的发展浪潮,越来越多的企业选择跨境出海,扩展海外市场.而想要在一个陌生市场最快速地吸引到用户,一定不能缺少的就是丰富多样的各类活动.然而活动在带来大流量的同时,也带来了一些问题,比 ...

随机推荐

  1. 【python】脚本连续发送QQ邮件

    今天习得用python写一个连续发送QQ邮件的脚本,经过测试,成功给国内外的服务器发送邮件,包括QQ邮箱.163邮箱.google邮箱,香港科技大学的邮箱和爱丁堡大学的邮箱.一下逐步解答相关技巧. 首 ...

  2. win7文件夹带锁标志如何去除?win7去除文件夹带锁标志的方法

    win7文件夹带锁标志如何去除?win7去除文件夹带锁标志的方法 http://www.xitongcheng.com/jiaocheng/win7_article_30333.html 具体方法如下 ...

  3. Web jsp开发学习——网上直播聊天室的简单开发

    整个界面为chat.jsp: 如果用户没有登录,就不能进行聊天. 为将发言的句子传到页面上,要设置一个<iframe></iframe>虚拟框架,将allmessage.jsp ...

  4. Java笔记Spring(二)

    spring-core 通过Gradle构建工具,转换包的命名空间为org.springframework下 cglib包,net.sf.cglib -> org.springframework ...

  5. Android 梯形进度条、下载进度条;

    额,Gif有点卡: 梯形.矩形.圆角.背景色.前景色.进度条中的文字都可以改: <?xml version="1.0" encoding="utf-8"? ...

  6. 3.1链表----链表(Linked List)入门

    在分析链表之前,我们先来对之前的动态数组.栈.队列总结一下: (1)底层依托于静态数组 (2)依靠resize解决固定容量问题 (3)是一种假的的动态数据结构 1.什么是链表 可以从以下两个部分来理解 ...

  7. Mysql 8.0修改密码

    ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY '你的密码';

  8. I2C的小结

    下面是 I 2 C 总线的一些特征 只要求两条总线线路 一条串行数据线 SDA 一条串行时钟线 SCL 每个连接到总线的器件都可以通过唯一的地址和一直存在的简单的主机 从机关系软件设定地 址 主机可以 ...

  9. Rabbitmq(7) confirm模式

    1. //将通道设置为comfirm模式channel.confirmSelect(); // 消息确认if(!channel.waitForConfirms()){ System.out.print ...

  10. PHP和Redis实现在高并发下的抢购及秒杀功能示例详解

    抢购.秒杀是平常很常见的场景,面试的时候面试官也经常会问到,比如问你淘宝中的抢购秒杀是怎么实现的等等. 抢购.秒杀实现很简单,但是有些问题需要解决,主要针对两个问题: 一.高并发对数据库产生的压力二. ...