从 Struts2 单体到 Spring Cloud 微服务:一个 P2P 系统的真实重构之路(2019 年实战复盘)
开源地址 :https://gitee.com/lijinquanBlog/lijinquan-p2p
关键词:微服务重构、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,而是为了证明"我能搞定复杂系统"