向DataX插件执行器增加调用参数

在最外层调用方法增加一个参数dynamicsParam

JobTriggerPoolHelper.trigger(jobId, TriggerTypeEnum.MANUAL, -1, null, executorParam, dynamicsParam);

在JobTriggerPoolHelper类中方法增加参数dynamicsParam

helper.addTrigger(jobId, triggerType, failRetryCount, executorShardingParam, executorParam, null, dynamicsParam);

在JobTrigger类中方法和实体中增加参数dynamicsParam

JobTrigger.trigger(jobId, triggerType, failRetryCount, executorShardingParam, executorParam, receiveData, dynamicsParam);
processTrigger(group, jobInfo, finalFailRetryCount, triggerType, i, group.getRegistryList().size(),dynamicsParam);

在TriggerParam实体类中增加 

private String dynamicsParam;

processTrigger中

triggerParam.setDynamicsParam(dynamicsParam);

在ExecutorJobHandler中

public ReturnT<String> execute(TriggerParam trigger)
EngineVo engineVo = EngineVo.build(trigger.getJobId(), trigger.getJobJson(), trigger.getReceiveData(),trigger.getDynamicsParam(),trigger.getApiConfig());

在EngineVo实体类中增加 

private String dynamicsParam;

在WebEngine的public static void runTask(EngineVo engineVo)中

String dynamicsParam = engineVo.getDynamicsParam();
if (StringUtils.isNotBlank(dynamicsParam)){
            configuration.set(CoreConstant.DYNAMICS_PARAM, dynamicsParam);
        }

以读插件为例:

在DiyJobContainer类中
private Reader.Job initJobReader(JobPluginCollector jobPluginCollector) {
    String dynamicsParam = this.configuration.getString(CoreConstant.DYNAMICS_PARAM);
        if (StringUtils.isNotBlank(dynamicsParam)) {
            jobReader.setDynamicsParam(dynamicsParam);
        }
}

在AbstractPlugin

实体类中增加 

private String dynamicsParam;

在插件中获得新增自定义参数

public static class Job extends Reader.Job {
    @Override
    public void init() {
        String dynamicsParam = super.getDynamicsParam();
        originalConfig.set("dynamicsParam",dynamicsParam);
    }

}

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值