HBASE-22961 Deprecate hbck1 in core
Adds deprecations on HBaseFsck and on supporting classes such as the reporting Interface. Provides alternatives in FSUtils for progress reporting and deprecates methods that use hbck1 facility. Signed-off-by: Peter Somogyi <psomogyi@apache.org>
This commit is contained in:
parent
2e0e1f8d7b
commit
e50ec76ac4
|
@ -1179,6 +1179,17 @@ public abstract class FSUtils extends CommonFSUtils {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Called every so-often by storefile map builder getTableStoreFilePathMap to
|
||||||
|
* report progress.
|
||||||
|
*/
|
||||||
|
interface ProgressReporter {
|
||||||
|
/**
|
||||||
|
* @param status File or directory we are about to process.
|
||||||
|
*/
|
||||||
|
void progress(FileStatus status);
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Runs through the HBase rootdir/tablename and creates a reverse lookup map for
|
* Runs through the HBase rootdir/tablename and creates a reverse lookup map for
|
||||||
* table StoreFile names to the full Path.
|
* table StoreFile names to the full Path.
|
||||||
|
@ -1198,7 +1209,8 @@ public abstract class FSUtils extends CommonFSUtils {
|
||||||
public static Map<String, Path> getTableStoreFilePathMap(Map<String, Path> map,
|
public static Map<String, Path> getTableStoreFilePathMap(Map<String, Path> map,
|
||||||
final FileSystem fs, final Path hbaseRootDir, TableName tableName)
|
final FileSystem fs, final Path hbaseRootDir, TableName tableName)
|
||||||
throws IOException, InterruptedException {
|
throws IOException, InterruptedException {
|
||||||
return getTableStoreFilePathMap(map, fs, hbaseRootDir, tableName, null, null, null);
|
return getTableStoreFilePathMap(map, fs, hbaseRootDir, tableName, null, null,
|
||||||
|
(ProgressReporter)null);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -1218,14 +1230,54 @@ public abstract class FSUtils extends CommonFSUtils {
|
||||||
* @param tableName name of the table to scan.
|
* @param tableName name of the table to scan.
|
||||||
* @param sfFilter optional path filter to apply to store files
|
* @param sfFilter optional path filter to apply to store files
|
||||||
* @param executor optional executor service to parallelize this operation
|
* @param executor optional executor service to parallelize this operation
|
||||||
* @param errors ErrorReporter instance or null
|
* @param progressReporter Instance or null; gets called every time we move to new region of
|
||||||
|
* family dir and for each store file.
|
||||||
|
* @return Map keyed by StoreFile name with a value of the full Path.
|
||||||
|
* @throws IOException When scanning the directory fails.
|
||||||
|
* @deprecated Since 2.3.0. For removal in hbase4. Use ProgressReporter override instead.
|
||||||
|
*/
|
||||||
|
@Deprecated
|
||||||
|
public static Map<String, Path> getTableStoreFilePathMap(Map<String, Path> resultMap,
|
||||||
|
final FileSystem fs, final Path hbaseRootDir, TableName tableName, final PathFilter sfFilter,
|
||||||
|
ExecutorService executor, final HbckErrorReporter progressReporter)
|
||||||
|
throws IOException, InterruptedException {
|
||||||
|
return getTableStoreFilePathMap(resultMap, fs, hbaseRootDir, tableName, sfFilter, executor,
|
||||||
|
new ProgressReporter() {
|
||||||
|
@Override
|
||||||
|
public void progress(FileStatus status) {
|
||||||
|
// status is not used in this implementation.
|
||||||
|
progressReporter.progress();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Runs through the HBase rootdir/tablename and creates a reverse lookup map for
|
||||||
|
* table StoreFile names to the full Path. Note that because this method can be called
|
||||||
|
* on a 'live' HBase system that we will skip files that no longer exist by the time
|
||||||
|
* we traverse them and similarly the user of the result needs to consider that some
|
||||||
|
* entries in this map may not exist by the time this call completes.
|
||||||
|
* <br>
|
||||||
|
* Example...<br>
|
||||||
|
* Key = 3944417774205889744 <br>
|
||||||
|
* Value = hdfs://localhost:51169/user/userid/-ROOT-/70236052/info/3944417774205889744
|
||||||
|
*
|
||||||
|
* @param resultMap map to add values. If null, this method will create and populate one
|
||||||
|
* to return
|
||||||
|
* @param fs The file system to use.
|
||||||
|
* @param hbaseRootDir The root directory to scan.
|
||||||
|
* @param tableName name of the table to scan.
|
||||||
|
* @param sfFilter optional path filter to apply to store files
|
||||||
|
* @param executor optional executor service to parallelize this operation
|
||||||
|
* @param progressReporter Instance or null; gets called every time we move to new region of
|
||||||
|
* family dir and for each store file.
|
||||||
* @return Map keyed by StoreFile name with a value of the full Path.
|
* @return Map keyed by StoreFile name with a value of the full Path.
|
||||||
* @throws IOException When scanning the directory fails.
|
* @throws IOException When scanning the directory fails.
|
||||||
* @throws InterruptedException
|
* @throws InterruptedException
|
||||||
*/
|
*/
|
||||||
public static Map<String, Path> getTableStoreFilePathMap(Map<String, Path> resultMap,
|
public static Map<String, Path> getTableStoreFilePathMap(Map<String, Path> resultMap,
|
||||||
final FileSystem fs, final Path hbaseRootDir, TableName tableName, final PathFilter sfFilter,
|
final FileSystem fs, final Path hbaseRootDir, TableName tableName, final PathFilter sfFilter,
|
||||||
ExecutorService executor, final HbckErrorReporter errors)
|
ExecutorService executor, final ProgressReporter progressReporter)
|
||||||
throws IOException, InterruptedException {
|
throws IOException, InterruptedException {
|
||||||
|
|
||||||
final Map<String, Path> finalResultMap =
|
final Map<String, Path> finalResultMap =
|
||||||
|
@ -1247,8 +1299,8 @@ public abstract class FSUtils extends CommonFSUtils {
|
||||||
final List<Future<?>> futures = new ArrayList<>(regionDirs.size());
|
final List<Future<?>> futures = new ArrayList<>(regionDirs.size());
|
||||||
|
|
||||||
for (FileStatus regionDir : regionDirs) {
|
for (FileStatus regionDir : regionDirs) {
|
||||||
if (null != errors) {
|
if (null != progressReporter) {
|
||||||
errors.progress();
|
progressReporter.progress(regionDir);
|
||||||
}
|
}
|
||||||
final Path dd = regionDir.getPath();
|
final Path dd = regionDir.getPath();
|
||||||
|
|
||||||
|
@ -1271,8 +1323,8 @@ public abstract class FSUtils extends CommonFSUtils {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
for (FileStatus familyDir : familyDirs) {
|
for (FileStatus familyDir : familyDirs) {
|
||||||
if (null != errors) {
|
if (null != progressReporter) {
|
||||||
errors.progress();
|
progressReporter.progress(familyDir);
|
||||||
}
|
}
|
||||||
Path family = familyDir.getPath();
|
Path family = familyDir.getPath();
|
||||||
if (family.getName().equals(HConstants.RECOVERED_EDITS_DIR)) {
|
if (family.getName().equals(HConstants.RECOVERED_EDITS_DIR)) {
|
||||||
|
@ -1282,8 +1334,8 @@ public abstract class FSUtils extends CommonFSUtils {
|
||||||
// put in map
|
// put in map
|
||||||
FileStatus[] familyStatus = fs.listStatus(family);
|
FileStatus[] familyStatus = fs.listStatus(family);
|
||||||
for (FileStatus sfStatus : familyStatus) {
|
for (FileStatus sfStatus : familyStatus) {
|
||||||
if (null != errors) {
|
if (null != progressReporter) {
|
||||||
errors.progress();
|
progressReporter.progress(sfStatus);
|
||||||
}
|
}
|
||||||
Path sf = sfStatus.getPath();
|
Path sf = sfStatus.getPath();
|
||||||
if (sfFilter == null || sfFilter.accept(sf)) {
|
if (sfFilter == null || sfFilter.accept(sf)) {
|
||||||
|
@ -1362,12 +1414,11 @@ public abstract class FSUtils extends CommonFSUtils {
|
||||||
* @param hbaseRootDir The root directory to scan.
|
* @param hbaseRootDir The root directory to scan.
|
||||||
* @return Map keyed by StoreFile name with a value of the full Path.
|
* @return Map keyed by StoreFile name with a value of the full Path.
|
||||||
* @throws IOException When scanning the directory fails.
|
* @throws IOException When scanning the directory fails.
|
||||||
* @throws InterruptedException
|
|
||||||
*/
|
*/
|
||||||
public static Map<String, Path> getTableStoreFilePathMap(
|
public static Map<String, Path> getTableStoreFilePathMap(final FileSystem fs,
|
||||||
final FileSystem fs, final Path hbaseRootDir)
|
final Path hbaseRootDir)
|
||||||
throws IOException, InterruptedException {
|
throws IOException, InterruptedException {
|
||||||
return getTableStoreFilePathMap(fs, hbaseRootDir, null, null, null);
|
return getTableStoreFilePathMap(fs, hbaseRootDir, null, null, (ProgressReporter)null);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -1382,14 +1433,49 @@ public abstract class FSUtils extends CommonFSUtils {
|
||||||
* @param hbaseRootDir The root directory to scan.
|
* @param hbaseRootDir The root directory to scan.
|
||||||
* @param sfFilter optional path filter to apply to store files
|
* @param sfFilter optional path filter to apply to store files
|
||||||
* @param executor optional executor service to parallelize this operation
|
* @param executor optional executor service to parallelize this operation
|
||||||
* @param errors ErrorReporter instance or null
|
* @param progressReporter Instance or null; gets called every time we move to new region of
|
||||||
|
* family dir and for each store file.
|
||||||
|
* @return Map keyed by StoreFile name with a value of the full Path.
|
||||||
|
* @throws IOException When scanning the directory fails.
|
||||||
|
* @deprecated Since 2.3.0. Will be removed in hbase4. Used {@link
|
||||||
|
* #getTableStoreFilePathMap(FileSystem, Path, PathFilter, ExecutorService, ProgressReporter)}
|
||||||
|
*/
|
||||||
|
@Deprecated
|
||||||
|
public static Map<String, Path> getTableStoreFilePathMap(final FileSystem fs,
|
||||||
|
final Path hbaseRootDir, PathFilter sfFilter, ExecutorService executor,
|
||||||
|
HbckErrorReporter progressReporter)
|
||||||
|
throws IOException, InterruptedException {
|
||||||
|
return getTableStoreFilePathMap(fs, hbaseRootDir, sfFilter, executor,
|
||||||
|
new ProgressReporter() {
|
||||||
|
@Override
|
||||||
|
public void progress(FileStatus status) {
|
||||||
|
// status is not used in this implementation.
|
||||||
|
progressReporter.progress();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Runs through the HBase rootdir and creates a reverse lookup map for
|
||||||
|
* table StoreFile names to the full Path.
|
||||||
|
* <br>
|
||||||
|
* Example...<br>
|
||||||
|
* Key = 3944417774205889744 <br>
|
||||||
|
* Value = hdfs://localhost:51169/user/userid/-ROOT-/70236052/info/3944417774205889744
|
||||||
|
*
|
||||||
|
* @param fs The file system to use.
|
||||||
|
* @param hbaseRootDir The root directory to scan.
|
||||||
|
* @param sfFilter optional path filter to apply to store files
|
||||||
|
* @param executor optional executor service to parallelize this operation
|
||||||
|
* @param progressReporter Instance or null; gets called every time we move to new region of
|
||||||
|
* family dir and for each store file.
|
||||||
* @return Map keyed by StoreFile name with a value of the full Path.
|
* @return Map keyed by StoreFile name with a value of the full Path.
|
||||||
* @throws IOException When scanning the directory fails.
|
* @throws IOException When scanning the directory fails.
|
||||||
* @throws InterruptedException
|
* @throws InterruptedException
|
||||||
*/
|
*/
|
||||||
public static Map<String, Path> getTableStoreFilePathMap(
|
public static Map<String, Path> getTableStoreFilePathMap(
|
||||||
final FileSystem fs, final Path hbaseRootDir, PathFilter sfFilter,
|
final FileSystem fs, final Path hbaseRootDir, PathFilter sfFilter,
|
||||||
ExecutorService executor, HbckErrorReporter errors)
|
ExecutorService executor, ProgressReporter progressReporter)
|
||||||
throws IOException, InterruptedException {
|
throws IOException, InterruptedException {
|
||||||
ConcurrentHashMap<String, Path> map = new ConcurrentHashMap<>(1024, 0.75f, 32);
|
ConcurrentHashMap<String, Path> map = new ConcurrentHashMap<>(1024, 0.75f, 32);
|
||||||
|
|
||||||
|
@ -1399,7 +1485,7 @@ public abstract class FSUtils extends CommonFSUtils {
|
||||||
// only include the directory paths to tables
|
// only include the directory paths to tables
|
||||||
for (Path tableDir : FSUtils.getTableDirs(fs, hbaseRootDir)) {
|
for (Path tableDir : FSUtils.getTableDirs(fs, hbaseRootDir)) {
|
||||||
getTableStoreFilePathMap(map, fs, hbaseRootDir,
|
getTableStoreFilePathMap(map, fs, hbaseRootDir,
|
||||||
FSUtils.getTableName(tableDir), sfFilter, executor, errors);
|
FSUtils.getTableName(tableDir), sfFilter, executor, progressReporter);
|
||||||
}
|
}
|
||||||
return map;
|
return map;
|
||||||
}
|
}
|
||||||
|
|
|
@ -150,7 +150,9 @@ import org.apache.hbase.thirdparty.com.google.common.collect.Sets;
|
||||||
* HBaseFsck (hbck) is a tool for checking and repairing region consistency and
|
* HBaseFsck (hbck) is a tool for checking and repairing region consistency and
|
||||||
* table integrity problems in a corrupted HBase. This tool was written for hbase-1.x. It does not
|
* table integrity problems in a corrupted HBase. This tool was written for hbase-1.x. It does not
|
||||||
* work with hbase-2.x; it can read state but is not allowed to change state; i.e. effect 'repair'.
|
* work with hbase-2.x; it can read state but is not allowed to change state; i.e. effect 'repair'.
|
||||||
* See hbck2 (HBASE-19121) for a hbck tool for hbase2.
|
* Even though it can 'read' state, given how so much has changed in how hbase1 and hbase2 operate,
|
||||||
|
* it will often misread. See hbck2 (HBASE-19121) for a hbck tool for hbase2. This class is
|
||||||
|
* deprecated.
|
||||||
*
|
*
|
||||||
* <p>
|
* <p>
|
||||||
* Region consistency checks verify that hbase:meta, region deployment on region
|
* Region consistency checks verify that hbase:meta, region deployment on region
|
||||||
|
@ -193,7 +195,9 @@ import org.apache.hbase.thirdparty.com.google.common.collect.Sets;
|
||||||
* If hbck is run from the command line, there are a handful of arguments that
|
* If hbck is run from the command line, there are a handful of arguments that
|
||||||
* can be used to limit the kinds of repairs hbck will do. See the code in
|
* can be used to limit the kinds of repairs hbck will do. See the code in
|
||||||
* {@link #printUsageAndExit()} for more details.
|
* {@link #printUsageAndExit()} for more details.
|
||||||
|
* @deprecated For removal in hbase-4.0.0. Use HBCK2 instead.
|
||||||
*/
|
*/
|
||||||
|
@Deprecated
|
||||||
@InterfaceAudience.LimitedPrivate(HBaseInterfaceAudience.TOOLS)
|
@InterfaceAudience.LimitedPrivate(HBaseInterfaceAudience.TOOLS)
|
||||||
@InterfaceStability.Evolving
|
@InterfaceStability.Evolving
|
||||||
public class HBaseFsck extends Configured implements Closeable {
|
public class HBaseFsck extends Configured implements Closeable {
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
/**
|
/*
|
||||||
* Licensed to the Apache Software Foundation (ASF) under one
|
* Licensed to the Apache Software Foundation (ASF) under one
|
||||||
* or more contributor license agreements. See the NOTICE file
|
* or more contributor license agreements. See the NOTICE file
|
||||||
* distributed with this work for additional information
|
* distributed with this work for additional information
|
||||||
|
@ -20,12 +20,15 @@ package org.apache.hadoop.hbase.util;
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
|
|
||||||
import org.apache.yetus.audience.InterfaceAudience;
|
import org.apache.yetus.audience.InterfaceAudience;
|
||||||
import org.apache.yetus.audience.InterfaceStability;
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Used by {@link HBaseFsck} reporting system.
|
||||||
|
* @deprecated Since 2.3.0. To be removed in hbase4. Use HBCK2 instead. Remove when
|
||||||
|
* {@link HBaseFsck} is removed.
|
||||||
|
*/
|
||||||
|
@Deprecated
|
||||||
@InterfaceAudience.Private
|
@InterfaceAudience.Private
|
||||||
@InterfaceStability.Evolving
|
|
||||||
public interface HbckErrorReporter {
|
public interface HbckErrorReporter {
|
||||||
|
|
||||||
enum ERROR_CODE {
|
enum ERROR_CODE {
|
||||||
UNKNOWN, NO_META_REGION, NULL_META_REGION, NO_VERSION_FILE, NOT_IN_META_HDFS, NOT_IN_META,
|
UNKNOWN, NO_META_REGION, NULL_META_REGION, NO_VERSION_FILE, NOT_IN_META_HDFS, NOT_IN_META,
|
||||||
NOT_IN_META_OR_DEPLOYED, NOT_IN_HDFS_OR_DEPLOYED, NOT_IN_HDFS, SERVER_DOES_NOT_MATCH_META,
|
NOT_IN_META_OR_DEPLOYED, NOT_IN_HDFS_OR_DEPLOYED, NOT_IN_HDFS, SERVER_DOES_NOT_MATCH_META,
|
||||||
|
|
Loading…
Reference in New Issue