19

我们正在尝试为我们的 cron 作业构建一个仪表板——CF、Java、SQLServer 等,以便我们可以看到上次运行的时间、结果是什么以及它们计划下一次运行的时间。

有没有办法使用 CFAdmin API 或一些未记录<cfschedule>的技巧来获取以下列表:

  1. 安排了哪些任务?
  2. 上次运行时间是多少?
  3. 成功了吗?
  4. 计划什么时候再次运行?

我们目前使用的是 CF8,但将在几周内升级到 CF9。

4

3 回答 3

28

我为你做了一些研究。我发现了一个较旧的参考仍然有效,至少在 CF8 中,大概在 CF9 中也是如此。

<cfobject type="JAVA" action="Create" name="factory" class="coldfusion.server.ServiceFactory">
<cfset allTasks = factory.CronService.listAll()/>
<cfloop index="i" from="1" to="#ArrayLen(allTasks)#">
    <cfdump var="#allTasks[i]#" />
</cfloop>

来自http://www.bpurcell.org/blog/index.cfm?mode=entry&ENTRY=935

这回答了您的问题#1 和#4。至于#3,没有答案。ColdFusion 的计划任务引擎只是在规定的时间加载指定的 URL。没有成功或失败——它只是执行一个 HTTP 请求。

希望这可以帮助。

于 2010-02-23T18:48:12.350 回答
1

可以“发布”作业的结果。HTTP 请求的响应可以写入文件服务器,其中包含上次运行作业的值。

<cfschedule action = "update"
    task = "TaskName" 
    operation = "HTTPRequest"
    url = "/index.cfm?action=task"
    startDate = "#STARTDATE#"
    startTime = "12:00:00 AM"
    interval = "Daily"
    resolveURL = "NO"
    requestTimeOut = "600"
    publish = "yes"
    path = "#PATH#"
    file = "log_file.log">

然后,如果需要,您可以根据数据库验证日志。由于它是来自页面的响应,因此您也可以在此处获取和存储错误和警告。

于 2012-05-21T21:44:31.130 回答
1

@eric kolb 是对的 - 这就是以编程方式进行的方式。如果您想更好地控制列表的反应方式,请尝试以下代码(基本相同,但在 cfscript 中):

<cfscript>
scheduledTasksArray=ArrayNew(1);
taskService=createobject('java','coldfusion.server.ServiceFactory').getCronService();
scheduledTasksArray=taskservice.listall();

另外,要回答 #2 和 #3(如果你做对了,这几乎只是一个由两部分组成的问题):当任务运行时,在顶部给自己发送一封电子邮件,说“嘿!我正在运行! !!!” 然后又说“嘿!我完成了!!!” 在任务代码的底部 - 您还可以添加时间戳以告知它何时开始和停止(将其记录在数据库中也可以)。此外,要知道下一次运行的时间,只需查看最后一次以及从 ServiceFactory 调用的结果中返回的“间隔”字段。(如果您需要进一步解释我的意思,请随时提问。

如果你还没有弄清楚你需要什么,希望这会有所帮助

于 2012-07-17T20:48:25.493 回答