http://blog.sina.com.cn/s/blog_76a8411a01010u2h.html

首先:当我们引入data-integration\lib文件夹下的所有jar包后 运行java程序要求我们必须引入log4j,由此我们可以确认控制台输出的信息为log4j做的:

程序如下:

public static void main(String[] args) throws Exception{
  KettleEnvironment.init();
  try {

JobMeta
jobMeta = new JobMeta("E:\\BI\\sample.kjb", null,null);
   Job job = new
Job(null, jobMeta);
   jobMeta.setArguments(new
String[]{"aaaaa","bbbbbb"});//传参数
           
job.getJobMeta().setInternalKettleVariables(job);

job.setLogLevel(LogLevel.BASIC);
           
// Start the Job, as it is a Thread itself by Kettle.
           
job.start();
           
job.waitUntilFinished();

if (job.getResult() != null &&
job.getResult().getNrErrors() != 0) {
           
 //Do something here.
           
}
           
// Now the job task is finished, mark it as finished.
           
job.setFinished(true);

// Cleanup the parameters used by the job. Post that invoke
GC.
           
jobMeta.eraseParameters();
           
job.eraseParameters();
       
} catch (Exception e) {
            
e.printStackTrace();
       
}

}

 解决步骤:

1、首先想到查看输出这些日志的来源:Job类

2、通过反编译软件 或者 查看源文件 查看代码
找到:this.log = new LogChannel(this);

3、进入LogChannel找到:  private static
LogWriter log = LogWriter.getInstance();

可以看出是单例

4、查看LogWiter的构造方法:

private LogWriter()
  {
   
this.pentahoLogger = Logger.getLogger("org.pentaho.di");
   
this.pentahoLogger.setAdditivity(false);

   
this.pentahoLogger.setLevel(Level.ALL);

   
layout = new Log4jKettleLayout();

   
boolean consoleAppenderFound = false;
    Enumeration
appenders = this.pentahoLogger.getAllAppenders();
    while
(appenders.hasMoreElements()) {
     
Appender appender = (Appender)appenders.nextElement();
     
if ((appender instanceof ConsoleAppender)) {
       
consoleAppenderFound = true;
       
break;
     
}

   
}

    if
(!consoleAppenderFound) {
     
Layout patternLayout = new PatternLayout("%-5p %d{dd-MM
HH:mm:ss,SSS} - %m%n");
     
ConsoleAppender consoleAppender = new
ConsoleAppender(patternLayout);
     
consoleAppender.setName("ConsoleAppender:org.pentaho.di");
     
this.pentahoLogger.addAppender(consoleAppender);
   
}

   
LogManager.getLogger("org.apache.commons.vfs").setLevel(Level.WARN);

}
5、看出 原来 他们是判断有没有控制台输出的,如果没有就加入一个控制台输出的,

log的识别符为:Logger.getLogger("org.pentaho.di");

6、==============================================================

=================================================================

由此,我们可以再我们程序中加入一行代码:
手动的去加入一个FileAppender

在try中第一行加入:

Logger.getLogger("org.pentaho.di").addAppender(new
FileAppender(new SimpleLayout(),
"E:\\logger.log"));

这样我们就可以把console端打印出来的log
直接输入到一个log文件中去了


 

java程序中输出console的日志到文本的更多相关文章

  1. 在java程序中,对于数据的输入/输出操作以“流”(stream)方式进行

    在java程序中,对于数据的输入/输出操作以“流”(stream)方式进行

  2. SQL函数TIMEDIFF在Java程序中使用报错的问题分析

    需求背景 (读者可略过)司机每天从早到晚都会去到不同的自动售货机上补货,而且补货次数和路线等也是因人而异,补货依据是由系统优化并指派.但是目前系统还无法实施有效指挥和优良的补货策略,司机的补货活动因此 ...

  3. 如何在java程序中调用linux命令或者shell脚本

    转自:http://blog.sina.com.cn/s/blog_6433391301019bpn.html 在java程序中如何调用linux的命令?如何调用shell脚本呢? 这里不得不提到ja ...

  4. Java程序中调用Python脚本的方法

    在程序开发中,有时候需要Java程序中调用相关Python脚本,以下内容记录了先关步骤和可能出现问题的解决办法. 1.在Eclipse中新建Maven工程: 2.pom.xml文件中添加如下依赖包之后 ...

  5. java程序中的经常出现的的异常处理课后总结

    一.JDK中常见的异常情况 1.常见异常总结图 2.java中异常分类 Throwable类有两个直接子类: (1)Exception:出现的问题是可以被捕获的 (2)Error:系统错误,通常由JV ...

  6. Linux上从Java程序中调用C函数

    原则上来说,"100%纯Java"的解决方法是最好的,但有些情况下必须使用本地方法.特别是在以下三种情况: 需要访问Java平台无法访问的系统特性和设备: 通过基准测试,发现Jav ...

  7. 在网页程序或Java程序中调用接口实现短信猫收发短信的解决方案

    方案特点: 在网页程序或Java程序中调用接口实现短信猫收发短信的解决方案,简化软件开发流程,减少各应用系统相同模块的重复开发工作,提高系统稳定性和可靠性. 基于HTTP协议的开发接口 使用特点在网页 ...

  8. 在java程序中访问windows有用户名和密码保护的共享目录

    在java程序中访问windows有用户名和密码保护的共享目录 Posted on 2015-11-20 14:03 云自无心水自闲 阅读(3744) 评论(0)  编辑  收藏 --> Jav ...

  9. 在 ASP.NET MVC Web 应用程序中输出 RSS Feeds

    RSS全称Really Simple Syndication.一些更新频率较高的网站可以通过RSS让订阅者快速获取更新信息.RSS文档需遵守XML规范的,其中必需包含标题.链接.描述信息,还可以包含发 ...

随机推荐

  1. java梳理-一个汉字占多大空间

    面试题:一个汉字占多大空间. 事实上这个问题我了解不深的,知道结论不知道为什么.借此梳理下认识. 先回想下java基本类型 一基本类型 :简称四类八种,声明变量的同一时候分配了空间.举比例如以下:   ...

  2. MySQL之myisamchk

    Description, check and repair of MyISAM tables.Used without options all tables on the command will b ...

  3. Python-搭建Nginx+Django环境

    1.安装 flup 模块 下载:http://projects.unbit.it/downloads/uwsgi-latest.tar.gz 安装:python setup.py install 2. ...

  4. 关于分部视图(Partial View)

    一.关于分部视图(Partial View) Partial View是可以应用在View中的,编写一次,在其他View中可以被反复使用.通常都是放在"Views——Shared" ...

  5. 摘:"error LNK2019: 无法解析的外部符号 该符号在函数 中被引用" 错误原因

    例如“error LNK2019: 无法解析的外部符号error LNK2001: 无法解析的外部符号“private: static struct _OVERLAPPED CUsbCom::g_Wr ...

  6. quartz cron表达式在线生成

    近期使用了quartz定时器,有感于起cron表达式有点复杂.且无法实时推断定时时间是否正确,因此写了个在线表达式及依据表达式获得前10次运行时间. 訪问地址例如以下:http://cron.g2ro ...

  7. dbcp2连接池获取数据库连接Connection

    一.先来看看手工创建的方式 public static Connection getConnection() { Connection conn = null; try { Class.forName ...

  8. SortedDictionary<TKey,TValue>正序与反序排序及Dicttionary相关

    SortedDictionary<TKey,TValue>能对字典排序 using System; using System.Collections.Generic; using Syst ...

  9. 停掉一台服务器,Nginx响应慢(转载)

    测试发现的问题及解决办法 1.当后端两台IIS应用服务器都正常时,访问速度非常快,查看日志,原来一个请求,是后端两台服务器同时响应的; 2.为了模仿故障测试,停掉一台IIS应用服务器,这时再访问,请求 ...

  10. mybatis-spring 项目简介

    mybatis-spring 主要是为了解决 spring3.0 中支持 mybatis3.0 1 mybatis-spring 主要包含以下几个部分 数据源 SqlSessionFactory Sq ...