5
0
mirror of https://github.com/apache/sqoop.git synced 2025-05-03 04:11:44 +08:00

SQOOP-357. Debug logs should include chained exception trace.

(Bilung Lee via Arvind Prabhakar)


git-svn-id: https://svn.apache.org/repos/asf/incubator/sqoop/trunk@1180162 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
Arvind Prabhakar 2011-10-07 19:12:01 +00:00
parent fd3634dc3c
commit d6eec1f2d5
3 changed files with 62 additions and 1 deletions

View File

@ -27,11 +27,13 @@
import java.util.ArrayList;
import java.util.List;
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
import org.apache.hadoop.conf.Configuration;
import org.apache.hadoop.mapreduce.RecordWriter;
import org.apache.hadoop.mapreduce.TaskAttemptContext;
import com.cloudera.sqoop.mapreduce.db.DBConfiguration;
import com.cloudera.sqoop.util.LoggingUtils;
import com.cloudera.sqoop.lib.SqoopRecord;
/**
@ -47,6 +49,8 @@
public abstract class AsyncSqlRecordWriter<K extends SqoopRecord, V>
extends RecordWriter<K, V> {
private static final Log LOG = LogFactory.getLog(AsyncSqlRecordWriter.class);
private Connection connection;
private Configuration conf;
@ -166,6 +170,7 @@ private void execUpdate(boolean commit, boolean stopThread)
// Check for any previous SQLException. If one happened, rethrow it here.
SQLException lastException = execThread.getLastError();
if (null != lastException) {
LoggingUtils.logAll(LOG, lastException);
throw lastException;
}
}

View File

@ -37,6 +37,8 @@
import org.apache.hadoop.util.ReflectionUtils;
import org.apache.hadoop.conf.Configuration;
import com.cloudera.sqoop.util.LoggingUtils;
/**
* A RecordReader that reads records from a SQL table.
* Emits LongWritables containing the record number as
@ -245,6 +247,7 @@ public boolean nextKeyValue() throws IOException {
pos++;
} catch (SQLException e) {
LoggingUtils.logAll(LOG, e);
throw new IOException("SQLException in nextKeyValue", e);
}
return true;

View File

@ -0,0 +1,53 @@
/**
* Copyright 2011 The Apache Software Foundation
*
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. The ASF licenses this file
* to you under the Apache License, Version 2.0 (the
* "License"); you may not use this file except in compliance
* with the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package com.cloudera.sqoop.util;
import java.sql.SQLException;
import org.apache.commons.logging.Log;
/**
* A helper class for logging.
*/
public final class LoggingUtils {
/**
* Private constructor to prevent instantiation.
*/
private LoggingUtils() {
}
/**
* Log every exception in the chain if
* the exception is a chain of exceptions.
*/
public static void logAll(Log log, SQLException e) {
log.error("Top level exception: ", e);
e = e.getNextException();
int indx = 1;
while (e != null) {
log.error("Chained exception " + indx + ": ", e);
e = e.getNextException();
indx++;
}
}
}