当前位置:首页>python>2026年Python异步编程大爆发,你跟上了吗?

2026年Python异步编程大爆发,你跟上了吗?

  • 2026-03-25 16:22:15
2026年Python异步编程大爆发,你跟上了吗?

深入解析Python asyncio的最新特性和最佳实践,轻松应对高并发挑战


📖 引言:你的同步代码,正在被时代抛弃

还在用同步代码写爬虫、API服务器?醒醒,2026年了!

你的服务器CPU占用率不到10%,但请求排队排到法国?

根本原因:你的代码在"等"——等数据库响应、等网络IO、等磁盘读写。

异步编程不是什么新魔法,但asyncio生态在2026年已经彻底成熟。

从Web框架到数据库驱动,从HTTP客户端到消息队列,万物皆可async。

这篇文章,就是你的异步编程爽文通关指南。不讲废话,只给干货。 读完你就能把同步代码,改造成性能怪兽。


🔍 核心原理:把你的代码变成"时间管理大师"

先搞懂底层逻辑,不然你只是在复制粘贴魔法咒语。

1️⃣ 事件循环:你的全能经理

想象一个快餐店经理(事件循环)。

他手下有10个服务员(协程),但只有1个厨房(单线程)。

  • • 传统同步模式:经理让一个服务员盯着厨房等炸鸡,其他9个服务员干站着
  • • 异步模式:经理让服务员A去等炸鸡,立刻安排服务员B去接可乐、C去收桌子… 炸鸡好了?经理立刻通知A来取

结果:1个经理+1个厨房,同时处理了10件事!

import asyncio

asyncdef炸鸡(订单号):
print(f"🍔 订单{订单号}: 开始炸鸡...")
await asyncio.sleep(2)  # 模拟炸鸡耗时2秒(非阻塞等待!)
print(f"🍗 订单{订单号}: 炸鸡完成!")
returnf"炸鸡_{订单号}"

asyncdefmain():
# 经理(事件循环)同时派发3个订单
    tasks = [炸鸡(i) for i inrange(3)]
    results = await asyncio.gather(*tasks)  # 等所有订单完成
print(f"📦 所有订单完成: {results}")

# 启动经理
asyncio.run(main())

💡 关键点await不是阻塞,是让出控制权。"我去等炸鸡,经理你先忙别的!"


2️⃣ 协程:可以暂停的函数

普通函数
协程函数
一旦调用,必须执行完
可以在await处暂停,把CPU让给别人

本质:协程是一个状态机,每次await都是一次状态保存和切换。


3️⃣ Task:经理手里的任务卡

asyncio.create_task() = 经理把任务写在卡片上,立刻扔进待办列表。不立刻await,经理就会同时处理多个卡片。

import asyncio
import time

asyncdef慢任务(名称, 秒数):
print(f"🐢 {名称} 开始,需要{秒数}秒")
await asyncio.sleep(秒数)
print(f"✅ {名称} 完成!")
return 秒数

asyncdefmain():
    start = time.time()

# ❌ 错误:串行等待(总时间 = 3+2+1 = 6秒)
# await 慢任务("任务A", 3)
# await 慢任务("任务B", 2)
# await 慢任务("任务C", 1)

# ✅ 正确:并行执行(总时间 ≈ 3秒)
    task_a = asyncio.create_task(慢任务("任务A"3))
    task_b = asyncio.create_task(慢任务("任务B"2))
    task_c = asyncio.create_task(慢任务("任务C"1))

# 等所有任务完成
await task_a
await task_b
await task_c

print(f"⏱️ 总耗时: {time.time() - start:.1f}秒")

asyncio.run(main())

输出对比:

  • • ❌ 串行输出:总耗时6.0秒
  • • ✅ 并行输出:总耗时3.0秒

💡 实战案例:直接抄作业,马上能用

理论说完,直接上能跑的代码。案例从简单到复杂。


案例1:异步HTTP请求(爬虫/调用API)

痛点:同步请求requests.get()会阻塞整个程序。

import asyncio
import aiohttp
import time

asyncdef抓取网页(session, url):
"""异步抓取单个网页"""
try:
asyncwith session.get(url, timeout=10as response:
            content = await response.text()
print(f"✅ 抓取成功: {url[:50]}... 长度: {len(content)}")
return {"url": url, "status": response.status, "length"len(content)}
except Exception as e:
print(f"❌ 抓取失败: {url[:50]}... 错误: {e}")
returnNone

asyncdefmain():
    urls = [
"https://httpbin.org/delay/1",  # 模拟延迟1秒
"https://httpbin.org/delay/2",  # 模拟延迟2秒
"https://httpbin.org/delay/3",  # 模拟延迟3秒
"https://httpbin.org/status/404",
"https://www.python.org",
"https://github.com",
    ]

    start = time.time()

# 创建一个持久化的HTTP会话(连接池!)
asyncwith aiohttp.ClientSession() as session:
        tasks = [抓取网页(session, url) for url in urls]
        results = await asyncio.gather(*tasks, return_exceptions=True)

    success = [r for r in results if r andnotisinstance(r, Exception)]
print(f"\n📊 统计: 成功{len(success)}/{len(urls)}个")
print(f"⏱️ 总耗时: {time.time() - start:.1f}秒")
# 同步方式至少需要 1+2+3 = 6秒,异步只需要 ≈3秒!

if __name__ == "__main__":
    asyncio.run(main())

关键技巧:

  • • 使用aiohttp.ClientSession()复用TCP连接(性能提升巨大!)
  • • asyncio.gather()批量并发
  • • return_exceptions=True防止一个失败全盘崩溃

案例2:异步数据库操作(以aiosqlite为例)

痛点:数据库查询是典型的IO密集型操作。

import asyncio
import aiosqlite
import random
import time

asyncdef初始化数据库(db_path=":memory:"):
"""创建测试数据库和表"""
asyncwith aiosqlite.connect(db_path) as db:
await db.execute("""
            CREATE TABLE IF NOT EXISTS users (
                id INTEGER PRIMARY KEY AUTOINCREMENT,
                name TEXT NOT NULL,
                age INTEGER,
                city TEXT
            )
        """
)
        users = [(f"用户_{i}", random.randint(1880), random.choice(["北京""上海""广州"])) 
for i inrange(1000)]
await db.executemany("INSERT INTO users (name, age, city) VALUES (?, ?, ?)", users)
await db.commit()
print(f"✅ 数据库初始化完成,插入{len(users)}条数据")

asyncdef查询用户(db, user_id):
"""异步查询单个用户"""
asyncwith db.execute("SELECT * FROM users WHERE id = ?", (user_id,)) as cursor:
        row = await cursor.fetchone()
if row:
return {"id": row[0], "name": row[1], "age": row[2], "city": row[3]}
returnNone

asyncdef批量查询(db, user_ids):
"""并发查询多个用户"""
    tasks = [查询用户(db, uid) for uid in user_ids]
returnawait asyncio.gather(*tasks)

asyncdefmain():
    db_path = "test_async.db"
await 初始化数据库(db_path)

    random_ids = [random.randint(11000for _ inrange(100)]

    start = time.time()
asyncwith aiosqlite.connect(db_path) as db:
        results = await 批量查询(db, random_ids)

    found = [r for r in results if r isnotNone]
print(f"🔍 查询完成: 找到{len(found)}/{len(random_ids)}个用户")
print(f"⏱️ 耗时: {time.time() - start:.3f}秒")

for user in found[:5]:
print(f"  👤 {user['name']}{user['age']}岁, 来自{user['city']}")

if __name__ == "__main__":
    asyncio.run(main())

性能对比:

  • • 同步查询100次:每次等待数据库响应 → 总时间 ≈ 100 * 单次查询时间
  • • 异步查询100次:并发发送所有查询 → 总时间 ≈ 最慢的那次查询时间

案例3:异步WebSocket服务器(实时通信)

痛点:传统同步服务器处理WebSocket连接数有限。

import asyncio
import websockets
import json
from datetime import datetime

connected_clients = set()

asyncdef广播消息(message, sender=None):
"""向所有客户端广播消息"""
if connected_clients:
        tasks = []
for client in connected_clients:
if client != sender:
                tasks.append(client.send(json.dumps(message)))
if tasks:
await asyncio.gather(*tasks, return_exceptions=True)

asyncdef处理客户端(websocket, path):
    client_id = f"客户端_{id(websocket)}"
    connected_clients.add(websocket)
print(f"🟢 {client_id} 已连接,当前连接数: {len(connected_clients)}")

await websocket.send(json.dumps({
"type""system",
"message"f"欢迎 {client_id}!当前在线: {len(connected_clients)}人",
"timestamp": datetime.now().isoformat()
    }))

await 广播消息({
"type""join",
"client": client_id,
"message"f"{client_id} 加入了聊天室",
"timestamp": datetime.now().isoformat()
    }, sender=websocket)

try:
asyncfor message in websocket:
            data = json.loads(message)
print(f"📨 收到来自 {client_id}{data.get('content''')}")
await 广播消息({
"type""chat",
"client": client_id,
"content": data.get("content"""),
"timestamp": datetime.now().isoformat()
            }, sender=websocket)
except websockets.exceptions.ConnectionClosed:
pass
finally:
        connected_clients.discard(websocket)
print(f"🔴 {client_id} 已断开,当前连接数: {len(connected_clients)}")
await 广播消息({
"type""leave",
"client": client_id,
"message"f"{client_id} 离开了聊天室",
"timestamp": datetime.now().isoformat()
        })

asyncdefmain():
    server = await websockets.serve(处理客户端, "localhost"8765)
print("🚀 WebSocket服务器已启动: ws://localhost:8765")
await server.wait_closed()

if __name__ == "__main__":
    asyncio.run(main())

🚀 高级技巧:让异步代码飞起来

掌握了基础,现在来点进阶操作。

1️⃣ 异步生成器:流式处理大数据

处理大文件或数据库结果集时,别一次性加载到内存!

import asyncio
import aiofiles

asyncdef异步读取大文件(file_path, chunk_size=1024):
"""异步生成器:逐块读取文件"""
asyncwith aiofiles.open(file_path, 'rb'as f:
whileTrue:
            chunk = await f.read(chunk_size)
ifnot chunk:
break
yield chunk

asyncdef处理数据块(chunk):
await asyncio.sleep(0.1)
returnlen(chunk)

asyncdefmain():
    test_file = "large_test_file.bin"
asyncwith aiofiles.open(test_file, 'wb'as f:
await f.write(b'0' * 10 * 1024 * 1024)

    total_size = 0
    processed_chunks = 0

asyncfor chunk in 异步读取大文件(test_file, chunk_size=64*1024):
        size = await 处理数据块(chunk)
        total_size += size
        processed_chunks += 1
if processed_chunks % 10 == 0:
print(f"已处理 {processed_chunks} 块,累计 {total_size/(1024*1024):.1f} MB")

print(f"✅ 处理完成: {processed_chunks} 块,总计 {total_size/(1024*1024):.1f} MB")

asyncio.run(main())

💡 优势:内存占用恒定,不管文件多大。


2️⃣ Asyncio.TaskGroup:Python 3.11+的优雅并发

gather()更安全,一个任务失败会自动取消其他任务。

import asyncio

asyncdef可能失败的任务(名称, 失败=False):
print(f"🚀 任务 {名称} 开始")
await asyncio.sleep(1)
if 失败:
raise ValueError(f"任务 {名称} 故意失败!")
print(f"✅ 任务 {名称} 完成")
return 名称

asyncdefmain():
try:
asyncwith asyncio.TaskGroup() as tg:
            task1 = tg.create_task(可能失败的任务("A"))
            task2 = tg.create_task(可能失败的任务("B", 失败=True))
            task3 = tg.create_task(可能失败的任务("C"))
except* ValueError as eg:
print(f"捕获到异常组: {eg.exceptions}")
print("程序继续执行...")

asyncio.run(main())

3️⃣ Semaphore:控制并发数量

防止同时发起太多请求,被服务器封IP。

import asyncio
import aiohttp
from asyncio import Semaphore

asyncdef限制并发请求(session, url, semaphore):
asyncwith semaphore:
print(f"🌐 开始请求: {url[:30]}...")
try:
asyncwith session.get(url) as response:
await asyncio.sleep(0.5)
return response.status
except Exception as e:
returnf"错误: {e}"

asyncdefmain():
    urls = [f"https://httpbin.org/delay/{i%3+1}"for i inrange(20)]
    semaphore = Semaphore(5)  # 最多同时5个并发

asyncwith aiohttp.ClientSession() as session:
        tasks = [限制并发请求(session, url, semaphore) for url in urls]
        results = await asyncio.gather(*tasks)

print(f"完成 {len(results)} 个请求")

asyncio.run(main())

⚠️ 常见误区:这些坑我替你踩过了

新手最容易犯的错,看看你中了几个。


❌ 误区1:在异步函数里调用同步阻塞代码

import requests  # 同步库!

asyncdef错误示例():
    response = requests.get("https://httpbin.org/delay/2")  # ❌ 阻塞!
    time.sleep(1)  # ❌ 阻塞!

asyncdef正确示例():
import aiohttp
asyncwith aiohttp.ClientSession() as session:
asyncwith session.get("https://httpbin.org/delay/2"as response:
await response.text()
await asyncio.sleep(1)  # ✅ 异步sleep

💡 解决方案:寻找异步版本的库,或用asyncio.to_thread()包装同步代码


❌ 误区2:忘记await协程

asyncdef获取数据():
await asyncio.sleep(1)
return"数据"

asyncdef错误示例():
    result = 获取数据()  # ❌ 返回协程对象,不是结果!

asyncdef正确示例():
    result = await 获取数据()  # ✅ 必须await

❌ 误区3:过度使用asyncio.gather()

asyncdef错误示例(数据列表):
# ❌ 列表有10000项?会同时创建10000个任务!
    tasks = [处理单个(item) for item in 数据列表]
returnawait asyncio.gather(*tasks)

asyncdef正确示例(数据列表):
    semaphore = asyncio.Semaphore(100)  # ✅ 最多100个并发

asyncdef带限制的任务(item):
asyncwith semaphore:
returnawait 处理单个(item)

    tasks = [带限制的任务(item) for item in 数据列表]
returnawait asyncio.gather(*tasks)

❌ 误区4:忽视异常处理

asyncdef正确示例():
    tasks = [可能出错的任务(i) for i inrange(5)]
# ✅ 设置return_exceptions=True
    results = await asyncio.gather(*tasks, return_exceptions=True)

for i, result inenumerate(results):
ifisinstance(result, Exception):
print(f"任务{i}失败: {result}")
else:
print(f"任务{i}成功: {result}")

❌ 误区5:在异步代码中使用锁不当

共享数据 = []
lock = asyncio.Lock()

asyncdef正确示例():
for i inrange(10):
await asyncio.sleep(0.1)
asyncwith lock:  # ✅ 正确使用异步锁
            共享数据.append(i)

📌 总结:异步编程的核心就这几条

  1. 1. 事件循环是大脑:管理所有协程的调度
  2. 2. 协程是执行单元:用async def定义,用await暂停
  3. 3. Task是并发手段:create_task()让协程立刻开始
  4. 4. 非阻塞是关键:所有IO操作必须用异步版本
  5. 5. 控制并发数:用Semaphore防止资源耗尽

📝 口诀记好:遇到IO就await,创建任务用gather,控制并发上Semaphore,异常处理不能少。


👋 行动引导:别只收藏,动手练!

看完不练,等于白看。现在就做这三件事:

  1. 1. 点个赞 👍 如果这篇文章对你有用
  2. 2. 收藏 🔖 异步编程坑多,随时回来看
  3. 3. 关注 ➕ 点击头像关注「Python小甲鱼」,获取更多硬核技术文

📌 版权声明:本文为Python小甲鱼原创,转载需授权
💬 技术交流:欢迎评论区留言,看到都会回复!

最新文章

随机文章

基本 文件 流程 错误 SQL 调试
  1. 请求信息 : 2026-03-27 09:58:21 HTTP/2.0 GET : https://f.mffb.com.cn/a/481344.html
  2. 运行时间 : 0.287193s [ 吞吐率:3.48req/s ] 内存消耗:5,396.76kb 文件加载:140
  3. 缓存信息 : 0 reads,0 writes
  4. 会话信息 : SESSION_ID=1eb717cc95e5233122df8f16bd961373
  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.000888s ] mysql:host=127.0.0.1;port=3306;dbname=f_mffb;charset=utf8mb4
  2. SHOW FULL COLUMNS FROM `fenlei` [ RunTime:0.001803s ]
  3. SELECT * FROM `fenlei` WHERE `fid` = 0 [ RunTime:0.006858s ]
  4. SELECT * FROM `fenlei` WHERE `fid` = 63 [ RunTime:0.001194s ]
  5. SHOW FULL COLUMNS FROM `set` [ RunTime:0.001534s ]
  6. SELECT * FROM `set` [ RunTime:0.001850s ]
  7. SHOW FULL COLUMNS FROM `article` [ RunTime:0.001635s ]
  8. SELECT * FROM `article` WHERE `id` = 481344 LIMIT 1 [ RunTime:0.007321s ]
  9. UPDATE `article` SET `lasttime` = 1774576701 WHERE `id` = 481344 [ RunTime:0.004289s ]
  10. SELECT * FROM `fenlei` WHERE `id` = 66 LIMIT 1 [ RunTime:0.000832s ]
  11. SELECT * FROM `article` WHERE `id` < 481344 ORDER BY `id` DESC LIMIT 1 [ RunTime:0.007600s ]
  12. SELECT * FROM `article` WHERE `id` > 481344 ORDER BY `id` ASC LIMIT 1 [ RunTime:0.009589s ]
  13. SELECT * FROM `article` WHERE `id` < 481344 ORDER BY `id` DESC LIMIT 10 [ RunTime:0.021044s ]
  14. SELECT * FROM `article` WHERE `id` < 481344 ORDER BY `id` DESC LIMIT 10,10 [ RunTime:0.023626s ]
  15. SELECT * FROM `article` WHERE `id` < 481344 ORDER BY `id` DESC LIMIT 20,10 [ RunTime:0.017573s ]
0.290556s