当前位置:首页>python>Python 微服务实战:一套 10 服务的 ERP 系统是怎么搭出来的?

Python 微服务实战:一套 10 服务的 ERP 系统是怎么搭出来的?

  • 2026-06-30 11:22:43
Python 微服务实战:一套 10 服务的 ERP 系统是怎么搭出来的?

前言

Java 做 ERP 太重?Spring Cloud 全家桶学不动?XEERP项目用纯 Python 技术栈证明:FastAPI 同样能撑起复杂业务的微服务架构。10 个独立服务、Consul 服务发现、统一网关鉴权限流、全异步 ORM——这套方案在真实生产环境稳定运行。

今天带你拆解这套系统的技术内核。

整体架构:网关 + 业务微服务 + 共享内核

三段式架构

  1. 网关层:统一入口,处理认证、限流、路由转发
  2. 业务服务层:按领域拆分为 10 个独立服务
  3. 共享内核:公共组件库(数据库/Redis/工具类),避免重复造轮子

核心设计原则: 服务边界清晰、技术栈统一、解耦性强。

Gateway 网关:微服务的"门面担当"

网关是所有请求的第一站,承担三大职责:

2.1 JWT 统一鉴权

class AuthVerifyMiddleware(BaseHTTPMiddleware):    async def dispatch(self, request, call_next):        path = request.url.path        # 白名单直接放行(登录/验证码/刷新Token)        for white_path in config.whitelist_paths:            if path.startswith(white_path):                return await call_next(request)        # 验证 Token        token = request.headers.get("Authorization""")        payload = JwtUtil.verify_token(token)        if not payload:            return ResponseUtil.unauthorized(msg="token无效或已过期")        # 用户信息注入 request.state        request.state.user = payload        return await call_next(request)

设计要点:

  • 白名单机制:登录/验证码等接口无需认证
  • Token 验证在网关统一处理,业务服务无需重复实现
  • 用户信息通过 request.state 向下透传

2.2 动态限流(Consul KV 热更新)

class RequestLimiterMiddleware(BaseHTTPMiddleware):    async def dispatch(self, request, call_next):        # 从 URL 提取服务名        # /api/system-service/user/list → system-service        service_name = parts[1]        # 从 Consul KV 动态读取限流规则        consul_key = f"config/gateway/limit/{service_name}"        limit_rule = ConsulUtil.get_config_kv(consul_key)  # "60/minute"        # 按 IP + 服务名限流        cache_key = f"{client_ip}:{service_name}"        if len(REQUEST_RECORD[cache_key]) >= max_count:            return ResponseUtil.too_many_requests()

亮点:

  • 限流规则存储在 Consul KV,修改即时生效,无需重启网关
  • 支持 second/minute/hour 三种时间窗口
  • 按 IP + 服务粒度限流,精细可控

2.3 路由转发(Consul 服务发现)

@router.api_route("/{service_name}/{path:path}", methods=["GET","POST","PUT","DELETE"])async def proxy_request(request, service_name, path):    # 从 Consul 获取服务实例    service_map = ConsulUtil.get_all_services_with_instances()    instances = service_map[service_name]    # 构建目标 URL    instance = instances[0]    target_url = f"http://{instance['address']}:{instance['port']}/{path}"    # 流式转发(支持大文件/SSE)    resp = await client.send(req, stream=True)    return StreamingResponse(resp.aiter_raw(), ...)

一条路由搞定所有转发 — 通过 FastAPI 的 path 参数捕获,动态路由到对应服务。Consul 负责服务注册与健康检查,网关只做转发。

服务发现:Consul 注册中心

每个微服务启动时自动向 Consul 注册,关停时注销:

@asynccontextmanagerasync def lifespan(app: FastAPI):    # 启动:注册到 Consul    ConsulUtil.register_service(        name="system-service",        address=None,  # 自动获取本地IP        port=8001,        service_id="system-service-001"    )    yield    # 关停:从 Consul 注销    ConsulUtil.deregister_service("system-service""system-service-001")

Consul 在系统中的角色:

功能
用途
服务注册
每个服务启动时注册 IP + 端口
健康检查
HTTP /health 端点探活
服务发现
网关从 Consul 获取可用实例列表
KV 配置
存储限流规则等动态配置

全异步数据库层:SQLAlchemy 2.x + asyncmy

异步引擎 + 连接池

from sqlalchemy.ext.asyncio import create_async_engine, async_sessionmakerasync_engine = create_async_engine(    url="mysql+asyncmy://user:pass@host:3306/xeerp?charset=utf8mb4",    pool_size=50,           # 连接池大小    max_overflow=10,        # 允许溢出连接数    pool_recycle=3600,      # 连接回收周期(防止 MySQL 8小时断开)    pool_pre_ping=True,     # 每次使用前健康检查)AsyncSessionLocal = async_sessionmaker(    bind=async_engine,    expire_on_commit=False,  # 关键:提交后对象不失效)

为什么选 asyncmy 而非 aiomysql?

  • asyncmy 是 asyncio 原生实现,性能更好
  • 对 MySQL 8.0+ 特性支持更完善
  • 与 SQLAlchemy 2.x async 无缝集成

ORM 模型示例

class Base(AsyncAttrs, DeclarativeBase):    """所有 Model 的基类"""    passclass SysUser(Base):    __tablename__ = 'sys_user'    user_id = Column(BigInteger, primary_key=True)    user_name = Column(String(64), nullable=False)    dept_id = Column(BigInteger)    status = Column(CHAR(1), default='0')    create_time = Column(DateTime, default=datetime.now)

权限体系:RBAC + 数据权限

功能权限

采用 用户 → 角色 → 菜单/权限标识 的经典 RBAC 模型:

@CheckPerm("system:user:add")  # 装饰器声明所需权限async def add_user(request, user):    ...# 装饰器实现def CheckPerm(perm: str):    def decorator(func):        async def wrapper(*args, **kwargs):            user = kwargs.get("user")            # 超级管理员直接通过            if "*" in user.perms:                return await func(*args, **kwargs)            # 检查权限标识            if perm not in user.perms:                raise ServiceException(f"无权限:{perm}"403)            return await func(*args, **kwargs)        return wrapper    return decorator

数据权限(部门级别)

class DataPermission:    @staticmethod    def get_filter(model, user):        scope = user.data_scope        # 1=全部 2=本部门及子级 3=本部门 4=本人 5=自定义        if scope == 1return True        if scope == 4return model.create_user_id == user.user_id        if scope == 3return model.create_dept_id == user.dept_id        if scope == 5return model.create_dept_id.in_(user.custom_dept_ids)

五种数据范围,覆盖企业常见场景: 总经理看全部、部门经理看本部门、业务员只看自己的数据。

跨服务通信:BaseClient 封装

微服务之间通过 HTTP 调用通信,统一封装在 clients/ 目录:

class BaseClient:    """所有服务客户端的基类"""    def __init__(self, base_url: str, timeout: int = 30):        self.base_url = base_url        self.timeout = aiohttp.ClientTimeout(total=timeout)    async def _request(self, method, path, params=None, data=None):        session = await self.get_session()        url = f"{self.base_url}/{path.lstrip('/')}"        async with session.request(method, url, params=params, json=data) as resp:            return resp.status, await resp.json()    async def get(self, path, **kwargs):        return await self._request("GET", path, **kwargs)    async def post(self, path, **kwargs):        return await self._request("POST", path, **kwargs)

业务服务继承 BaseClient,一行代码完成跨服务调用:

class StockClient(BaseClient):    def __init__(self):        super().__init__(base_url="http://127.0.0.1:8003")    async def get_inventory(self, product_id: int):        return await self.get(f"/api/stock/inventory/{product_id}")

设计思考:

  • 内部服务直连,不经过网关(减少一跳延迟)
  • 统一超时/重试/异常转换
  • 生产环境自动切换 K8s Service DNS

统一响应 + 全局异常:企业级 API 规范

ResponseUtil 统一响应

class ResponseUtil:    @classmethod    def success(cls, msg="操作成功", data=None, rows=None, total=None):        return JSONResponse(content={            "code"200,            "msg": msg,            "success"True,            "time": datetime.now().isoformat(),            "data": data,            "rows": rows,            "total": total        })    @classmethod    def fail(cls, msg="操作失败", code=500): ...    @classmethod    def unauthorized(cls, msg="请先登录"): ...    @classmethod    def too_many_requests(cls, msg="请求频繁"): ...

15+ 种预定义响应方法,覆盖所有 HTTP 状态码场景。

四层异常处理器

# 业务异常 → 400app.add_exception_handler(ServiceException, biz_exception_handler)# HTTP 异常 → 对应状态码app.add_exception_handler(HTTPException, http_exception_handler)# 参数校验 → 400app.add_exception_handler(RequestValidationError, validation_exception_handler)# 兜底异常 → 500app.add_exception_handler(Exception, global_exception_handler)

任何异常都不会返回原始堆栈给前端。

定时任务:APScheduler + 数据库持久化

系统服务内置完整的定时任务管理能力:

from apscheduler.schedulers.asyncio import AsyncIOSchedulerfrom apscheduler.jobstores.sqlalchemy import SQLAlchemyJobStore# 任务存储到数据库(重启不丢失)job_stores = {    'default': SQLAlchemyJobStore(engine=sync_engine)}scheduler = AsyncIOScheduler(    jobstores=job_stores,    executors={'default': AsyncIOExecutor()},)

特色功能:

  • 支持 6/7 位 Cron 表达式(兼容 Linux crontab 和带秒级的扩展格式)
  • 任务持久化到 MySQL,服务重启自动恢复
  • 执行日志入库(任务名、触发时间、状态、异常信息)
  • 支持在线管理:启停/删除/立即执行/修改表达式
# 自定义 Cron 支持 6/7 位class MyCronTrigger(CronTrigger):    @classmethod    def from_crontab(cls, expr, timezone=None):        values = expr.split()        # 5位=标准 / 6位=带秒 / 7位=带秒+年        if len(values) == 5:            # 秒 分 时 日 月 周            ...

Redis 缓存策略

Redis 在系统中承担多重角色:

场景
Key 格式
用途
用户会话
session:{user_id}
在线状态/强制下线
字典缓存
sys_dict:{dict_type}
减少 DB 查询
系统参数
sys_config:{key}
全局配置缓存
验证码
captcha:{uuid}
图形验证码存储
限流计数
网关内存(可切 Redis)
IP 限流窗口

启动预热机制:

# 服务启动时,一次性加载高频数据到 Redisawait RedisUtil.init_sys_dict(redis)    # 字典预热await RedisUtil.init_sys_config(redis)  # 参数预热await RedisUtil.init_sys_user(redis)    # 在线用户恢复

每个服务的统一分层

所有微服务遵循相同的目录结构,新人一看就懂:

service/├── api/v1/             # Controller 层:路由定义 + 参数校验│   ├── user_controller.py│   └── dept_controller.py├── service/            # Service 层:业务编排 + 事务│   ├── user_service.py│   └── dept_service.py├── dao/                # DAO 层:数据库操作封装│   ├── user_dao.py│   └── dept_dao.py├── models/             # Model 层:ORM 实体├── schemas/            # Schema 层:Pydantic 校验模型├── clients/            # Client 层:跨服务调用├── core/               # 本服务私有配置└── middlewares/        # 本服务中间件

分层铁律:

  • Controller 只做参数解析和响应返回
  • Service 处理业务逻辑和事务
  • DAO 只关心 SQL 查询
  • 层与层之间 禁止跨层调用

性能优化细节

orjson 替换标准 json

app = FastAPI(json_serializer=orjson.dumps)

orjson 比标准库快 3-10 倍,对于高频 JSON 序列化场景效果显著。

Linux 自动切换高性能模式

if os.name == "posix":    LOOP = "uvloop"       # 替换默认 asyncio 事件循环    HTTP = "httptools"    # 替换默认 HTTP 解析器

uvloop + httptools 组合,让 FastAPI 的吞吐量接近 Go/Rust 级别。

连接池调优

# 50 个常驻连接 + 10 个溢出连接pool_size=50, max_overflow=10# 连接回收(防 MySQL wait_timeout 断开)pool_recycle=3600# 使用前探活(避免拿到死连接)pool_pre_ping=True

技术栈全景

层级
技术选型
选型理由
Web 框架
FastAPI + Uvicorn
异步高性能,自动 OpenAPI
ORM
SQLAlchemy 2.x + asyncmy
全异步,声明式模型
数据库
MySQL 8.0+
成熟稳定,支持主从
缓存
Redis 7.0+
会话/缓存/限流
服务注册
Consul
注册/发现/KV/健康检查
鉴权
JWT (pyjwt + bcrypt)
无状态,网关统一验证
定时任务
APScheduler
异步调度,数据库持久化
限流
自研中间件 + Consul KV
动态规则,热更新
序列化
orjson
比标准库快 3-10x
前端
Vue3 + Element Plus
RuoYi-Vue3 二次开发
部署
Gunicorn + Uvicorn Workers
多 Worker 生产部署

10 个服务一览

服务
端口
职责
Gateway
8000
统一入口:鉴权 + 限流 + 转发
System
8001
系统权限:用户/角色/菜单/字典/定时任务
Product
8002
商品中心:商品/分类/品牌/单位
Stock
8003
库存中心:仓库/库存/流水
Production
8004
生产中心:BOM/计划/领料/入库
Report
8005
报表中心:进度/成本/台账
Approval
8006
审批流:流程/节点/实例/记录
Partner
8007
往来单位:客户/供应商
Sales
8008
销售中心:销售订单
Purchase
8009
采购中心:采购单/收货入库

技术对比:FastAPI vs Spring Cloud

很多人会问:企业级 ERP 为什么不用 Java?我们来做一个实打实的对比:

框架层对比

对比项
FastAPI (Python)
Spring Cloud (Java)
启动速度
~1s 极快启动
~15-30s(依赖注入、组件扫描)
内存占用
~50-80MB / 服务
~300-500MB / 服务
并发模型
async/await 协程
线程池(Servlet)/ WebFlux(响应式)
开发效率
极高(50% 代码量)
中等(注解多、样板代码多)
类型校验
Pydantic 自动校验 + OpenAPI
Bean Validation + Swagger 配置
API 文档
自动生成(零配置)
需手动配置 Swagger/SpringDoc
热重载
原生支持 --reload
需 Spring DevTools / JRebel
部署包大小
~20MB(纯代码)
~80-200MB(Fat JAR)

微服务基础设施对比

能力
XEERP (FastAPI)
Spring Cloud
服务注册
Consul
Nacos / Eureka / Consul
网关
自研 Gateway (轻量)
Spring Cloud Gateway (重)
配置中心
Consul KV
Nacos Config / Apollo
服务调用
aiohttp/httpx 直连
OpenFeign 声明式调用
熔断降级
自实现 / httpx 超时
Resilience4j / Sentinel
链路追踪
X-Trace-Id 透传
Sleuth + Zipkin
定时任务
APScheduler
XXL-Job / Quartz
消息队列
暂无(可接 RabbitMQ)
RocketMQ / Kafka 全家桶

性能实测对比(同条件 CRUD 接口)

指标
FastAPI + asyncmy
Spring Boot + MyBatis
QPS(单机)
~8,000-12,000
~3,000-6,000
P99 延迟
~5ms
~15-30ms
内存占用
~80MB
~400MB
CPU 利用率
高(单线程异步)
中(多线程上下文切换)

  测试环境:4核 8G,MySQL 8.0,100 并发连接,单表 10w 行数据

开发体验对比

场景
FastAPI
Spring Cloud
新建一个 CRUD 接口
5 分钟
15-20 分钟
新增一个微服务
复制模板 10 分钟
创建工程 + 配置 30 分钟+
调试一个接口
Swagger 自动生成,直接调
配置 Swagger,可能还要 Postman
排查性能问题
async链路清晰
线程栈复杂,需 Arthas
新人上手
1-2 天
1-2 周
部署复杂度
pip install
 + python run.py
Maven/Gradle + JDK + 打包 + JVM 调优

适用场景对比

场景
推荐
原因
中小企业 ERP / 进销存
FastAPI
轻量、开发快、部署简单
大型集团 ERP(SAP 级)
Spring Cloud
生态完善、团队大
AI + 业务融合系统
FastAPI
Python AI 生态无缝对接
高并发交易系统
各有优势
FastAPI 异步强 / Java 线程池成熟
快速原型 / MVP
FastAPI
开发速度快 3 倍
已有 Java 团队
Spring Cloud
团队技术栈一致

核心结论

不是“Python 能不能做微服务”的问题,而是“什么场景下用哪个更合适”的问题。

我们选择 FastAPI 的核心理由:

  1. 人效比:3 人 Python 团队 = 8 人 Java 团队的产出
  2. 资源占用:10 个服务总内存 < 1GB,Java 需 4-5GB
  3. AI 融合:同一语言对接 LLM/RAG/数据分析,零成本
  4. 部署简单:无 JVM、无 Maven、无 Fat JAR,一个 pip install
 解决

总结:Python 做微服务的几点思考

  1. FastAPI 完全能胜任企业级微服务 — 异步性能优秀,生态成熟
  2. Consul 比 Nacos 更轻量 — 单二进制部署,Go 实现,资源占用极低
  3. 网关是微服务的咽喉 — 鉴权、限流、日志在此一把搞定
  4. 共享内核(common)是关键 — 统一响应/分页/日志,避免各服务各搞一套
  5. 全异步到底 — 从 ORM 到 Redis 到 HTTP 调用,一条链路全异步不阻塞
  6. 分层约定大于自由 — Controller/Service/DAO 三层严格分离,新人一天上手

Python 微服务不是玩具,它可以是真正的生产力。

关于 XEERP-FASTAPI

企业级进销存微服务系统,面向中小制造与流通型企业。10 个微服务按业务域独立部署,覆盖权限、商品、库存、生产、采购、销售、报表、审批全业务线。

技术栈:Python 3.12 + FastAPI + SQLAlchemy 2.x + MySQL 8 + Redis 7 + Consul + Vue3。


开源地址:https://gitee.com/zhiops/xeerp-fastapi


如果需要进一步了解可以加:

最新文章

随机文章

基本 文件 流程 错误 SQL 调试
  1. 请求信息 : 2026-07-03 08:10:13 HTTP/2.0 GET : https://f.mffb.com.cn/a/498155.html
  2. 运行时间 : 0.089016s [ 吞吐率:11.23req/s ] 内存消耗:4,629.20kb 文件加载:140
  3. 缓存信息 : 0 reads,0 writes
  4. 会话信息 : SESSION_ID=b3a4945f002c9c4dfd9c6529bd38134f
  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.000461s ] mysql:host=127.0.0.1;port=3306;dbname=f_mffb;charset=utf8mb4
  2. SHOW FULL COLUMNS FROM `fenlei` [ RunTime:0.000740s ]
  3. SELECT * FROM `fenlei` WHERE `fid` = 0 [ RunTime:0.000277s ]
  4. SELECT * FROM `fenlei` WHERE `fid` = 63 [ RunTime:0.000295s ]
  5. SHOW FULL COLUMNS FROM `set` [ RunTime:0.000452s ]
  6. SELECT * FROM `set` [ RunTime:0.000227s ]
  7. SHOW FULL COLUMNS FROM `article` [ RunTime:0.000561s ]
  8. SELECT * FROM `article` WHERE `id` = 498155 LIMIT 1 [ RunTime:0.000689s ]
  9. UPDATE `article` SET `lasttime` = 1783037414 WHERE `id` = 498155 [ RunTime:0.008354s ]
  10. SELECT * FROM `fenlei` WHERE `id` = 66 LIMIT 1 [ RunTime:0.000289s ]
  11. SELECT * FROM `article` WHERE `id` < 498155 ORDER BY `id` DESC LIMIT 1 [ RunTime:0.000481s ]
  12. SELECT * FROM `article` WHERE `id` > 498155 ORDER BY `id` ASC LIMIT 1 [ RunTime:0.006339s ]
  13. SELECT * FROM `article` WHERE `id` < 498155 ORDER BY `id` DESC LIMIT 10 [ RunTime:0.000921s ]
  14. SELECT * FROM `article` WHERE `id` < 498155 ORDER BY `id` DESC LIMIT 10,10 [ RunTime:0.001413s ]
  15. SELECT * FROM `article` WHERE `id` < 498155 ORDER BY `id` DESC LIMIT 20,10 [ RunTime:0.001410s ]
0.090607s