《一个人,一台老电脑:我如何将 Struts2 单体 P2P 系统重构为 Spring Cloud 微服务》

18 阅读3分钟

从 Struts2 单体到 Spring Cloud 微服务:一个 P2P 系统的真实重构之路(2019 年实战复盘)

开源地址:gitee.com/lijinquanBl… 关键词:微服务重构、Spring Cloud、Eureka、Feign、Hystrix、P2P 系统、架构演进

🌟 写在前面:这不是 Demo,而是一次“生存式”重构 2019 年初,我手头有一个运行多年的 P2P 投资平台——基于 Struts2 + Spring + MyBatis + Oracle 的典型单体架构。随着用户增长,系统暴露出严重问题:

每次发版需全量部署,上线风险高 团队协作困难:前端改页面,后端动接口,测试全回归 高峰期数据库连接池打满,投资下单经常超时 权限、账户、债权逻辑耦合,改一处崩三处 于是,我决定:彻底重构为微服务架构。 没有大厂资源,没有团队支持,只有一个人、一台 Dell 笔记本,和一个信念:“能跑起来,就能活下去。”

🔧 一、为什么选择 Eureka + Feign + Hystrix?(不是没得选,而是选得稳) 很多人问我:“2019 年都快 Nacos 了,为啥不用?”

答案很简单:时间点不对。

Nacos:2018 年 7 月才开源,2019 年初仍是 0.x 版本,无生产级案例,文档匮乏。 Sentinel:虽已开源,但 Spring Cloud 集成不成熟,连自动装配都靠手写。 Eureka + Feign + Hystrix:Netflix 套件,经过 Netflix、国内电商多年验证,社区问题一搜就有解。 💡 在资金敏感的 P2P 系统里,稳定性 > 新潮。 我选择了“能让我睡着觉”的技术栈。

🏗️ 二、如何拆分服务?从业务出发,而非技术炫技 我没有盲目按“用户、订单、商品”拆,而是根据 P2P 核心业务域:

微服务 职责 端口 microservicecloud-provider-user-8001 用户注册、登录、实名认证 8001 microservicecloud-provider-invest-8002 投资、债权匹配、收益计算 8002 microservicecloud-provider-account-8003 资金账户、充值提现(对接支付) 8003 microservicecloud-consumer-web-81 前台 Web(Angular)调用聚合层 81 microservicecloud-eureka-7001 服务注册中心 7001 ✅ 关键原则:

每个服务独立数据库(避免跨库事务) 异步解耦:投资成功后,通过 ActiveMQ 通知账户系统扣款 统一入口:Web 层通过 Feign 调用多个 Provider,前端无感知 ⚙️ 三、踩过的坑与解决方案(全是血泪经验) ❌ 坑 1:Feign 调用默认超时 1 秒,投资下单直接失败

yaml

解决方案:显式配置超时

feign: client: config: default: connectTimeout: 5000 readTimeout: 10000 ❌ 坑 2:Redis Token 多服务共享,登出失效难 方案:Token 存 Redis,Key = user:token:{userId} 登出时删除该 Key,所有服务读取同一 Redis 实例 ❌ 坑 3:Hystrix 熔断后,用户看到“系统繁忙”,体验差 优化:自定义 fallback 返回友好提示,并记录日志供运维分析 📊 四、效果如何?数据不会说谎 指标 重构前(单体) 重构后(微服务) 部署时间 15 分钟(全量) 3 分钟(单服务) 并发能力 ≈ 50 TPS ≈ 500 TPS(本地压测) 故障隔离 一处崩,全站挂 投资服务挂,用户仍可查账户 开发效率 全员阻塞 前端 + 后端并行开发 💡 虽然没上云、没做 CI/CD,但在资源有限的个人项目中,这已是质的飞跃。

❤️ 五、给后来者的建议 不要为了微服务而微服务:先问“业务是否需要拆?” 技术选型看成熟度,不看热度:2019 年用 Eureka,是专业;硬上 Nacos,是冒险。 文档比代码更重要:我在 README 里写了架构图、启动顺序、依赖关系——这是项目能被理解的关键。 开源不是为了 Star,而是为了证明“我能搞定复杂系统”