6.5.4.1 半自动化拆分工具使用指南
背景
从大单体 SpringBoot 应用中拆出 Koupleless 模块时,用户拆分的学习和试错成本较高。用户需要先从服务入口分析要拆出哪些类至模块,然后根据 Koupleless 模块编码方式改造模块。
为了降低学习和试错成本,KouplelessIDE 插件提供半自动化拆分能力:分析依赖,并自动化修改。
快速开始
1. 安装插件
从 IDEA 插件市场安装插件 KouplelessIDE:
data:image/s3,"s3://crabby-images/9e88e/9e88ee69584ebae60d9243c37484a98cd40421bb" alt=""
2. 配置 IDEA
确保 IDEA -> Preferences -> Builder -> Compiler 的 “User-local build process heap size” 至少为 4096
data:image/s3,"s3://crabby-images/4a2a5/4a2a52ad671da2cea85c5ec0a776344d5b0f8c62" alt=""
3. 选择模块
步骤一:用 IDEA 打开需要拆分的 SpringBoot 应用,在面板右侧打开 ServerlessSplit
data:image/s3,"s3://crabby-images/e1a22/e1a223a1effa016835d5699fe1a11a8dd2984a70" alt=""
步骤二:按需选择拆分方式,点击“确认并收起”
data:image/s3,"s3://crabby-images/7f744/7f7446f7f0869504b93722c70fd29ed3486f7895" alt=""
4. 依赖分析
在拆分时,需要分析类和Bean之间的依赖。可以通过插件可视化依赖关系,由业务方决定某个类是否要拆分到模块中。
步骤一:点击激活
data:image/s3,"s3://crabby-images/46f93/46f93e7f810cdc449ecc7eebbdff6a616697eaab" alt=""
步骤二:拖拽服务入口至模块,支持跨层级拖拽
data:image/s3,"s3://crabby-images/6320d/6320ddf1fc974dfaa75bccc0848cfb85509059c8" alt=""
拖拽结果:
data:image/s3,"s3://crabby-images/40de7/40de762205fc83e5c3d53ee6abcc7cfa09ad6614" alt=""
步骤三:拖拽“待分析文件”,点击分析依赖,查看类/Bean的依赖关系,如下图:
data:image/s3,"s3://crabby-images/51117/511175d3ebd6b13a7b7be858f19defcd85f4cffe" alt=""
data:image/s3,"s3://crabby-images/3c649/3c6490216fea56e68a4a745fb541ff0d7b1899eb" alt=""
data:image/s3,"s3://crabby-images/0db39/0db39354348e528f9ac19993be2291090af32bd0" alt=""
其中,各图标表示:
图标 | 含义 | 用户需要的操作 |
---|---|---|
![]() | 已在模块 | 无需操作 |
![]() | 可移入模块 | 拖拽至模块 ![]() |
![]() | 建议分析被依赖关系 | 拖拽至分析 ![]() |
![]() | 不应该移入模块 | 鼠标悬停,查看该类被依赖情况 ![]() |
步骤四:根据提示,通过拖拽,一步步分析,导入需要的模块文件
5. 检测
点击初步检测,将提示用户此次拆分可能的问题,以及哪些中间件需要人工。
data:image/s3,"s3://crabby-images/a2ca4/a2ca42c8a685175fd9b44bf7aa01c160087d1ff1" alt=""
打开下侧面板中 KouplelessIDE,查看提示。
data:image/s3,"s3://crabby-images/f93a8/f93a8dc606634eb9a7b02bc7f7d0a0661bd88659" alt=""
6. 拆分
点击开始拆分。
data:image/s3,"s3://crabby-images/56013/56013985565648b1902efdbb0b0a07d85f9af6bd" alt=""
打开下侧面板中 KouplelessIDE,查看提示。
data:image/s3,"s3://crabby-images/f6e55/f6e5530ba28bbce9dbee3eb4e011de498910cdfe" alt=""
Feedback
Was this page helpful?
Welcome propose feedback to community!
Welcome propose feedback to community, or improve this document directly.。
最后修改 2025.07.02: Update multi-app-adapter-developing-notes.md (19868e7)