缩短命令行的类路径 (-cp)

Shorten classpath (-cp) for command line

我的 maven 构建在 jdeps 插件上失败(我们需要它升级到 jdk11)。

命令行对于 windows 来说太长了。 这是我得到的错误:

[ERROR] Failed to execute goal org.apache.maven.plugins:maven-jdeps-plugin:3.1.1:jdkinternals (default) on project myproject:
[ERROR] Exit code: 1 - La ligne de commande est trop longue.
[ERROR]
[ERROR] Command line was: cmd.exe /X /C 
"
    "C:\Program Files\Java\jdk-11.0.2\bin\jdeps.exe"
    -cp "
        C:\Users\Me\.m2\repository\com\something\firstJar.jar;
        C:\Users\Me\.m2\repository\com\somethingElse\secondJar.jar;
        C:\Users\Me\.m2\repository\com\somethingDifferent\someOtherJar.jar;
        ... and one more
        ... and another one
        ... I think you get the idea......."
    --multi-release 9 D:\git\myworkspace\myproject\target\classes
"

举个例子,我只放了 3 个罐子,但我有很多依赖项...

如何缩短此命令行?(并确保它不依赖于用户)

限制:这是一个共享项目,仅在我的计算机上更改任何内容都不是解决方案。

maven-jdeps-plugin 正在使用 plexus-utils 将子进程派生到 运行 jdeps可执行。 plexus-utils 通过构建命令行并将其传递给 cmd.exe 来实现这一点。这是错误的方法,因为它将受到 cmd.exe 施加的 8192 个字符的限制。正确的方法是使用 Java ProcessBuilder API。这本身使用 ProcessImpl.create API 方法,该方法在 Windows 上通过调用 CreateProcess 的 Win32 API 实现。后者 API 有 32k 个字符的限制,对于大多数用例来说应该足够了。

为此有一个 plexus-utils bug report。您可能还想使用 maven-jdeps-plugin 提高一个 - Java ProcessBuilder API 非常有用,因此无需仅对 运行 jdeps 使用 plexus-utils。

最好是创建 jar 文件,并在清单中配置类路径。

官方 oracle 文档位于 Adding Classes to the JAR File's Classpath

maven-jar 插件确实支持更新清单类路径属性:How to add Class-Path to the manifest file with maven

也许有点厚颜无耻的解决方案但是...

使用环境变量怎么样?

set MR=C:\Users\Me\.m2\repository\

"C:\Program Files\Java\jdk-11.0.2\bin\jdeps.exe"
    -cp "
        %MR%\com\something\firstJar.jar;
        %MR%\com\somethingElse\secondJar.jar;

没有测试,希望有用...

这就是 Maven 旨在管理大量依赖项的原因,因为您可以简单地将它们全部放在 .pom 文件中。集中式依赖列表的使用允许 Maven 能够看到几乎 运行 程序所需的一切。看看这个 post,它可以执行您正在尝试的操作,但添加每个 jar 以供 Maven 查看它们。 How do I package and run a simple command-line application with dependencies using maven?

此外,这是一本很好的 .pom 基础知识指南 阅读 www.maven.apache.org 上的 pom 指南。

由于 Manifest 规范,Maven 不会按照您尝试的方式使用 cmdline 参数。这是程序员(包括我自己)喜欢 Maven 的根本原因,因为它可以真正让生活变得更简单,因为它的构建正是为了满足您的需求。随着文件的更改,您有一个文件来制作更新版本。

如果您使用 Windows 10 周年更新或 Windows Server 2016 或更高版本,您可以将最大路径长度增加到超过 260 个字符的默认值。

您可以将以下两行复制到扩展名为 .reg 的文件中并打开它,

[HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Control\FileSystem]
"LongPathsEnabled"=dword:00000001

或者,打开注册表编辑器并浏览到该位置,然后将值从 0 更改为 1。

所以我确实为这个问题苦苦挣扎了很长时间,终于在做maven构建时找到了解决类路径太长问题的方法。 这是一种解决方法,但效果很好。

运行 从 linux 构建 - 这不是开玩笑(原文如此!)

  • 通过以下步骤在 Windows 上打开 WSL(Windows Linux 的子系统) https://docs.microsoft.com/en-us/windows/wsl/install-win10
  • 完成后 运行 您的 Linux 子系统在 windows
  • 编辑 linux maven settings.xml /usr/share/maven/conf/settings.xml
  • 添加或覆盖 <localRepository>/mnt/c/.m2</localRepository> (/mnt/c/.m2) - 是我的 windows 从 WSL 看到的 maven repo 路径
  • cd /path/to/your/project
  • mvn 构建