maven本地仓库有jar包,但是引入报错

我的工程结构

父工程dubbo-server下有两个子工程,分别为:server-api(定义接口,打包发布到本地),server-provider(引入server-api的打包,并实现它的接口)。
然后又来了一个工程dubbo-client,它跟工程server-provider一样,引入server-api的打包。然后问题出现了,明明server-api已经打包到本地,server-provider引用没问题,dubbo-client引用就直接报错了。

报错体现

maven本地仓库有jar包,但是引入报错

尝试的解决方案

针对这种错误,按理说很常见也很容易解决。首先我在本地maven仓库里查看了下,发现这个jar包是存在的,pom文件的引用路径也没问题。于是怀疑是缓存导致的,我将Idea重启、clean、将maven依赖删除又重新加入、查看setting文件配置路径是否正确、甚至将server-api模块重新打包发布、maven工程不断刷新都没能解决。顿时感觉自己maven好弱~

解决方案

我去网上搜索了下问题,很多基本都是我上面的方案可以解决的,找了一阵子,终于有一段文字吸引了我:

如果你有子项目引用了父项目的POM,但没有在父项目POM目录下执行安装操作(父目录下执行mvn
install),这个问题就会出现。当一个子模块可能会依赖一个兄弟子模块而且去读取兄弟子模块的pom时,除非在父项目POM目录下至少执行一次安装,否则就会读取失败,即出现上述错误。

也就是说,dubbo-client引用server-api的jar包,除了server-api需要打包发布外,它的父工程dubbo-server也需要打包发布(mvn install),这样dubbo-client才能引用server-api不报错。server-provider由于本身就是dubbo-server下的子工程,所以引用server-api的时候没有报错。

总结

平常对于maven多模块开发中,如果另外一个工程要引用某个子模块,切记子模块和它的父模块都需要打包发布。