java LogWriter

package org.rx.core;

import lombok.Getter;
import lombok.Setter;
import lombok.SneakyThrows;
import lombok.extern.slf4j.Slf4j;
import org.jetbrains.annotations.NotNull;

import java.io.StringWriter;

import static org.rx.core.Contract.require;

@Slf4j
public class LogWriter extends StringWriter {
    private org.slf4j.Logger logRef;
    @Getter
    @Setter
    private String prefix;

    public LogWriter() {
        this(log);
    }

    public LogWriter(org.slf4j.Logger log) {
        require(log);

        this.logRef = log;
    }

    @Override
    public void write(@NotNull String str) {
        super.write(prefix);
        super.write(" ");
        super.write(str);
    }

    @Override
    public void write(String str, int off, int len) {
        write(str.substring(off, off + len));
    }

    public LogWriter writeLine() {
        super.write(System.lineSeparator());
        return this;
    }

    public LogWriter info(Object obj) {
        write(String.valueOf(obj));
        writeLine();
        return this;
    }

    public LogWriter info(String format, Object... args) {
        write(String.format(format.replace("{}", "%s"), args));
        writeLine();
        return this;
    }

    public LogWriter infoAndFlush(Object obj) {
        info(obj).flush();
        return this;
    }

    public LogWriter infoAndFlush(String format, Object... args) {
        info(format, args).flush();
        return this;
    }

    public LogWriter error(String msg, Throwable e) {
        logRef.error(msg, e);
        return this;
    }

    @Override
    public void flush() {
        super.flush();
        StringBuffer buffer = super.getBuffer();
        logRef.info(buffer.toString());
        buffer.setLength(0);
    }

    @SneakyThrows
    @Override
    public void close() {
        this.flush();
        super.close();
    }
}

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Java可以通过Kettle的Java API来集成Kettle。以下是集成Kettle的步骤: 1. 下载Kettle的Java API jar包,将其添加到Java项目的类路径中。 2. 创建一个Kettle环境,可以使用KettleEnvironment.init()方法来初始化Kettle环境。 3. 创建一个Kettle的转换或作业对象。 4. 设置转换或作业的参数,可以使用Kettle的参数管理器来设置参数。 5. 执行转换或作业,可以使用Kettle的执行引擎来执行转换或作业。 6. 处理转换或作业的执行结果,可以使用Kettle的日志和结果管理器来处理执行结果。 以下是一个简单的示例代码,演示了如何使用Kettle的Java API来执行一个转换: ``` import org.pentaho.di.core.KettleEnvironment; import org.pentaho.di.core.logging.LogLevel; import org.pentaho.di.core.logging.LogWriter; import org.pentaho.di.core.logging.LoggingRegistry; import org.pentaho.di.core.parameters.UnknownParamException; import org.pentaho.di.core.variables.Variables; import org.pentaho.di.trans.Trans; import org.pentaho.di.trans.TransMeta; public class KettleIntegrationDemo { public static void main(String[] args) { try { // 初始化Kettle环境 KettleEnvironment.init(); // 创建转换对象 TransMeta transMeta = new TransMeta("path/to/your/transformation.ktr"); // 创建参数管理器,并设置参数 Variables variables = new Variables(); variables.setVariable("inputFilePath", "/path/to/input/file.csv"); variables.setVariable("outputFilePath", "/path/to/output/file.csv"); // 创建转换对象,并设置参数 Trans trans = new Trans(transMeta, variables); // 设置日志级别 trans.setLogLevel(LogLevel.BASIC); // 启动转换 trans.execute(null); // 等待转换执行完成 trans.waitUntilFinished(); // 处理转换执行结果 if (trans.getErrors() > 0) { System.out.println("转换执行出错!"); } else { System.out.println("转换执行成功!"); } } catch (Exception e) { e.printStackTrace(); } } } ``` 需要注意的是,Kettle的Java API是基于线程安全的,因此可以在一个Java应用程序中同时执行多个转换或作业。同时,Kettle也提供了丰富的API来管理转换或作业的执行结果,包括日志、结果集、错误处理等。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值