如何快速解决ThinkPHP5.1出现MISS缓存未命中问题

后端开发   发布日期:2023年06月10日   浏览次数:550

这篇文章主要介绍了如何快速解决ThinkPHP5.1出现MISS缓存未命中问题的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇如何快速解决ThinkPHP5.1出现MISS缓存未命中问题文章都会有所收获,下面我们一起来看看吧。

ThinkPHP5.1使用CDN加速-MISS缓存未命中解决

在单独给首页配置CDN加速后,出现了X-Cache: MISS TCP_MISS dirn:-2:-2,MISS也就是缓存没有被命中。这个问题不是配置错了,而框架问题。

什么要使用CDN?

“cdn简介 CDN的全称是Content Delivery Network,即内容分发网络。

为什么使用CDN?

CDN就近节点访问,提高了网站加载速度,降低延时;能起到分流作用,减轻服务器负载,

使用动静分离提高网站访问速度。

配置实现

这个呢,我是部署在了生产环境,实际测试大并发高流量处理,当然了,也有很多的不足。

环境

服务器:腾讯云

系统:CentOS7

框架:ThinkPHP5.1

使用阿里云OSS+CDN并配置缓存

当然还要有经过备案的域名。

关于怎么使用阿里云OSS对象存储系统,Laravel6.x上传视频到阿里云Oss对象存储 这篇文章记录过。

bucket创建完成后,可以在列表中看到 '阿里云 CDN 加速',点击这个进行相关的CDN操作,配置完后需要在域名中进行解析。

问题

在单独给首页配置CDN加速后,出现了X-Cache: MISS TCP_MISS dirn:-2:-2,MISS也就是缓存没有被命中。这个问题不是配置错了,而框架问题。

解决方法如下:

第一步:public/index.php读取/设置缓存限制器

  1. <?php
  2. namespace think;
  3. // 设置缓存限制
  4. session_cache_limiter('public');
  5. require __DIR__ . '/../thinkphp/base.php';
  6. Container::get('app')->run()->send();

第二步:开启请求缓存

  1. // 文件位置: config/app.php
  2. 'request_cache' => true,

ab压测

如下压测是经过了CDN+OSS之后的结果,可以看到qps可以达到573

  1. $ ab -c100 -n1000 你的页面URL
  2. This is ApacheBench, Version 2.3 <$Revision: 1430300 $>
  3. Copyright 1996 Adam Twiss, Zeus Technology Ltd, http://www.zeustech.net/
  4. Licensed to The Apache Software Foundation, http://www.apache.org/
  5. Benchmarking miaosha.nikexu.com (be patient)
  6. Completed 100 requests
  7. Completed 200 requests
  8. Completed 300 requests
  9. Completed 400 requests
  10. Completed 500 requests
  11. Completed 600 requests
  12. Completed 700 requests
  13. Completed 800 requests
  14. Completed 900 requests
  15. Completed 1000 requests
  16. Finished 1000 requests
  17. Server Software: Tengine
  18. Server Hostname: miaosha.nikexu.com
  19. Server Port: 80
  20. Document Path: /
  21. Document Length: 774 bytes
  22. Concurrency Level: 100
  23. Time taken for tests: 1.745 seconds
  24. Complete requests: 1000
  25. Failed requests: 0
  26. Write errors: 0
  27. Total transferred: 1403829 bytes
  28. HTML transferred: 774000 bytes
  29. Requests per second: 573.16 [#/sec] (mean)
  30. Time per request: 174.472 [ms] (mean)
  31. Time per request: 1.745 [ms] (mean, across all concurrent requests)
  32. Transfer rate: 785.76 [Kbytes/sec] received
  33. Connection Times (ms)
  34. min mean[+/-sd] median max
  35. Connect: 15 17 1.5 16 25
  36. Processing: 18 91 113.4 71 1195
  37. Waiting: 18 90 113.4 71 1195
  38. Total: 36 107 113.4 87 1212
  39. Percentage of the requests served within a certain time (ms)
  40. 50% 87
  41. 66% 99
  42. 75% 103
  43. 80% 105
  44. 90% 120
  45. 95% 195
  46. 98% 437
  47. 99% 834
  48. 100% 1212 (longest request)

在来看看500个并发的压测。

  1. ab -c500 -n10000 你的页面URL
  2. Requests per second: 965.61 [#/sec] (mean)
  3. Time per request: 517.806 [ms] (mean)
  4. Time per request: 1.036 [ms] (mean, across all concurrent requests)
  5. Percentage of the requests served within a certain time (ms)
  6. 50% 257
  7. 66% 319
  8. 75% 541
  9. 80% 1043
  10. 90% 1102
  11. 95% 1281
  12. 98% 1560
  13. 99% 1821
  14. 100% 3771 (longest request)

通过这个两个手段,已经可以看到还并发量提供,500的并发量,80%的用户可以在1s左右打开。在没有使用CDN+OSS前,我压测的结果是 150的并发,CPU就冲到了90%。使用OSS+CDN的优势就不言而喻了。

以上就是如何快速解决ThinkPHP5.1出现MISS缓存未命中问题的详细内容,更多关于如何快速解决ThinkPHP5.1出现MISS缓存未命中问题的资料请关注九品源码其它相关文章!