Mvnw,到底是什么鬼?

开发 前端
使用start.spring.io生成项目,会发现里面有mvnw和mvnw.cmd两个文件。两个文件加起来有20多kb。

 本文转载自微信公众号「小姐姐味道」,作者小姐姐养的狗  。转载本文请联系小姐姐味道公众号。 

使用start.spring.io生成项目,会发现里面有mvnw和mvnw.cmd两个文件。两个文件加起来有20多kb。

我代码还没超过20行呢,就整上这样两个文件,做什么用呢?到底是什么鬼?

官方说,它是maven的一个wrapper,在找不到maven的时候,它会自动下载一个;或者,碰到你的项目maven和你环境里的mavne不兼容,它也会自动下载一个。

这不是在搞笑么?不知道我现在身处局域网深处么?

我们尝试执行一下传统的mvn命令,可以看到它使用mvnw去替换了自己。

  1.  ~/codes/ $ mvn -Dmaven.test.skip=true -Pdev package 
  2. executing mvnw instead of mvn 
  3.  
  4. Exception in thread "main" java.util.zip.ZipException: error in opening zip file 
  5.     at java.util.zip.ZipFile.open(Native Method) 
  6.     at java.util.zip.ZipFile.<init>(ZipFile.java:225) 
  7.     at java.util.zip.ZipFile.<init>(ZipFile.java:155) 
  8.     at java.util.zip.ZipFile.<init>(ZipFile.java:169) 
  9.     at org.apache.maven.wrapper.Installer.unzip(Installer.java:169) 
  10.     at org.apache.maven.wrapper.Installer.createDist(Installer.java:86) 
  11.     at org.apache.maven.wrapper.WrapperExecutor.execute(WrapperExecutor.java:121) 
  12.     at org.apache.maven.wrapper.MavenWrapperMain.main(MavenWrapperMain.java:61) 

但是但是,等了良久,日志也没有向下滚动。等了十几分钟,好不容易有输出了,结果报错。然后接下来每次运行都报错。

聒噪的很,是时候要让它露出真面目了。

使用ps命令,找到了它的启动参数。这才发现,除了mvnw文件,它还偷偷的在项目中放了.mvn目录,好家伙,足足有64kb。

  1. # ps -ef| grep mvn 
  2. java -classpath ~/codes/.mvn/wrapper/maven-wrapper.jar -Dmaven.home=~/codes -Dmaven.multiModuleProjectDirectory=~/codes  org.apache.maven.wrapper.MavenWrapperMain -Dmaven.test.skip=true -Pdev package 

这可真是多此一举,不如不举。你要是贴心,直接塞个apache maven在里面啊。

深处国内,对付这玩意最好的方式,那就是:

删掉它!

删掉它!

删掉它!

[[344020]]

即使它的初衷如何好,目标是如何宏大,还是要毫不留情的干掉它。

曾经有个小弟,使用mvnw下载了一下午的jar包,最后茫然的向我吐槽:公司的maven私服太慢了。

不能背这个锅。

一个好的项目,不会依赖特定的打包工具。这算是maven项目偷懒出的插件,因为一个基础工具,有一个点必须要做到,那就是向后兼容。

搞出这么个工具,连个CDN都舍不得弄,这不是方便开发人员,而是给开发人员添乱。

更要命的是,企业内部都是自己搭建maven私服的,有自己的配置文件和账号。使用这个玩意,还得需要知道maven下载在哪了,找到以后替换它的配置文件。典型的管生不管养啊。

当然了,gradle也是一个德行。

所以,xjjdog的处理方式是,看到mvnw和.mvn这些文件,第一时间就毫不留情的干掉它。

虽然我很残忍,辜负了作者的一片好心。但深处这样的网络环境之中,我也是无奈之举啊。

作者简介:小姐姐味道 (xjjdog),一个不允许程序员走弯路的公众号。聚焦基础架构和Linux。十年架构,日百亿流量,与你探讨高并发世界,给你不一样的味道。我的个人微信xjjdog0,欢迎添加好友,进一步交流。

 

责任编辑:武晓燕 来源: 小姐姐味道
相关推荐

2019-10-30 10:13:15

区块链技术支付宝

2016-10-21 09:58:19

WindowsKMSOEM系统

2011-04-27 09:30:48

企业架构

2010-11-01 01:25:36

Windows NT

2020-09-22 08:22:28

快充

2020-10-14 06:22:14

UWB技术感知

2020-10-25 20:05:29

Pythonyield开发

2022-02-16 20:04:08

容器KubernetesShim

2021-09-03 09:12:09

Linux中断软件

2013-06-09 09:47:31

.NetPDBPDB文件

2010-04-22 14:14:29

Live-USB

2020-08-04 14:20:20

数据湖Hadoop数据仓库

2021-09-01 23:29:37

Golang语言gRPC

2023-07-12 15:32:49

人工智能AI

2021-07-07 05:07:15

JDKIterator迭代器

2021-01-21 21:24:34

DevOps开发工具

2022-10-08 00:00:00

Spring数据库项目

2020-03-05 10:28:19

MySQLMRR磁盘读

2024-02-04 00:01:00

云原生技术容器

2021-02-05 10:03:31

区块链技术智能
点赞
收藏

51CTO技术栈公众号