当前位置:首页>python>Python scrapy-redis模块详细介绍

Python scrapy-redis模块详细介绍

  • 2026-02-26 17:46:04
Python scrapy-redis模块详细介绍

1. 创始时间与作者

  • 创始时间Scrapy-Redis 最早由 Rolando Espinoza 等人开发,是 Scrapy 社区为解决分布式爬虫需求而诞生的一个扩展组件。它的第一个版本大约发布于 2012年左右,与 Scrapy 0.16 版本同期发展。

  • 核心开发者

    • Rolando Espinoza:Scrapy-Redis 项目的早期核心贡献者,为分布式爬虫架构奠定了基础。

    • Scrapy 开发团队:Scrapy-Redis 目前由 Zyte(原 Scrapinghub)公司和开源社区共同维护,是 Scrapy 生态中最流行的分布式扩展之一。

    • 开源社区贡献:超过 80 位贡献者参与优化和扩展。

  • 项目定位:一个基于 Redis 的 Scrapy 分布式组件,用于将 Scrapy 单机爬虫扩展为分布式爬虫系统。它通过 Redis 实现请求的分布式调度、去重和爬虫状态的同步,使得多台机器可以协同工作,共同完成大规模抓取任务。

2. 官方资源

  • GitHub 地址https://github.com/rmax/scrapy-redis

  • PyPI 地址https://pypi.org/project/scrapy-redis/

  • 官方文档https://scrapy-redis.readthedocs.io/

3. 核心功能

4. 应用场景

1. 大规模分布式数据采集
# settings.py 配置SCHEDULER = "scrapy_redis.scheduler.Scheduler"DUPEFILTER_CLASS = "scrapy_redis.dupefilter.RFPDupeFilter"REDIS_URL = 'redis://redis-server:6379'# 爬虫定义 (继承 RedisSpider)from scrapy_redis.spiders import RedisSpiderclass DomainSpider(RedisSpider):name = 'domain_spider'redis_key = 'domain:start_urls'# 从 Redis 读取起始 URLdef parse(selfresponse):# 处理逻辑for url in response.css('a::attr(href)').getall():yield {'url'url}

启动方式

# 在任意一台机器上启动爬虫scrapy crawl domain_spider# 在 Redis 中添加起始 URLredis-cli> lpush domain:start_urls https://example.com
2. 多爬虫共享任务队列
# 多个爬虫可以消费同一个任务队列# 爬虫 A (product_spider.py)class ProductSpider(RedisSpider):name = 'product_spider'redis_key = 'common:product_urls'# 爬虫 B (review_spider.py)  class ReviewSpider(RedisSpider):name = 'review_spider'redis_key = 'common:product_urls'# 同样消费 product_urls 队列# 这样两个爬虫可以并行处理同一批商品链接
3. 动态任务注入与优先级控制
# 通过 Redis 命令动态添加不同优先级的任务import redisr = redis.Redis()# 添加普通优先级任务r.lpush('myspider:requests''https://example.com/page1')# 添加高优先级任务(通过不同的 Redis 键实现优先级)r.lpush('myspider:high_priority_requests''https://example.com/important')# 爬虫中可以配置多个队列class PrioritySpider(RedisSpider):name = 'priority_spider'redis_key = 'myspider:requests'# 通过自定义调度器实现优先级队列def start_requests(self):# 先处理高优先级队列yield from self._get_requests_from_redis('high_priority_requests')# 再处理普通队列yield from self._get_requests_from_redis('requests')
4. 断点续爬与容灾恢复
# scrapy-redis 自动实现了断点续爬# 即使爬虫进程崩溃重启,也不会重复抓取已处理过的 URL# 检查 Redis 中当前的任务状态import redisr = redis.Redis()# 查看待处理任务数量pending = r.llen('myspider:requests')print(f"待处理任务: {pending}")# 查看已处理任务数量(去重集合大小)processed = r.scard('myspider:dupefilter')print(f"已处理任务: {processed}")# 清除去重集合(强制重新抓取)r.delete('myspider:dupefilter')

5. 底层逻辑与技术原理

核心架构
关键技术
  1. 基于 Redis 的分布式调度器

    • 替换 Scrapy 默认的本地调度器,使用 Redis 的 List、Set 或 Sorted Set 作为请求队列。

    • 支持 FIFO(List)、LIFO(List 右进左出)和优先级队列(Sorted Set)。

    • 多个爬虫实例从同一个 Redis 队列中 pop 请求,实现任务分发。

  2. 分布式去重过滤器

    • 使用 Redis 的 Set 数据结构存储已处理请求的指纹。

    • 指纹通常通过请求的 URL、方法和参数的哈希值生成。

    • 所有爬虫实例共享同一个去重集合,避免重复抓取。

  3. Spider 状态同步

    • 爬虫从 Redis 中读取 start_urls,而不是从本地配置读取。

    • 爬虫关闭后,未完成的任务仍保留在 Redis 队列中,下次启动可继续。

  4. 原子性操作

    • 使用 Redis 的 lpop/rpopsadd 等原子命令,确保多个爬虫实例不会重复消费同一个请求。

    • 利用 Redis 的事务特性保证请求提取和去重记录的一致性。

  5. 数据持久化

    • Redis 的持久化机制(RDB/AOF)确保任务队列和去重记录在系统重启后不丢失。

    • 支持主从复制和哨兵模式,提高系统可用性。


6. 安装与配置

基础安装
# 安装 scrapy-redispip install scrapy-redis# 需要先安装 Redis 服务器# Ubuntu/Debian: sudo apt-get install redis-server# macOS: brew install redis# Windows: 下载 Windows 版本或使用 WSL
Scrapy 项目配置

在 Scrapy 项目的 settings.py 中添加以下配置:

# 启用 Redis 调度器和去重过滤器SCHEDULER = "scrapy_redis.scheduler.Scheduler"DUPEFILTER_CLASS = "scrapy_redis.dupefilter.RFPDupeFilter"# Redis 连接配置REDIS_URL = 'redis://:password@host:port/db'# 或使用独立配置REDIS_HOST = 'localhost'REDIS_PORT = 6379REDIS_PASSWORD = ''REDIS_DB = 0# 可选:请求序列化方式(默认使用 pickle)SCHEDULER_SERIALIZER = "scrapy_redis.picklecompat"# 可选:队列模式(默认是 PriorityQueue)SCHEDULER_QUEUE_CLASS = 'scrapy_redis.queue.PriorityQueue'# 其他选项:FifoQueue, LifoQueue# 可选:是否持久化去重记录(重启后不清空)DUPEFILTER_PERSIST = True# 可选:空闲时是否暂停爬虫(等待新任务)SCHEDULER_IDLE_BEFORE_CLOSE = 10# 可选:Item 存储到 RedisITEM_PIPELINES = {'scrapy_redis.pipelines.RedisPipeline'300,}
爬虫定义
from scrapy_redis.spiders import RedisSpiderclass MySpider(RedisSpider):name = 'myspider'# 从 Redis 中读取起始 URL 的键名redis_key = 'myspider:start_urls'# 可选:允许的域名allowed_domains = ['example.com']def parse(selfresponse):# 提取数据yield {'url'response.url,'title'response.css('title::text').get(),        }# 提取新链接并加入队列for href in response.css('a::attr(href)').getall():yield scrapy.Request(url=response.urljoin(href))
环境要求
组件最低要求推荐配置
Python3.6+3.8+
Scrapy1.0+2.0+
Redis2.8+5.0+
Redis-py2.10+3.5+
操作系统所有平台Linux(生产环境最佳)

7. 性能指标

配置/场景请求速率Redis 内存占用网络带宽
单爬虫 + 单 Redis500-1000 请求/秒低(取决于队列大小)
10 爬虫实例 + 单 Redis3000-5000 请求/秒中等中等
100 爬虫实例 + Redis 集群10000-20000 请求/秒

优化建议

  • 使用 Redis 集群或哨兵模式避免单点故障。

  • 适当设置 SCHEDULER_IDLE_BEFORE_CLOSE 避免爬虫过早退出。

  • 对于超大规模抓取,考虑对请求队列进行分片(多个 Redis 键)。

  • 使用 RedisPipeline 时注意 Redis 内存限制,可配合其他持久化方案。


8. 高级功能使用

1. 自定义请求队列(优先级队列)
# 使用 Redis Sorted Set 实现优先级队列SCHEDULER_QUEUE_CLASS = 'scrapy_redis.queue.PriorityQueue'# 在爬虫中设置请求优先级from scrapy.http import Requestclass PrioritySpider(RedisSpider):name = 'priority_spider'redis_key = 'priority:start_urls'def parse(selfresponse):# 高优先级请求yield Request(url='https://example.com/important',priority=10,  # 数字越大优先级越高callback=self.parse_important        )# 低优先级请求yield Request(url='https://example.com/normal',priority=0        )
2. 分布式 Item 处理(使用 RedisPipeline)
# settings.pyITEM_PIPELINES = {'scrapy_redis.pipelines.RedisPipeline'300,'myproject.pipelines.CustomPipeline'400,}REDIS_ITEMS_KEY = '%(spider)s:items'# 默认键名格式REDIS_ITEMS_SERIALIZER = 'json'# 可选 'pickle' 或 'json'# 另一个进程可以消费 Redis 中的 Itemsimport redisimport jsonr = redis.Redis()while True:# 阻塞获取 Itemitem_data = r.blpop('myspider:items'timeout=0)if item_data:item = json.loads(item_data[1])# 将 Item 存入数据库save_to_database(item)
3. 动态添加任务(外部系统集成)
# web_api.py - Flask 应用接收抓取请求from flask import Flaskrequestimport redisimport jsonapp = Flask(__name__)r = redis.Redis()@app.route('/crawl'methods=['POST'])def add_crawl_task():data = request.jsonurl = data.get('url')priority = data.get('priority'0)# 创建请求对象(需要与爬虫的序列化兼容)request_obj = {'url'url,'method''GET','priority'priority,'callback''parse_product','dont_filter'False    }# 添加到 Redis 队列r.lpush('crawler:requests'json.dumps(request_obj))return {'status''ok''url'url}if __name__ == '__main__':app.run(port=5000)
4. 监控和管理
# monitor.py - 实时监控爬虫状态import redisimport timer = redis.Redis()def monitor_spider(spider_name):while True:# 获取队列大小pending = r.llen(f'{spider_name}:requests')# 获取去重集合大小processed = r.scard(f'{spider_name}:dupefilter')# 获取已抓取 Item 数量items = r.llen(f'{spider_name}:items')print(f"[{time.strftime('%H:%M:%S')}] "f"待处理: {pending}, 已处理: {processed}, Items: {items}")# 检查爬虫实例数量workers = r.get(f'{spider_name}:workers'or 0print(f"活跃爬虫实例: {workers}")time.sleep(5)# 在爬虫启动时记录实例数# 可以在爬虫的 spider_opened/spider_closed 中更新计数器

9. 与同类工具对比

特性Scrapy-RedisScrapy-ClusterGerapyFrontera自实现 Redis 调度
定位轻量级分布式扩展完整集群解决方案分布式管理平台爬虫策略框架定制化实现
安装复杂度中等不定
功能完整度调度+去重完整生态系统调度+监控+部署爬取策略取决于实现
扩展性⭐⭐⭐⭐⭐⭐⭐⭐⭐⭐⭐⭐⭐⭐⭐⭐⭐⭐⭐⭐⭐
社区活跃度中等中等-
适用场景已有 Scrapy 项目分布式化全新大型分布式系统爬虫集群管理自适应爬取策略特殊需求

10. 企业级应用案例

  1. 电商价格监控平台

    • 某比价网站使用 50+ 台服务器部署 Scrapy-Redis 爬虫,实时抓取数百个电商网站的商品价格。

    • Redis 集群存储待抓取 URL 队列和去重记录,单日处理 URL 量超过 1 亿。

  2. 新闻舆情分析系统

    • 舆情公司使用 Scrapy-Redis 构建分布式爬虫集群,实时抓取新闻网站和社交媒体。

    • 通过 Redis 的发布/订阅机制实现抓取任务的动态调度。

  3. 搜索引擎数据源

    • 垂直搜索引擎使用 Scrapy-Redis 定期更新索引数据,多台机器协同抓取,确保数据新鲜度。

    • 利用 Redis 持久化功能实现断点续爬,避免因机器故障导致的数据丢失。

  4. 学术研究数据采集

    • 研究机构使用 Scrapy-Redis 在云服务器集群上部署爬虫,采集大规模学术论文数据。

    • 通过 Redis 的优先级队列优先抓取重要来源网站。


总结

Scrapy-Redis 是 Scrapy 生态中最成熟、最易用的分布式爬虫解决方案,核心价值在于:

  1. 无缝集成:只需简单配置即可将现有 Scrapy 爬虫扩展为分布式系统。

  2. 轻量高效:基于 Redis 实现核心分布式功能,无额外复杂依赖。

  3. 功能完备:提供分布式调度、去重、队列管理、状态同步等完整功能。

  4. 生产验证:经过大量企业级项目的实践检验,稳定可靠。

技术亮点

  • 请求队列共享:多机协作,充分利用计算资源。

  • 分布式去重:避免跨机器重复抓取,节省带宽。

  • 断点续爬:系统崩溃或重启后自动恢复,无需人工干预。

  • 动态任务注入:可与其他系统集成,实现实时任务分发。

适用场景

  • 大规模数据采集:需要多台机器协同工作。

  • 高可用抓取系统:要求任务不丢失、可恢复。

  • 动态任务分发:需要外部系统实时注入抓取任务。

  • 已有 Scrapy 项目扩展:最小化改造成本实现分布式。

何时可能不适用

  • 小规模抓取任务:单机足够,无需分布式复杂化。

  • 需要浏览器渲染的爬虫:仍需集成 Splash/Selenium。

  • 对实时性要求极高的系统:Redis 队列可能成为瓶颈。

安装使用

pip install scrapy-redis# 配置 settings.py# 继承 RedisSpider 编写爬虫

学习资源

  • 官方文档https://scrapy-redis.readthedocs.io/

  • GitHub 仓库https://github.com/rmax/scrapy-redis

  • 实战教程Scrapy-Redis 分布式爬虫实战

截至 2024 年,Scrapy-Redis 在 GitHub 收获 4.5k+ Star,是 Scrapy 用户进行分布式爬虫的首选扩展。项目遵循 MIT 开源协议,可免费用于商业和非商业项目。

最新文章

随机文章

基本 文件 流程 错误 SQL 调试
  1. 请求信息 : 2026-02-28 08:58:19 HTTP/2.0 GET : https://f.mffb.com.cn/a/476563.html
  2. 运行时间 : 0.171910s [ 吞吐率:5.82req/s ] 内存消耗:4,741.24kb 文件加载:140
  3. 缓存信息 : 0 reads,0 writes
  4. 会话信息 : SESSION_ID=aa424c517f235543ae9fbe060eaac1d9
  1. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/public/index.php ( 0.79 KB )
  2. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/autoload.php ( 0.17 KB )
  3. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/composer/autoload_real.php ( 2.49 KB )
  4. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/composer/platform_check.php ( 0.90 KB )
  5. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/composer/ClassLoader.php ( 14.03 KB )
  6. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/composer/autoload_static.php ( 4.90 KB )
  7. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-helper/src/helper.php ( 8.34 KB )
  8. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-validate/src/helper.php ( 2.19 KB )
  9. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/helper.php ( 1.47 KB )
  10. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/stubs/load_stubs.php ( 0.16 KB )
  11. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Exception.php ( 1.69 KB )
  12. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-container/src/Facade.php ( 2.71 KB )
  13. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/symfony/deprecation-contracts/function.php ( 0.99 KB )
  14. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/symfony/polyfill-mbstring/bootstrap.php ( 8.26 KB )
  15. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/symfony/polyfill-mbstring/bootstrap80.php ( 9.78 KB )
  16. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/symfony/var-dumper/Resources/functions/dump.php ( 1.49 KB )
  17. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-dumper/src/helper.php ( 0.18 KB )
  18. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/symfony/var-dumper/VarDumper.php ( 4.30 KB )
  19. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/App.php ( 15.30 KB )
  20. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-container/src/Container.php ( 15.76 KB )
  21. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/psr/container/src/ContainerInterface.php ( 1.02 KB )
  22. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/app/provider.php ( 0.19 KB )
  23. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Http.php ( 6.04 KB )
  24. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-helper/src/helper/Str.php ( 7.29 KB )
  25. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Env.php ( 4.68 KB )
  26. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/app/common.php ( 0.03 KB )
  27. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/helper.php ( 18.78 KB )
  28. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Config.php ( 5.54 KB )
  29. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/config/app.php ( 0.95 KB )
  30. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/config/cache.php ( 0.78 KB )
  31. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/config/console.php ( 0.23 KB )
  32. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/config/cookie.php ( 0.56 KB )
  33. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/config/database.php ( 2.48 KB )
  34. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/facade/Env.php ( 1.67 KB )
  35. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/config/filesystem.php ( 0.61 KB )
  36. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/config/lang.php ( 0.91 KB )
  37. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/config/log.php ( 1.35 KB )
  38. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/config/middleware.php ( 0.19 KB )
  39. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/config/route.php ( 1.89 KB )
  40. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/config/session.php ( 0.57 KB )
  41. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/config/trace.php ( 0.34 KB )
  42. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/config/view.php ( 0.82 KB )
  43. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/app/event.php ( 0.25 KB )
  44. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Event.php ( 7.67 KB )
  45. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/app/service.php ( 0.13 KB )
  46. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/app/AppService.php ( 0.26 KB )
  47. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Service.php ( 1.64 KB )
  48. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Lang.php ( 7.35 KB )
  49. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/lang/zh-cn.php ( 13.70 KB )
  50. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/initializer/Error.php ( 3.31 KB )
  51. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/initializer/RegisterService.php ( 1.33 KB )
  52. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/services.php ( 0.14 KB )
  53. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/service/PaginatorService.php ( 1.52 KB )
  54. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/service/ValidateService.php ( 0.99 KB )
  55. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/service/ModelService.php ( 2.04 KB )
  56. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-trace/src/Service.php ( 0.77 KB )
  57. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Middleware.php ( 6.72 KB )
  58. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/initializer/BootService.php ( 0.77 KB )
  59. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/Paginator.php ( 11.86 KB )
  60. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-validate/src/Validate.php ( 63.20 KB )
  61. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/Model.php ( 23.55 KB )
  62. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/model/concern/Attribute.php ( 21.05 KB )
  63. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/model/concern/AutoWriteData.php ( 4.21 KB )
  64. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/model/concern/Conversion.php ( 6.44 KB )
  65. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/model/concern/DbConnect.php ( 5.16 KB )
  66. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/model/concern/ModelEvent.php ( 2.33 KB )
  67. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/model/concern/RelationShip.php ( 28.29 KB )
  68. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-helper/src/contract/Arrayable.php ( 0.09 KB )
  69. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-helper/src/contract/Jsonable.php ( 0.13 KB )
  70. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/model/contract/Modelable.php ( 0.09 KB )
  71. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Db.php ( 2.88 KB )
  72. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/DbManager.php ( 8.52 KB )
  73. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Log.php ( 6.28 KB )
  74. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Manager.php ( 3.92 KB )
  75. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/psr/log/src/LoggerTrait.php ( 2.69 KB )
  76. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/psr/log/src/LoggerInterface.php ( 2.71 KB )
  77. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Cache.php ( 4.92 KB )
  78. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/psr/simple-cache/src/CacheInterface.php ( 4.71 KB )
  79. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-helper/src/helper/Arr.php ( 16.63 KB )
  80. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/cache/driver/File.php ( 7.84 KB )
  81. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/cache/Driver.php ( 9.03 KB )
  82. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/contract/CacheHandlerInterface.php ( 1.99 KB )
  83. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/app/Request.php ( 0.09 KB )
  84. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Request.php ( 55.78 KB )
  85. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/app/middleware.php ( 0.25 KB )
  86. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Pipeline.php ( 2.61 KB )
  87. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-trace/src/TraceDebug.php ( 3.40 KB )
  88. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/middleware/SessionInit.php ( 1.94 KB )
  89. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Session.php ( 1.80 KB )
  90. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/session/driver/File.php ( 6.27 KB )
  91. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/contract/SessionHandlerInterface.php ( 0.87 KB )
  92. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/session/Store.php ( 7.12 KB )
  93. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Route.php ( 23.73 KB )
  94. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/route/RuleName.php ( 5.75 KB )
  95. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/route/Domain.php ( 2.53 KB )
  96. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/route/RuleGroup.php ( 22.43 KB )
  97. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/route/Rule.php ( 26.95 KB )
  98. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/route/RuleItem.php ( 9.78 KB )
  99. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/route/app.php ( 1.72 KB )
  100. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/facade/Route.php ( 4.70 KB )
  101. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/route/dispatch/Controller.php ( 4.74 KB )
  102. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/route/Dispatch.php ( 10.44 KB )
  103. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/app/controller/Index.php ( 4.81 KB )
  104. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/app/BaseController.php ( 2.05 KB )
  105. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/facade/Db.php ( 0.93 KB )
  106. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/connector/Mysql.php ( 5.44 KB )
  107. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/PDOConnection.php ( 52.47 KB )
  108. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/Connection.php ( 8.39 KB )
  109. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/ConnectionInterface.php ( 4.57 KB )
  110. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/builder/Mysql.php ( 16.58 KB )
  111. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/Builder.php ( 24.06 KB )
  112. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/BaseBuilder.php ( 27.50 KB )
  113. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/Query.php ( 15.71 KB )
  114. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/BaseQuery.php ( 45.13 KB )
  115. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/concern/TimeFieldQuery.php ( 7.43 KB )
  116. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/concern/AggregateQuery.php ( 3.26 KB )
  117. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/concern/ModelRelationQuery.php ( 20.07 KB )
  118. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/concern/ParamsBind.php ( 3.66 KB )
  119. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/concern/ResultOperation.php ( 7.01 KB )
  120. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/concern/WhereQuery.php ( 19.37 KB )
  121. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/concern/JoinAndViewQuery.php ( 7.11 KB )
  122. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/concern/TableFieldInfo.php ( 2.63 KB )
  123. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/concern/Transaction.php ( 2.77 KB )
  124. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/log/driver/File.php ( 5.96 KB )
  125. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/contract/LogHandlerInterface.php ( 0.86 KB )
  126. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/log/Channel.php ( 3.89 KB )
  127. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/event/LogRecord.php ( 1.02 KB )
  128. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-helper/src/Collection.php ( 16.47 KB )
  129. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/facade/View.php ( 1.70 KB )
  130. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/View.php ( 4.39 KB )
  131. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Response.php ( 8.81 KB )
  132. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/response/View.php ( 3.29 KB )
  133. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Cookie.php ( 6.06 KB )
  134. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-view/src/Think.php ( 8.38 KB )
  135. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/contract/TemplateHandlerInterface.php ( 1.60 KB )
  136. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-template/src/Template.php ( 46.61 KB )
  137. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-template/src/template/driver/File.php ( 2.41 KB )
  138. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-template/src/template/contract/DriverInterface.php ( 0.86 KB )
  139. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/runtime/temp/067d451b9a0c665040f3f1bdd3293d68.php ( 11.98 KB )
  140. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-trace/src/Html.php ( 4.42 KB )
  1. CONNECT:[ UseTime:0.001021s ] mysql:host=127.0.0.1;port=3306;dbname=f_mffb;charset=utf8mb4
  2. SHOW FULL COLUMNS FROM `fenlei` [ RunTime:0.001378s ]
  3. SELECT * FROM `fenlei` WHERE `fid` = 0 [ RunTime:0.048074s ]
  4. SELECT * FROM `fenlei` WHERE `fid` = 63 [ RunTime:0.001829s ]
  5. SHOW FULL COLUMNS FROM `set` [ RunTime:0.001550s ]
  6. SELECT * FROM `set` [ RunTime:0.000736s ]
  7. SHOW FULL COLUMNS FROM `article` [ RunTime:0.001730s ]
  8. SELECT * FROM `article` WHERE `id` = 476563 LIMIT 1 [ RunTime:0.005050s ]
  9. UPDATE `article` SET `lasttime` = 1772240299 WHERE `id` = 476563 [ RunTime:0.020194s ]
  10. SELECT * FROM `fenlei` WHERE `id` = 66 LIMIT 1 [ RunTime:0.000370s ]
  11. SELECT * FROM `article` WHERE `id` < 476563 ORDER BY `id` DESC LIMIT 1 [ RunTime:0.000412s ]
  12. SELECT * FROM `article` WHERE `id` > 476563 ORDER BY `id` ASC LIMIT 1 [ RunTime:0.000439s ]
  13. SELECT * FROM `article` WHERE `id` < 476563 ORDER BY `id` DESC LIMIT 10 [ RunTime:0.010240s ]
  14. SELECT * FROM `article` WHERE `id` < 476563 ORDER BY `id` DESC LIMIT 10,10 [ RunTime:0.004076s ]
  15. SELECT * FROM `article` WHERE `id` < 476563 ORDER BY `id` DESC LIMIT 20,10 [ RunTime:0.001282s ]
0.173554s