- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
这个问题和这个有点相似Best way to deploy large *.war to tomcat所以这是一本很好的读物,但请继续阅读我的问题,最后会有所不同...
使用 maven 2 我的 war 文件非常大 (60M)。我将它们部署到一组 tomcat 服务器上,只是复制文件花费的时间太长(每场 war 大约 1m)。
最重要的是,我添加了一个 RPM 层,它将 war 打包到一个 RPM 文件中(使用 maven 的 rpm 插件)。当 RPM 在目标机器上执行时,它会清理、“安装”war(只需复制它)、停止并启动 tomcat(这就是我们在这里做事的方式,没有热部署)并在中设置适当的上下文文件地方。这一切都很好。
然而,问题在于 RPM 文件太大且复制速度慢。几乎占据整个空间的自然是war文件。
我还没有看到任何现成的解决方案,所以我正在考虑自己实现一个解决方案,所以我将在下面对其进行描述,并且此描述有望有助于解释问题域。我很高兴听到您对计划的解决方案的想法,并且更好地向我指出其他现有解决方案和随机提示。
war 文件包含:
大部分空间都被 #2,第 3 方 jar 占用了。
第 3 方 jar 也安装在我们公司的内部 Nexus 服务器上,因此我可以利用它。
你现在可能已经猜到了,所以计划是创建仅包含应用程序 jar(由我公司编写的)、资源和 WEB-INF 内容的小型 war ,并向 RPM 安装脚本添加智能将在需要时复制第 3 方 jar 。
RPM 允许您在安装之前或之后运行任意脚本,因此计划是在构建 war 时使用 mvn 编写第 3 方依赖项列表并将其作为资源添加到 RPM,然后在安装 RPM 时 RPM 安装脚本将运行在所需的第 3 方 jar 列表上,仅当它们尚不存在时才从 nexus 下载新的 jar。
如果不使用,RPM 将不得不删除 jar。
RPM 还必须为 tomcat 重建 war 以使其爆炸,或者将第 3 方 jar 添加到 common/lib 或类似的东西,尽管我们每个 tomcat 都有一些网络应用程序,所以从这个意义上讲它会使事情变得复杂。也许自己爆炸 jar ,然后将第 3 方 jar 复制到 WEB-INF/lib
感谢您的意见:)
最佳答案
我们在目标机器上有一个目录,其中包含我们正在使用的所有第三方 jar(大约 110Mb)。这些 jar 使用的命名编码约定包括它们的版本号(asm-3.2.jar、asm-2.2.3.jar ...)。添加第三方的新版本时,我们不会删除旧版本。
部署时,我们的 jar 文件仅包含我们在构建中编译的业务逻辑类和资源(无第三方)。类路径在 jar manifest 中定义我们在运行时挑选它应该使用的第三方。我们正在用 ant 做这件事,没有涉及 maven,我们的系统中有超过 25 种类型的服务(非常“soa”,虽然我不喜欢这个流行词)。该业务逻辑 jar 是启动进程时 jvm 类路径中唯一的 jar,它也由我们的代码 repo 修订号进行版本控制。如果您返回到我们代码的旧版本(回滚),它可能使用旧的第三方 jar,它仍然可以工作,因为我们不会删除旧 jar。新的第三方 jar 应该在使用它们的业务代码之前传播到生产机器。但是一旦他们在那里,他们就不会在每次部署时被重新推送。
总体而言,我们倾向于简单性(即不是 OSGi)并且我们不使用 Maven。
关于java - Maven - 部署大型 war 文件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4192940/
我试图理解 Maven 模块和 Maven 项目之间的区别。哪一个是什么以及我应该在哪里?谢谢 最佳答案 maven 模块就像一个 maven“子项目”。一个 Maven 项目包含 1 个或多个模块。
我们目前没有自己的存储库。因此,当我们使用 Maven 构建时,它会在当前用户的主目录中创建 .m2 存储库。 现在有两个在 Maven Central 中找不到的第三方 jar。假设其中之一是 ha
我有 Maven 项目,但在其中一台服务器上我必须在没有 Maven 的情况下构建它。 可以使用标准 JDK 命令。在哪里可以看到 Maven 在构建项目时向 JDK 发送了哪些命令? 最佳答案 Ma
我打算将 ImageJ 用于 web 应用程序,但似乎 ImageJ maven 依赖项不在中央 maven 存储库中。 我说得对吗? 当 ImageJ 2.x 发布时,这会改变吗? 最佳答案 您可以
我可以有多个 Maven 实例吗,即 Mave 2.2.1 和 Maven 3 都指向同一个本地存储库? 我的意思是我知道我可以在技术上将每个 settings.xml 指向同一个文件夹,但从长远来看
我有两个项目,项目 A 依赖于项目 B,所以通常,我的 projectA/pom.xml 中有以下部分: projectB blabla version1 我想要实现的目标非常简
在网上的许多地方,我看到它讨论了要使 maven 构建可重现,明确指定所有使用的插件的版本号很重要,这样更新的插件就不会破坏构建。推荐的方法似乎是使用 enforcer 插件。下面是我在网上找到的复制
有没有办法暂停 Maven 执行流程以提供命令提示符,以便用户可以输入文本。 然后我希望将提供的文本存储在 Maven 属性中。 如果用户输入可以被屏蔽,那将是一个奖励。 这对于避免在 pom.xml
我正在尝试使用 maven 插件将 maven java 项目的源文件夹添加到 Eclipse。 尝试使用 org.codehaus.mojo 插件时,我收到以下错误 无法在项目应用程序框架上执行目标
我有两个几乎相同的配置文件。我不想在每个配置文件中复制配置,而是希望一个配置文件从另一个配置文件“继承”,但我没有看到使用 maven 3 执行此操作的明显方法。 在 Maven 中是否可以继承配置文
我是 Maven 新手,花了大约 3 天的时间使用程序集插件生成 zip 文件,引用 http://www.petrikainulainen.net/programming/tips-and-tric
想象一下这种情况。我有一个使用 Maven 管理的开源项目,它依赖于一个不在 Maven 存储库中的知名库(例如 jpathwatch)。我怎样才能让它发挥作用? 直接的方法是将 jpathwatch
我将 Neo4j 和 MongoDB 与 Grails 一起使用,我想知道 Maven Neo4j 插件是否也为我的构建提供了 Neo4j 依赖项。 MongoDB 也是如此。 我很困惑。我应该使用什
我正在尝试同时发布多个 Maven 项目,将它们部署到 oss.sonatype.org,然后将它们发布到 Maven Central。 我有一个构建 pom,用于一起构建多个多模块项目。构建 pom
我有一个带有 maven pom.xml 的项目 4.0.0 Minimal-J Minimal-J 0.1-SNAPSHOT Minimal-J
我需要制作一个下载maven项目并打印其依赖项的小程序 像这样: MavenArtifactRepository repository = new MavenArtifactRepository("t
我有一个关于 maven 在构建过程中如何计算类路径的问题。具体来说,控制何时使用“目标/类”以及何时使用来自存储库(本地/远程)的“jar”。 我有一个版本为 1.0.0-SNAPSHOT 的项目,
我有一个 maven 项目,需要在命令行(-Dmy.property=val)设置一个属性。 我需要做的是将该字符串转换为所有大写,因为该属性是 用于通过 maven-resources-plugin
引用和转义如何对传递给 Maven 插件的参数起作用? 例如,我想将多个文件名作为参数传递给 Maven Exec 插件运行的应用程序: mvnDebug exec:java -Dexec.mainC
我在父 pom 的导入的 dependencyManagement 部分中指定了一个库版本。我确认我的有效 pom 只有一次出现这种依赖。它在依赖管理部分: org.jav
我是一名优秀的程序员,十分优秀!