HBASE-433 HBASE-251 Region server should delete restore log after successful restore, Stuck replaying the edits of crashed machine.
HLog - don't overwrite oldlogfile in splitLog if it already exists. Rename it and copy it into the new oldlogfile. Then delete it once it has been copied. - use FileUtil.fullyDelete to delete region server log directory. HRegion - delete oldlogfile once it has been successfully processed git-svn-id: https://svn.apache.org/repos/asf/hadoop/hbase/trunk@636396 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
parent
dc6e91f615
commit
082e0237fd
|
@ -33,6 +33,8 @@ Hbase Change Log
|
||||||
HBASE-496 impossible state for createLease writes 400k lines in about 15mins
|
HBASE-496 impossible state for createLease writes 400k lines in about 15mins
|
||||||
HBASE-472 Passing on edits, we dump all to log
|
HBASE-472 Passing on edits, we dump all to log
|
||||||
HBASE-495 No server address listed in .META.
|
HBASE-495 No server address listed in .META.
|
||||||
|
HBASE-433 HBASE-251 Region server should delete restore log after successful
|
||||||
|
restore, Stuck replaying the edits of crashed machine.
|
||||||
|
|
||||||
IMPROVEMENTS
|
IMPROVEMENTS
|
||||||
HBASE-415 Rewrite leases to use DelayedBlockingQueue instead of polling
|
HBASE-415 Rewrite leases to use DelayedBlockingQueue instead of polling
|
||||||
|
|
|
@ -19,7 +19,6 @@
|
||||||
*/
|
*/
|
||||||
package org.apache.hadoop.hbase.regionserver;
|
package org.apache.hadoop.hbase.regionserver;
|
||||||
|
|
||||||
import java.io.File;
|
|
||||||
import java.io.FileNotFoundException;
|
import java.io.FileNotFoundException;
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.util.Collections;
|
import java.util.Collections;
|
||||||
|
@ -49,6 +48,7 @@ import org.apache.hadoop.hbase.HStoreKey;
|
||||||
import org.apache.hadoop.hbase.HTableDescriptor;
|
import org.apache.hadoop.hbase.HTableDescriptor;
|
||||||
import org.apache.hadoop.hbase.HRegionInfo;
|
import org.apache.hadoop.hbase.HRegionInfo;
|
||||||
import org.apache.hadoop.hbase.HBaseConfiguration;
|
import org.apache.hadoop.hbase.HBaseConfiguration;
|
||||||
|
import org.apache.hadoop.hbase.RemoteExceptionHandler;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* HLog stores all the edits to the HStore.
|
* HLog stores all the edits to the HStore.
|
||||||
|
@ -304,7 +304,7 @@ public class HLog implements HConstants {
|
||||||
* file-number.
|
* file-number.
|
||||||
*/
|
*/
|
||||||
Path computeFilename(final long fn) {
|
Path computeFilename(final long fn) {
|
||||||
return new Path(dir, HLOG_DATFILE + new Long(fn).toString());
|
return new Path(dir, HLOG_DATFILE + fn);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -503,7 +503,15 @@ public class HLog implements HConstants {
|
||||||
*/
|
*/
|
||||||
public static void splitLog(Path rootDir, Path srcDir, FileSystem fs,
|
public static void splitLog(Path rootDir, Path srcDir, FileSystem fs,
|
||||||
Configuration conf) throws IOException {
|
Configuration conf) throws IOException {
|
||||||
|
if (!fs.exists(srcDir)) {
|
||||||
|
// Nothing to do
|
||||||
|
return;
|
||||||
|
}
|
||||||
FileStatus logfiles[] = fs.listStatus(srcDir);
|
FileStatus logfiles[] = fs.listStatus(srcDir);
|
||||||
|
if (logfiles == null || logfiles.length == 0) {
|
||||||
|
// Nothing to do
|
||||||
|
return;
|
||||||
|
}
|
||||||
LOG.info("splitting " + logfiles.length + " log(s) in " +
|
LOG.info("splitting " + logfiles.length + " log(s) in " +
|
||||||
srcDir.toString());
|
srcDir.toString());
|
||||||
Map<Text, SequenceFile.Writer> logWriters =
|
Map<Text, SequenceFile.Writer> logWriters =
|
||||||
|
@ -512,12 +520,12 @@ public class HLog implements HConstants {
|
||||||
for (int i = 0; i < logfiles.length; i++) {
|
for (int i = 0; i < logfiles.length; i++) {
|
||||||
if (LOG.isDebugEnabled()) {
|
if (LOG.isDebugEnabled()) {
|
||||||
LOG.debug("Splitting " + i + " of " + logfiles.length + ": " +
|
LOG.debug("Splitting " + i + " of " + logfiles.length + ": " +
|
||||||
logfiles[i]);
|
logfiles[i].getPath());
|
||||||
}
|
}
|
||||||
// Check for empty file.
|
// Check for empty file.
|
||||||
if (logfiles[i].getLen() <= 0) {
|
if (logfiles[i].getLen() <= 0) {
|
||||||
LOG.info("Skipping " + logfiles[i].toString() +
|
LOG.info("Skipping " + logfiles[i].toString() +
|
||||||
" because zero length");
|
" because zero length");
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
HLogKey key = new HLogKey();
|
HLogKey key = new HLogKey();
|
||||||
|
@ -538,6 +546,17 @@ public class HLog implements HConstants {
|
||||||
),
|
),
|
||||||
HREGION_OLDLOGFILE_NAME
|
HREGION_OLDLOGFILE_NAME
|
||||||
);
|
);
|
||||||
|
|
||||||
|
Path oldlogfile = null;
|
||||||
|
SequenceFile.Reader old = null;
|
||||||
|
if (fs.exists(logfile)) {
|
||||||
|
LOG.warn("Old log file " + logfile +
|
||||||
|
" already exists. Copying existing file to new file");
|
||||||
|
oldlogfile = new Path(logfile.toString() + ".old");
|
||||||
|
fs.rename(logfile, oldlogfile);
|
||||||
|
old = new SequenceFile.Reader(fs, oldlogfile, conf);
|
||||||
|
}
|
||||||
|
|
||||||
if (LOG.isDebugEnabled()) {
|
if (LOG.isDebugEnabled()) {
|
||||||
LOG.debug("Creating new log file writer for path " + logfile +
|
LOG.debug("Creating new log file writer for path " + logfile +
|
||||||
"; map content " + logWriters.toString());
|
"; map content " + logWriters.toString());
|
||||||
|
@ -547,8 +566,22 @@ public class HLog implements HConstants {
|
||||||
// Use copy of regionName; regionName object is reused inside in
|
// Use copy of regionName; regionName object is reused inside in
|
||||||
// HStoreKey.getRegionName so its content changes as we iterate.
|
// HStoreKey.getRegionName so its content changes as we iterate.
|
||||||
logWriters.put(new Text(regionName), w);
|
logWriters.put(new Text(regionName), w);
|
||||||
|
|
||||||
|
if (old != null) {
|
||||||
|
// Copy from existing log file
|
||||||
|
HLogKey oldkey = new HLogKey();
|
||||||
|
HLogEdit oldval = new HLogEdit();
|
||||||
|
for (; old.next(oldkey, oldval); count++) {
|
||||||
|
if (LOG.isDebugEnabled() && count > 0 && count % 10000 == 0) {
|
||||||
|
LOG.debug("Copied " + count + " edits");
|
||||||
|
}
|
||||||
|
w.append(oldkey, oldval);
|
||||||
|
}
|
||||||
|
old.close();
|
||||||
|
fs.delete(oldlogfile);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
if (count % 10000 == 0 && count > 0 && LOG.isDebugEnabled()) {
|
if (LOG.isDebugEnabled() && count > 0 && count % 10000 == 0) {
|
||||||
LOG.debug("Applied " + count + " edits");
|
LOG.debug("Applied " + count + " edits");
|
||||||
}
|
}
|
||||||
w.append(key, val);
|
w.append(key, val);
|
||||||
|
@ -566,13 +599,13 @@ public class HLog implements HConstants {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (fs.exists(srcDir)) {
|
try {
|
||||||
if (!fs.delete(srcDir)) {
|
FileUtil.fullyDelete(fs, srcDir);
|
||||||
LOG.error("Cannot delete: " + srcDir);
|
} catch (IOException e) {
|
||||||
if (!FileUtil.fullyDelete(new File(srcDir.toString()))) {
|
e = RemoteExceptionHandler.checkIOException(e);
|
||||||
throw new IOException("Cannot delete: " + srcDir);
|
IOException io = new IOException("Cannot delete: " + srcDir);
|
||||||
}
|
io.initCause(e);
|
||||||
}
|
throw io;
|
||||||
}
|
}
|
||||||
LOG.info("log file splitting completed for " + srcDir.toString());
|
LOG.info("log file splitting completed for " + srcDir.toString());
|
||||||
}
|
}
|
||||||
|
|
|
@ -314,6 +314,13 @@ public class HRegion implements HConstants {
|
||||||
maxSeqId = storeSeqId;
|
maxSeqId = storeSeqId;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
if (fs.exists(oldLogFile)) {
|
||||||
|
if (LOG.isDebugEnabled()) {
|
||||||
|
LOG.debug("Deleting old log file: " + oldLogFile);
|
||||||
|
}
|
||||||
|
fs.delete(oldLogFile);
|
||||||
|
}
|
||||||
|
|
||||||
this.minSequenceId = maxSeqId;
|
this.minSequenceId = maxSeqId;
|
||||||
if (LOG.isDebugEnabled()) {
|
if (LOG.isDebugEnabled()) {
|
||||||
LOG.debug("Next sequence id for region " + regionInfo.getRegionName() +
|
LOG.debug("Next sequence id for region " + regionInfo.getRegionName() +
|
||||||
|
|
Loading…
Reference in New Issue