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

从 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,但在资源有限的个人项目中,这已是质的飞跃


❤️ 五、给后来者的建议

  1. 不要为了微服务而微服务:先问"业务是否需要拆?"
  2. 技术选型看成熟度,不看热度:2019 年用 Eureka,是专业;硬上 Nacos,是冒险。
  3. 文档比代码更重要:我在 README 里写了架构图、启动顺序、依赖关系------这是项目能被理解的关键。
  4. 开源不是为了 Star,而是为了证明"我能搞定复杂系统"
相关推荐
FQNmxDG4S3 小时前
Java多线程编程:Thread与Runnable的并发控制
java·开发语言
前端老石人4 小时前
HTML 字符引用完全指南
开发语言·前端·html
matlab_xiaowang4 小时前
Redux 入门:JavaScript 可预测状态管理库
开发语言·javascript·其他·ecmascript
虹科网络安全4 小时前
艾体宝干货|数据复制详解:类型、原理与适用场景
java·开发语言·数据库
axng pmje4 小时前
Java语法进阶
java·开发语言·jvm
rKWP8gKv75 小时前
Java微服务性能监控:Prometheus与Grafana集成方案
java·微服务·prometheus
老前端的功夫5 小时前
【Java从入门到入土】28:Stream API:告别for循环的新时代
java·开发语言·python
qq_435287925 小时前
第9章 夸父逐日与后羿射日:死循环与进程终止?十个太阳同时值班的并行冲突
java·开发语言·git·死循环·进程终止·并行冲突·夸父逐日
小江的记录本5 小时前
【Kafka核心】架构模型:Producer、Broker、Consumer、Consumer Group、Topic、Partition、Replica
java·数据库·分布式·后端·搜索引擎·架构·kafka
止语Lab5 小时前
从手动到框架:Go DI 演进的三个拐点
开发语言·后端·golang