当前位置:首页>python>超级缓存:Cashews 如何在 Python 异步应用中实现“10x 加速

超级缓存:Cashews 如何在 Python 异步应用中实现“10x 加速

  • 2026-03-23 00:20:06
超级缓存:Cashews 如何在 Python 异步应用中实现“10x 加速

超级缓存:Cashews 如何在 Python 异步应用中实现“10x 加速

🥔 异步缓存框架,简洁API打造快速可靠的应用 🥔


📝 引言

在现代应用中,缓存不是一种选择,而是一种必需品。但传统的缓存工具往往功能单一,面对缓存雪崩、缓存穿透、缓存击穿等经典问题,开发者需要自己实现各种复杂的保护机制。

今天介绍的开源框架Cashews(土豆),以简洁的装饰器API强大的异步能力,让这些高级缓存策略变得触手可及。

📊 官方数据显示:在启用客户端缓存的情况下,Cashews比另一个流行框架aiocache快2倍以上


🥔 Cashews是什么?

Cashews是一个基于异步编程的缓存框架,提供简单易用的API,帮助开发者构建快速、可靠和可扩展的应用程序。

💡 有趣的事实:项目名称“Cashews”(腰果)虽为谐音,但其图标却是🥔(土豆),也许正是暗示它像土豆一样朴实却万能的特性。


✨ 核心特性

特性
描述
🎯 易于配置和使用
简洁的API设计,快速上手
🎨 装饰器式API
一行装饰器搞定缓存逻辑
📦 多种缓存策略
内置多种开箱即用的缓存策略
💾 多后端支持
内存、Redis、DiskCache自由切换
⏱️ 灵活的TTL设置
字符串/"2h5m"/timedelta/函数
🔒 事务支持
保证缓存操作的原子性
🔄 中间件机制
支持自定义中间件扩展
⚡ 客户端缓存
比普通Redis缓存快10倍
🌸 布隆过滤器
高效判断元素是否存在
🏷️ 标签失效
基于标签的缓存失效机制
📦 对象序列化
支持pickle/dill/json等多种方式
🗜️ 压缩支持
支持gzip/zlib压缩节省内存

📊 与其他框架对比

特性CashewsAiocacheCachetools
异步支持
⚡ 原生异步
✅ 支持
❌ 仅同步
客户端缓存
🚀 10倍速度提升
缓存击穿保护
🛡️ 内置
⚠️ 需手动实现
⚠️ 需手动实现
布隆过滤器
✅ 支持
标签失效
✅ 支持
TTL设置灵活性
📝 字符串/函数/timedelta
📝 timedelta
📝 整数/timedelta
性能
⭐ 2倍于aiocache
📊 基准
N/A
最近更新
2025-12
2026-02
2024-09

🚀 快速上手

📦 安装

# 基础安装(内存缓存)pip install cashews# Redis支持(分布式缓存)pip install cashews[redis]# DiskCache支持(本地数据库缓存)pip install cashews[diskcache]# 完整功能(布隆过滤器等)pip install cashews[speedup]

💻 基础用法

from cashews import cacheimport asyncio# 配置内存缓存cache.setup("mem://")# 装饰器模式:自动缓存函数结果@cache(ttl="10m", key="user:{user_id}")asyncdefget_user(user_id: int):await asyncio.sleep(1)  # 模拟数据库查询return {"id": user_id, "name"f"User{user_id}"}asyncdefmain():# 第一次调用:执行函数,耗时1秒    user1 = await get_user(1)print("✅ 第一次调用完成 - 耗时1秒")# 第二次调用:从缓存读取,瞬间返回    user2 = await get_user(1)print("⚡ 第二次调用完成 - 瞬间返回")asyncio.run(main())

✨ 通过装饰器轻松实现缓存逻辑无需侵入业务代码


🛡️ 解决分布式缓存三大难题

1. Early Cache:解决缓存雪崩

缓存雪崩指大量缓存同时过期,导致请求直接打到数据库。Cashews提供了early策略,在缓存即将过期时异步更新缓存

from cashews import cachecache.setup("redis://localhost:6379")# 10分钟过期,7分钟时在后台自动更新@cache.early(ttl="10m", early_ttl="7m")asyncdefget_popular_products():returnawait fetch_products_from_db()

🔒 确保缓存始终有效彻底避免缓存雪崩


2. Soft Cache:解决缓存击穿

缓存击穿指热点key失效,高并发请求同时查询数据库。Soft策略允许缓存过期后继续使用旧数据,同时异步更新:

@cache.soft(ttl="10m", soft_ttl="1h")asyncdefget_hot_product(product_id: int):"""1小时内即使缓存过期也返回旧值"""returnawait fetch_product(product_id)

💪 确保系统持续可用,即使后端服务暂时不可用。


3. Locked:解决缓存击穿(另一角度)

确保只有一个请求会执行函数,其他并发请求等待结果:

@cache.locked(ttl="10s")asyncdefexpensive_computation():# 同时被100个请求调用,只有第一个实际执行returnawait compute()# 与缓存组合使用@cache(ttl="1h", lock=True)asyncdefget_expensive_data():"""锁保证单次执行,缓存保证后续快速返回"""returnawait compute()

📉 Fail Cache:服务降级利器

微服务架构中,当服务不可用时,使用缓存数据作为降级方案:

@cache.failover(ttl="30m", exceptions=(TimeoutError, ConnectionError))asyncdeffetch_from_microservice(service_id: str):"""调用微服务API,失败时返回缓存的旧数据"""returnawait call_service(service_id)

🚨 只要有一次成功调用,当服务再次异常时,自动返回缓存数据,实现优雅的服务降级


⏱️ 限流与熔断

速率限制

from cashews import cache, RateLimitError# 每分钟最多10次调用,超限后禁用10分钟@cache.rate_limit(limit=10, period="1m", ttl="10m")asyncdefget(name):returnawait api_call()# 与故障转移组合@cache.failover(ttl="10m", exceptions=(RateLimitError,))@cache.slice_rate_limit(limit=100, period="10m")asyncdefget_next(name):"""限流时返回缓存数据"""returnawait api_call()

熔断器

from cashews import cache, CircuitBreakerOpen# 1分钟内错误率超过10%时熔断5分钟@cache.circuit_breaker(errors_rate=10, period="1m", ttl="5m")asyncdefget(name):returnawait api_call()

🎨 灵活的Key模板

基础模板

@cache(ttl="2h", key="user_info:{user_id}")asyncdefget_info(user_id: str):    ...@cache(ttl="2h", key="user_info:{user.uuid}")asyncdefget_info(user: User):    ...

内置格式化函数

@cache(ttl="2h", key="user_info:{user.name:lower}:{password:hash(sha1)}")asyncdefget_info(user: User, password: str):    ...@cache(ttl="2h", key="user:{token:jwt(client_id)}")asyncdefget_user_by_token(token: str):    ...

💾 多后端存储

基于前缀的路由

from cashews import cache# 根据不同前缀使用不同后端cache.setup("redis://redis/0")                    # 默认Rediscache.setup("mem://?size=500", prefix="session")  # session使用内存cache.setup("disk://?directory=/tmp/cache", prefix="file")  # 文件使用磁盘# 使用方式完全一致await cache.get("accounts")        # 从Redis获取await cache.get("session:1")       # 从内存获取await cache.get("file:resume.pdf"# 从磁盘获取

Redis客户端缓存(10倍性能提升)

# 启用客户端缓存,热点数据缓存在应用本地内存cache.setup("redis://localhost:6379", client_side=True)@cache(ttl="5m")asyncdefget_frequently_accessed_data(key: str):returnawait expensive_operation(key)

🧹 缓存失效策略

标签失效

避免扫描整个数据库,使用SET存储标签关联的键:

from cashews import cachecache.setup("redis://", client_side=True)@cache(ttl="1h", tags=["items""page:{page}"])asyncdefitems(page=1):    ...# 按标签批量失效await cache.delete_tags("page:1")  # 只失效第1页await cache.delete_tags("items")    # 失效所有items相关的缓存

代码变更自动失效

from dataclasses import dataclass@dataclassclassUser:    name: str    surname: str# 使用数据类,结构变化时__repr__自动变化,缓存失效@cache(ttl="1d")asyncdefget_user(user_id):return User("Dima""Krykov")

🔍 检测结果来源

from cashews import cachewith cache.detect as detector:    response = await something_that_use_cache()    calls = detector.calls# 输出示例:{"my:key": [{"ttl": 10, "name": "simple", "backend": "redis"}]}

FastAPI中间件示例

@app.middleware("http")asyncdefadd_from_cache_headers(request: Request, call_next):with cache.detect as detector:        response = await call_next(request)if detector.calls:            key = list(detector.calls.keys())[0]            response.headers["X-From-Cache"] = keyreturn response

⚡ FastAPI集成

中间件

from fastapi import FastAPI, Header, Queryfrom fastapi.responses import StreamingResponsefrom cashews import cachefrom cashews.contrib.fastapi import (    CacheDeleteMiddleware,    CacheEtagMiddleware,    CacheRequestControlMiddleware,    cache_control_ttl,)app = FastAPI()app.add_middleware(CacheDeleteMiddleware)app.add_middleware(CacheEtagMiddleware)app.add_middleware(CacheRequestControlMiddleware)cache.setup(os.environ.get("CACHE_URI""redis://"))@app.get("/")@cache.failover(ttl="1h")@cache(ttl=cache_control_ttl(default="4m"), key="simple:{user_agent:hash}", time_condition="1s")asyncdefsimple(user_agent: str = Header("No")):    ...@app.get("/stream")@cache(ttl="1m", key="stream:{file_path}")asyncdefstream(file_path: str = Query(__file__)):return StreamingResponse(_read_file(file_path))

📊 Prometheus监控

from cashews import cachefrom cashews.contrib.prometheus import create_metrics_middlewaremetrics_middleware = create_metrics_middleware(with_tag=False)cache.setup("redis://", middlewares=(metrics_middleware,))

🎬 结语

Cashews不仅是一个缓存库,更是一套完整的缓存策略解决方案。

它用简洁的装饰器API封装了复杂的缓存最佳实践,让开发者可以轻松应对高并发场景下的各种挑战。

无论你是正在构建新的异步应用,还是希望优化现有系统的性能,Cashews都值得一试。正如其名,这个小小的“土豆”可能会成为你项目中的秘密武器


📚 资源链接

🔗
链接
📦 项目地址
https://github.com/Krukov/cashews
📖 PyPI页面
https://pypi.org/project/cashews/
💡 示例代码
https://github.com/Krukov/cashews/tree/master/examples

💬 互动话题

你在项目中遇到过哪些缓存难题?欢迎在评论区分享你的经验!

最新文章

随机文章

基本 文件 流程 错误 SQL 调试
  1. 请求信息 : 2026-03-27 19:17:04 HTTP/2.0 GET : https://f.mffb.com.cn/a/477873.html
  2. 运行时间 : 0.173898s [ 吞吐率:5.75req/s ] 内存消耗:4,791.64kb 文件加载:140
  3. 缓存信息 : 0 reads,0 writes
  4. 会话信息 : SESSION_ID=accc691e085abd2eac82428d044e10be
  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.001201s ] mysql:host=127.0.0.1;port=3306;dbname=f_mffb;charset=utf8mb4
  2. SHOW FULL COLUMNS FROM `fenlei` [ RunTime:0.001934s ]
  3. SELECT * FROM `fenlei` WHERE `fid` = 0 [ RunTime:0.000794s ]
  4. SELECT * FROM `fenlei` WHERE `fid` = 63 [ RunTime:0.000829s ]
  5. SHOW FULL COLUMNS FROM `set` [ RunTime:0.001402s ]
  6. SELECT * FROM `set` [ RunTime:0.000562s ]
  7. SHOW FULL COLUMNS FROM `article` [ RunTime:0.001607s ]
  8. SELECT * FROM `article` WHERE `id` = 477873 LIMIT 1 [ RunTime:0.001506s ]
  9. UPDATE `article` SET `lasttime` = 1774610224 WHERE `id` = 477873 [ RunTime:0.016445s ]
  10. SELECT * FROM `fenlei` WHERE `id` = 66 LIMIT 1 [ RunTime:0.000820s ]
  11. SELECT * FROM `article` WHERE `id` < 477873 ORDER BY `id` DESC LIMIT 1 [ RunTime:0.001211s ]
  12. SELECT * FROM `article` WHERE `id` > 477873 ORDER BY `id` ASC LIMIT 1 [ RunTime:0.001121s ]
  13. SELECT * FROM `article` WHERE `id` < 477873 ORDER BY `id` DESC LIMIT 10 [ RunTime:0.002071s ]
  14. SELECT * FROM `article` WHERE `id` < 477873 ORDER BY `id` DESC LIMIT 10,10 [ RunTime:0.002839s ]
  15. SELECT * FROM `article` WHERE `id` < 477873 ORDER BY `id` DESC LIMIT 20,10 [ RunTime:0.004063s ]
0.178069s