我们正在Kubernetes中部署Spring Cloud Data Flow v2.2.1.RELEASE。一切似乎都可行,但调度却不可行。实际上,即使使用UI(或API)手动启动运行任务时,我们也会看到错误日志。尝试计划时会生成相同的日志,但这一次使计划创建失败。
这是堆栈跟踪摘录:

java.lang.IllegalArgumentException: taskDefinitionName must not be null or empty
    at org.springframework.util.Assert.hasText(Assert.java:284)
    at org.springframework.cloud.dataflow.rest.resource.ScheduleInfoResource.<init>(ScheduleInfoResource.java:58)
    at org.springframework.cloud.dataflow.server.controller.TaskSchedulerController$Assembler.instantiateResource(TaskSchedulerController.java:174)
    at org.springframework.cloud.dataflow.server.controller.TaskSchedulerController$Assembler.instantiateResource(TaskSchedulerController.java:160)
    at org.springframework.hateoas.mvc.ResourceAssemblerSupport.createResourceWithId(ResourceAssemblerSupport.java:89)
    at org.springframework.hateoas.mvc.ResourceAssemblerSupport.createResourceWithId(ResourceAssemblerSupport.java:81)
    at org.springframework.cloud.dataflow.server.controller.TaskSchedulerController$Assembler.toResource(TaskSchedulerController.java:168)
    at org.springframework.cloud.dataflow.server.controller.TaskSchedulerController$Assembler.toResource(TaskSchedulerController.java:160)
    at org.springframework.data.web.PagedResourcesAssembler.createResource(PagedResourcesAssembler.java:208)
    at org.springframework.data.web.PagedResourcesAssembler.toResource(PagedResourcesAssembler.java:120)
    at org.springframework.cloud.dataflow.server.controller.TaskSchedulerController.list(TaskSchedulerController.java:85)
    at sun.reflect.GeneratedMethodAccessor180.invoke(Unknown Source)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
    at java.lang.reflect.Method.invoke(Method.java:498)

...,

我们已经查看了表内容,该任务确实有一个名称。

任何的想法?

最佳答案

我终于通过调试实时数据流找到了错误的根源。当不是由Data Flow创建的CronJob存在于 namespace 中时,就会出现问题,据我评估,这是一个问题。调度程序启动一个进程,该进程在Kubernetes CronJob资源上循环并尝试对其进行处理。

像所有Kubernetes原生工具一样,Data Flow当然应该对使用标签的对象进行处理,以仅选择与之相关的元素。任何进程都可以使用CronJob。

因此,Pivotal-Data Flow人员,增强该部分可能是一个好主意,并且这种方式可以防止此类“隐形”问题。我说不可见是因为我们得到的唯一错误是Schedule项目的验证,抱怨名称为空这一事实,这是因为CronJob没有以任何方式链接到SCDF任务。

希望以后能对某人有所帮助。

错误报告:https://github.com/spring-cloud/spring-cloud-deployer-kubernetes/issues/347

公关发布:https://github.com/spring-cloud/spring-cloud-deployer-kubernetes/pull/348

09-04 06:42
查看更多