datax 自定义钩子实现类

文章背景:

项目中使用datax 作为交换中间件,发现统计有异常,发现datax 统计异常,查看datax源码 发现datax 提供一个钩子函数 this.invokeHooks();

涉及技术点

spi
java 调用datax

实现步骤

1.实现hook接口

package com.bonc.hamal.swapnode.datax;

import com.alibaba.datax.common.spi.Hook;
import com.alibaba.datax.common.util.Configuration;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

import java.util.Map;

/**
 * @author
 * @version V1.0
 * @Description: (用一句话描述该文件做什么)
 * @date
 */
public class DataxHook  implements Hook {

     Logger logger = LoggerFactory.getLogger(this.getClass());
    @Override
    public String getName() {
        return this.getClass().getName();
    }

    @Override
    public void invoke(Configuration configuration, Map<String, Number> map) {
		  // 在这里写自己的业务函数
        logger.error("钩子执行参数 map:{}",map);
    }

}

2. 在datax job同一级目录创建hook目录

3. 进入hook目录给创建一个文件夹

4. 将步骤1生成的class 文件 放入到步骤1生成的目录中

5. 在自己的项目resource目录下创建

META-INF\services\com.alibaba.datax.common.spi.Hook 文件

6.在com.alibaba.datax.common.spi.Hook 写上步骤一自定义实现类的全类名

验证 运行datax的启动类 验证

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值