项目循环依赖导致Maven无法编译

今天使用Maven编译项目的时候,遇到了一个异常:

[ERROR] Internal error: java.lang.NullPointerException -> [Help 1]
org.apache.maven.InternalErrorException: Internal error: java.lang.NullPointerException
    at org.apache.maven.DefaultMaven.execute(DefaultMaven.java:167)
    at org.apache.maven.cli.MavenCli.execute(MavenCli.java:584)
    at org.apache.maven.cli.MavenCli.doMain(MavenCli.java:213)
    at org.apache.maven.cli.MavenCli.main(MavenCli.java:157)
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
    at java.lang.reflect.Method.invoke(Method.java:606)
    at org.codehaus.plexus.classworlds.launcher.Launcher.launchEnhanced(Launcher.java:289)
    at org.codehaus.plexus.classworlds.launcher.Launcher.launch(Launcher.java:229)
    at org.codehaus.plexus.classworlds.launcher.Launcher.mainWithExitCode(Launcher.java:415)
    at org.codehaus.plexus.classworlds.launcher.Launcher.main(Launcher.java:356)
Caused by: java.lang.NullPointerException
    at org.apache.maven.DefaultMaven.doExecute(DefaultMaven.java:270)
    at org.apache.maven.DefaultMaven.execute(DefaultMaven.java:155)
    ... 11 more
[ERROR] 
[ERROR] To see the full stack trace of the errors, re-run Maven with the -e switch.
[ERROR] Re-run Maven using the -X switch to enable full debug logging.
[ERROR] 
[ERROR] For more information about the errors and possible solutions, please read the following articles:
[ERROR] [Help 1] http://cwiki.apache.org/confluence/display/MAVEN/InternalErrorException

参考StackOverFlow的资料,导致这个问题的其中一个原因是项目循环引用,原回答为:

You have a cyclic reference of dependencies.
It looks like your crm-core project has crm-data in its dependencies and the crm-data project has crm-core in its dependencies.
Maven can't compile such a case

翻译:

你的依赖循环引用了,工程A里面有工程B的依赖,工程B有工程A的依赖。Maven在这种情况下是无法编译的。

突然想到我的工程中确实存在循环依赖的问题,在Eclipse的Markers里面有一堆警告提示信息,精简之后如下:

A cycle was detected in the build path of project 'prjoectA'. 
The cycle consists of projects {projectA, projectB, projectC...}

之前我看到这个问题的时候,网上提供了两种方案:

  1. 在Eclipse的首选项里面关闭这个错误提示,修改为警告;
  2. 解决项目之间循环引用的问题

当时因为偷懒,选择了Plan 1,但是现在问题来了,Maven项目编译不通过,而我们公司的整个工程都是建立在Maven上的。

经过仔细排查,最终在Maven dependencies里找到了common工程错误地依赖了某个facade工程,而facade工程又引用了common工程。
按照工程的设计,common应该作为所有的工程的依赖工程,所以,只能将facade中被引用的部分挪入common中。

代码修改之后,在项目上选择Maven-Update Project,勾选Force Update。完成后,对Project选择Clean,错误提示消失。
重新进行Maven编译,提示Success,问题解决!


总结:
这个问题告诉我们,进行工程开发之前,需要先理清楚工程结构。了解各个项目之间的依赖关系,杜绝循环引用。


参考资料:
https://stackoverflow.com/questions/23078500/maven-throws-nullpointer-exception

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 135,359评论 19 139
  • 简介 概述 Maven 是一个项目管理和整合工具 Maven 为开发者提供了一套完整的构建生命周期框架 Maven...
    闽越布衣阅读 9,807评论 6 39
  • Spring Boot 参考指南 介绍 转载自:https://www.gitbook.com/book/qbgb...
    毛宇鹏阅读 47,054评论 6 342
  • 迄今为止,村上春树的《当我谈跑步时我谈些什么》是我读一次就没有忘记过的一本书,一直到现在还是记忆犹新,也是...
    夜雪微澜阅读 2,338评论 0 0
  • b 很感谢众乐乐读书协会的姐妹给我推荐简书APP,有了它,可以为自己,甚至为他人,发出更多真实的声音。有时,它就...
    小主十九阅读 7,860评论 5 7