gpt4 book ai didi

java - 运行 java MainClasses 的工具,设计避免依赖陷阱

转载 作者:行者123 更新时间:2023-11-28 20:46:08 25 4
gpt4 key购买 nike

我必须实现一个工具来读取配置文件并运行配置文件中指定的应用程序/程序。一种用于测试的自动运行程序。我已经实现了一个执行此操作的程序,但是我遇到了依赖墙。在我当前的设计中,工具解析配置文件并检索程序类型映射和作业列表。基于ProgramType,选择并初始化一个Runner类,runner类是Program src的一部分。

//this is just a pseudo code
pkg org.Tool

class Tool {
//after parsing
runJobs(map) {
if(map.get() == ProgramType)
org.Tool.JobStats = org.ProgramType.Runner.run(Job)
}
}

pkg org.ProgramType

class Runner {
org.Tool.JobStats run(Job) {
if(Job = "certain job")
return CertainJob.run(Job)
}
}

要构建工具,我需要编译 org.ProgramType.*;要构建 ProgramType,我需要 org.Tool.Job 和 org.Tool.JobStats。我创建的“依赖 hell ”显然是非常糟糕的设计。我提出了一个解决方案,只需调用 ProgramType jar 并将 JobStats 存储在 jobStats.txt 文件中,一旦 jar 执行完成,读取文件并处理它。此解决方案是 Not Acceptable ,因为作业可以使用许多配置等运行多次,只需处理大量 *.txt 文件。我想我曾经看到过针对我的问题的编译解决方案,比如“部分编译”工具、编译 ProgramType、重新编译工具。但是我找不到它,摆脱“依赖 hell ”反模式也是明智的。因此我的问题是“我应该如何设计这个”。

(我希望解释清楚,如果不是只是问)

已解决

正如我在@aviad 的评论中所写,我正在寻找一种设计模式来解决我的问题。我找到了一个叫做“依赖倒置原则”的方法。我在这里链接了一个描述模式的 pdf 文档,它值得一读 (http://www.objectmentor.com/resources/articles/dip.pdf)(另一个很好的解释 http://java.dzone.com/articles/fun-modules )。谢谢大家的帮助(我真的很喜欢你们推荐的框架)。

最佳答案

如果可以使用 SpringBatch,我认为您仍然可以使用大部分代码框架。

使用 Spring 批处理的优势在于它是一个框架,所有困难的工作都已经完成(配置、多线程、持久性等)。

基本上你需要运行的java程序可以通过运行一个启动的批处理文件\shell脚本来执行:

java -cp %JOB_CLASSPATH% %JOB_MAIN_CLASS_FULLY_QUALIFIED_CLASS_NAME%

所以我会使用以下设计:

整个解决方案是基于 Spring 的应用程序。读取配置并运行显示的 Controller 类(您的主类)。 Controller 类使用作业及其配置填充作业队列。然后从队列中检索每个作业,并以编程方式实例化并运行 Spring 批处理作业。

您还可以使用 Commons Exec用于从 java 执行批处理文件\shell 脚本。

稍后您可以移动到在 web 容器中运行(为了启用配置更改和通过 http 触发的作业)- 检查 Spring Batch Admin

如果您使用 Quartz FW,您还可以按计划方式运行您的解决方案

祝你好运!

关于java - 运行 java MainClasses 的工具,设计避免依赖陷阱,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9310297/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com