Bug回忆录:Gradle/Spring多项目拆分

前言

最近我们将之前的一个python技术栈的项目完全转移到了java技术栈,转移后项目日趋庞大,便着手进行项目拆分。

拆分步骤

我们将共用的与具体业务无关的部分拆为common,另外两个业务一个是主干业务officep,一个是附加业务findd,officep和findd都依赖common,findd同时还依赖officep。拆分之后目录结构看起来像是这样:

  • common

    |-- build.gradle

    |-- src/main/java/com/uranome/fbs/common/

  • officep

    |-- build.gralde

    |-- src/main/java/com/uranome/fbs/officep/

    |-- src/main/java/com/uranome/fbs/officep/persistance/UserRepository.java

  • findd

    |-- build.gradle

    |-- src/main/java/

    |-- src/main/java/com/uranome/fbs/findd/service/EvaluationService.java

  • build.gradle

  • settings.gradle

Bug的来临

build.gradle和settings.gradle文件的编写直接参照官方docAuthoring Multi-Project Builds。编译顺利完成,officep项目也能顺利启动,但是在启动findd项目时报错。大意是EvaluationService装配UserRepository失败,找不到UserRepository这个Bean。bug来得总是如狂风暴雨一般猛烈,反复确认UserRepository加了@Repository这个注解之后bug依然存在。

Bug的尝试解决

1. 修改ComponentScan

com.uranome.fbs.officep.persistance加入到findd的ComponentScan,测试问题依然存在。

2. 添加EntityScan

经过一番google之后添加注解:

@EntityScan({
    "com.uranome.fbs.findd",
    "com.uranome.fbs.officep.persistance",
})

这次抛出的异常和之前有所不同,但依然是起不来。

进行思考

根据我们现有的知识可以推断这个bug的产生原因应该bean自动装配失败,而就目前来看装配失败无外乎两个原因:

  1. bean所在类未被扫描到。
  2. bean所在类被扫描到了,但是由于某种原因导致没有创建bean。

经过长达2天的google之后bug依然没有解决,我开始意识到解决这个bug需要对spring的DI整个流程有比较深入的了解。

之后就是clone了SpringBoot的仓库,循着run一路读代码+调试,在org.springframework.context.annotation.ConfigurationClassParserdoProcessConfigurationClass方法中看到了com.uranome.fbs.officep.persistance这个包,可知原因1可被排除。接下来验证原因2即可,所有的singleton beans都在ApplicationContext持有的DefaultListableBeanFactory.preInstantiateSingletons中创建(如果你看不懂这一段我在讲啥,可以参考一篇Spring源码解读的文章,或者自己看看源代码)。可以看到之所以UserRepository这个bean没有被创建,因为在isAbstract的判断中被排除了,意思就是说UserRepository是abstract的。回想一下Repository在Spring JPA中都是interface声明的,不是abstract才怪呢。

了解了bug产生的原因之后针对于此在google上又搜索了一番,总算得到了解决方案。Repository需要特殊的处理才能被创建为bean,即添加@EnableJpaRepositories注解。

Bug的解决

最终得到的代码大概是这样:

src/main/java/com/uranome/fbs/findd/App.java

@SpringBootApplication
@ComponentScan({"com.uranome.fbs.common", "com.uranome.fbs.findd",
 "com.uranome.fbs.officep.persistance", "com.uranome.fbs.officep.service"})
@EnableJpaRepositories({"com.uranome.fbs.findd", "com.uranome.fbs.officep.persistance"})
@EntityScan({"com.uranome.fbs.findd", "com.uranome.fbs.officep.persistance"})
public class App
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,230评论 5 476
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,261评论 2 380
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,089评论 0 336
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,542评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,542评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,544评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,922评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,578评论 0 257
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,816评论 1 296
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,576评论 2 320
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,658评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,359评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,937评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,920评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,156评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,859评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,381评论 2 342

推荐阅读更多精彩内容