diff --git a/hbase-server/src/main/java/org/apache/hadoop/hbase/tool/BulkLoadHFilesTool.java b/hbase-server/src/main/java/org/apache/hadoop/hbase/tool/BulkLoadHFilesTool.java index e8b701b7ae3c..6c62a3d6ea1d 100644 --- a/hbase-server/src/main/java/org/apache/hadoop/hbase/tool/BulkLoadHFilesTool.java +++ b/hbase-server/src/main/java/org/apache/hadoop/hbase/tool/BulkLoadHFilesTool.java @@ -129,14 +129,14 @@ public class BulkLoadHFilesTool extends Configured implements BulkLoadHFiles, To // above. It is invalid family name. static final String TMP_DIR = ".tmp"; - private final int maxFilesPerRegionPerFamily; - private final boolean assignSeqIds; + private int maxFilesPerRegionPerFamily; + private boolean assignSeqIds; private boolean bulkLoadByFamily; // Source delegation token - private final FsDelegationToken fsDelegationToken; - private final UserProvider userProvider; - private final int nrThreads; + private FsDelegationToken fsDelegationToken; + private UserProvider userProvider; + private int nrThreads; private final AtomicInteger numRetries = new AtomicInteger(0); private String bulkToken; @@ -146,6 +146,11 @@ public class BulkLoadHFilesTool extends Configured implements BulkLoadHFiles, To public BulkLoadHFilesTool(Configuration conf) { // make a copy, just to be sure we're not overriding someone else's config super(new Configuration(conf)); + initialize(); + } + + public void initialize() { + Configuration conf = getConf(); // disable blockcache for tool invocation, see HBASE-10500 conf.setFloat(HConstants.HFILE_BLOCK_CACHE_SIZE_KEY, 0); userProvider = UserProvider.instantiate(conf); @@ -1073,6 +1078,8 @@ public int run(String[] args) throws Exception { usage(); return -1; } + // Re-initialize to apply -D options from the command line parameters + initialize(); Path dirPath = new Path(args[0]); TableName tableName = TableName.valueOf(args[1]); if (args.length == 2) {