HBASE-7596 Redundant FSTableDescriptor update
git-svn-id: https://svn.apache.org/repos/asf/hbase/trunk@1434979 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
parent
0df9c4fdf0
commit
d333239070
|
@ -58,15 +58,13 @@ public class TableAddFamilyHandler extends TableEventHandler {
|
||||||
if(cpHost != null){
|
if(cpHost != null){
|
||||||
cpHost.preAddColumnHandler(this.tableName, this.familyDesc);
|
cpHost.preAddColumnHandler(this.tableName, this.familyDesc);
|
||||||
}
|
}
|
||||||
// Update table descriptor in HDFS
|
// Update table descriptor
|
||||||
HTableDescriptor htd = this.masterServices.getMasterFileSystem()
|
this.masterServices.getMasterFileSystem().addColumn(tableName, familyDesc);
|
||||||
.addColumn(tableName, familyDesc);
|
|
||||||
// Update in-memory descriptor cache
|
|
||||||
this.masterServices.getTableDescriptors().add(htd);
|
|
||||||
if(cpHost != null){
|
if(cpHost != null){
|
||||||
cpHost.postAddColumnHandler(this.tableName, this.familyDesc);
|
cpHost.postAddColumnHandler(this.tableName, this.familyDesc);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public String toString() {
|
public String toString() {
|
||||||
String name = "UnknownServerName";
|
String name = "UnknownServerName";
|
||||||
|
|
|
@ -53,11 +53,8 @@ public class TableDeleteFamilyHandler extends TableEventHandler {
|
||||||
if (cpHost != null) {
|
if (cpHost != null) {
|
||||||
cpHost.preDeleteColumnHandler(this.tableName, this.familyName);
|
cpHost.preDeleteColumnHandler(this.tableName, this.familyName);
|
||||||
}
|
}
|
||||||
// Update table descriptor in HDFS
|
// Update table descriptor
|
||||||
HTableDescriptor htd =
|
|
||||||
this.masterServices.getMasterFileSystem().deleteColumn(tableName, familyName);
|
this.masterServices.getMasterFileSystem().deleteColumn(tableName, familyName);
|
||||||
// Update in-memory descriptor cache
|
|
||||||
this.masterServices.getTableDescriptors().add(htd);
|
|
||||||
// Remove the column family from the file system
|
// Remove the column family from the file system
|
||||||
MasterFileSystem mfs = this.masterServices.getMasterFileSystem();
|
MasterFileSystem mfs = this.masterServices.getMasterFileSystem();
|
||||||
for (HRegionInfo hri : hris) {
|
for (HRegionInfo hri : hris) {
|
||||||
|
|
|
@ -55,11 +55,8 @@ public class TableModifyFamilyHandler extends TableEventHandler {
|
||||||
if (cpHost != null) {
|
if (cpHost != null) {
|
||||||
cpHost.preModifyColumnHandler(this.tableName, this.familyDesc);
|
cpHost.preModifyColumnHandler(this.tableName, this.familyDesc);
|
||||||
}
|
}
|
||||||
// Update table descriptor in HDFS
|
// Update table descriptor
|
||||||
HTableDescriptor htd =
|
|
||||||
this.masterServices.getMasterFileSystem().modifyColumn(tableName, familyDesc);
|
this.masterServices.getMasterFileSystem().modifyColumn(tableName, familyDesc);
|
||||||
// Update in-memory descriptor cache
|
|
||||||
this.masterServices.getTableDescriptors().add(htd);
|
|
||||||
if (cpHost != null) {
|
if (cpHost != null) {
|
||||||
cpHost.postModifyColumnHandler(this.tableName, this.familyDesc);
|
cpHost.postModifyColumnHandler(this.tableName, this.familyDesc);
|
||||||
}
|
}
|
||||||
|
|
|
@ -0,0 +1,160 @@
|
||||||
|
/**
|
||||||
|
* Copyright 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 org.apache.hadoop.hbase.master.handler;
|
||||||
|
|
||||||
|
import static org.junit.Assert.assertEquals;
|
||||||
|
import static org.junit.Assert.assertFalse;
|
||||||
|
import static org.junit.Assert.assertTrue;
|
||||||
|
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.util.Set;
|
||||||
|
|
||||||
|
import org.apache.hadoop.fs.FileStatus;
|
||||||
|
import org.apache.hadoop.fs.FileSystem;
|
||||||
|
import org.apache.hadoop.fs.Path;
|
||||||
|
import org.apache.hadoop.hbase.HBaseTestingUtility;
|
||||||
|
import org.apache.hadoop.hbase.HColumnDescriptor;
|
||||||
|
import org.apache.hadoop.hbase.HTableDescriptor;
|
||||||
|
import org.apache.hadoop.hbase.LargeTests;
|
||||||
|
import org.apache.hadoop.hbase.client.HBaseAdmin;
|
||||||
|
import org.apache.hadoop.hbase.master.MasterFileSystem;
|
||||||
|
import org.apache.hadoop.hbase.util.Bytes;
|
||||||
|
import org.apache.hadoop.hbase.util.FSTableDescriptors;
|
||||||
|
import org.junit.AfterClass;
|
||||||
|
import org.junit.BeforeClass;
|
||||||
|
import org.junit.Test;
|
||||||
|
import org.junit.experimental.categories.Category;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Verify that the HTableDescriptor is updated after
|
||||||
|
* addColumn(), deleteColumn() and modifyTable() operations.
|
||||||
|
*/
|
||||||
|
@Category(LargeTests.class)
|
||||||
|
public class TestTableDescriptorModification {
|
||||||
|
|
||||||
|
private static final HBaseTestingUtility TEST_UTIL = new HBaseTestingUtility();
|
||||||
|
private static final byte[] TABLE_NAME = Bytes.toBytes("table");
|
||||||
|
private static final byte[] FAMILY_0 = Bytes.toBytes("cf0");
|
||||||
|
private static final byte[] FAMILY_1 = Bytes.toBytes("cf1");
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Start up a mini cluster and put a small table of empty regions into it.
|
||||||
|
*
|
||||||
|
* @throws Exception
|
||||||
|
*/
|
||||||
|
@BeforeClass
|
||||||
|
public static void beforeAllTests() throws Exception {
|
||||||
|
TEST_UTIL.startMiniCluster(1);
|
||||||
|
}
|
||||||
|
|
||||||
|
@AfterClass
|
||||||
|
public static void afterAllTests() throws Exception {
|
||||||
|
TEST_UTIL.shutdownMiniCluster();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testModifyTable() throws IOException {
|
||||||
|
HBaseAdmin admin = TEST_UTIL.getHBaseAdmin();
|
||||||
|
// Create a table with one family
|
||||||
|
HTableDescriptor baseHtd = new HTableDescriptor(TABLE_NAME);
|
||||||
|
baseHtd.addFamily(new HColumnDescriptor(FAMILY_0));
|
||||||
|
admin.createTable(baseHtd);
|
||||||
|
admin.disableTable(TABLE_NAME);
|
||||||
|
try {
|
||||||
|
// Verify the table descriptor
|
||||||
|
verifyTableDescriptor(TABLE_NAME, FAMILY_0);
|
||||||
|
|
||||||
|
// Modify the table adding another family and verify the descriptor
|
||||||
|
HTableDescriptor modifiedHtd = new HTableDescriptor(TABLE_NAME);
|
||||||
|
modifiedHtd.addFamily(new HColumnDescriptor(FAMILY_0));
|
||||||
|
modifiedHtd.addFamily(new HColumnDescriptor(FAMILY_1));
|
||||||
|
admin.modifyTable(TABLE_NAME, modifiedHtd);
|
||||||
|
verifyTableDescriptor(TABLE_NAME, FAMILY_0, FAMILY_1);
|
||||||
|
} finally {
|
||||||
|
admin.deleteTable(TABLE_NAME);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testAddColumn() throws IOException {
|
||||||
|
HBaseAdmin admin = TEST_UTIL.getHBaseAdmin();
|
||||||
|
// Create a table with two families
|
||||||
|
HTableDescriptor baseHtd = new HTableDescriptor(TABLE_NAME);
|
||||||
|
baseHtd.addFamily(new HColumnDescriptor(FAMILY_0));
|
||||||
|
admin.createTable(baseHtd);
|
||||||
|
admin.disableTable(TABLE_NAME);
|
||||||
|
try {
|
||||||
|
// Verify the table descriptor
|
||||||
|
verifyTableDescriptor(TABLE_NAME, FAMILY_0);
|
||||||
|
|
||||||
|
// Modify the table removing one family and verify the descriptor
|
||||||
|
admin.addColumn(TABLE_NAME, new HColumnDescriptor(FAMILY_1));
|
||||||
|
verifyTableDescriptor(TABLE_NAME, FAMILY_0, FAMILY_1);
|
||||||
|
} finally {
|
||||||
|
admin.deleteTable(TABLE_NAME);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testDeleteColumn() throws IOException {
|
||||||
|
HBaseAdmin admin = TEST_UTIL.getHBaseAdmin();
|
||||||
|
// Create a table with two families
|
||||||
|
HTableDescriptor baseHtd = new HTableDescriptor(TABLE_NAME);
|
||||||
|
baseHtd.addFamily(new HColumnDescriptor(FAMILY_0));
|
||||||
|
baseHtd.addFamily(new HColumnDescriptor(FAMILY_1));
|
||||||
|
admin.createTable(baseHtd);
|
||||||
|
admin.disableTable(TABLE_NAME);
|
||||||
|
try {
|
||||||
|
// Verify the table descriptor
|
||||||
|
verifyTableDescriptor(TABLE_NAME, FAMILY_0, FAMILY_1);
|
||||||
|
|
||||||
|
// Modify the table removing one family and verify the descriptor
|
||||||
|
admin.deleteColumn(TABLE_NAME, FAMILY_1);
|
||||||
|
verifyTableDescriptor(TABLE_NAME, FAMILY_0);
|
||||||
|
} finally {
|
||||||
|
admin.deleteTable(TABLE_NAME);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private void verifyTableDescriptor(final byte[] tableName, final byte[]... families)
|
||||||
|
throws IOException {
|
||||||
|
HBaseAdmin admin = TEST_UTIL.getHBaseAdmin();
|
||||||
|
|
||||||
|
// Verify descriptor from master
|
||||||
|
HTableDescriptor htd = admin.getTableDescriptor(tableName);
|
||||||
|
verifyTableDescriptor(htd, tableName, families);
|
||||||
|
|
||||||
|
// Verify descriptor from HDFS
|
||||||
|
MasterFileSystem mfs = TEST_UTIL.getMiniHBaseCluster().getMaster().getMasterFileSystem();
|
||||||
|
Path tableDir = HTableDescriptor.getTableDir(mfs.getRootDir(), tableName);
|
||||||
|
htd = FSTableDescriptors.getTableDescriptor(mfs.getFileSystem(), tableDir);
|
||||||
|
verifyTableDescriptor(htd, tableName, families);
|
||||||
|
}
|
||||||
|
|
||||||
|
private void verifyTableDescriptor(final HTableDescriptor htd,
|
||||||
|
final byte[] tableName, final byte[]... families) {
|
||||||
|
Set<byte[]> htdFamilies = htd.getFamiliesKeys();
|
||||||
|
assertTrue(Bytes.equals(tableName, htd.getName()));
|
||||||
|
assertEquals(families.length, htdFamilies.size());
|
||||||
|
for (byte[] familyName: families) {
|
||||||
|
assertTrue("Expected family " + Bytes.toString(familyName), htdFamilies.contains(familyName));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in New Issue