5。hbase高级部分:compact/split/balance及其它维护原理--the flow of creating table

1.principle

 

 

 

 

2.note

-as is hbase-0.94.2,the table .meta. is not splittable,therefore,there is only ONE region in table -root-.

that is if you try to split the root you will do it w/o errors but this is meanlessfull and noneffective,as ONLY one row in root table.

 

3.flow at master side

Preconditinos:

-1.verify the meta table is online

-2.check the table whether exists or not(fun in CreateTableHandler#constructor)

-3 set a znode '/hbase/table/new-table' with state 'enabling'(differe from last step )

Real opers:

-4 create tableinfo.xxx file

-5 create new regions belong this table

-6 add them to meta for tracking down

-7 assign regions to respective rs (see [1] assign algo )

-8 enable the table state in with 'enabled'

 

[1] assign algo(round robin)

/**
   * Generates a bulk assignment plan to be used on cluster startup using a
   * simple round-robin assignment.
   * <p>
   * Takes a list of all the regions and all the servers in the cluster and
   * returns a map of each server to the regions that it should be assigned.
   * <p>
   * Currently implemented as a round-robin assignment.  Same invariant as
   * load balancing, all servers holding floor(avg) or ceiling(avg).
   *
   * TODO: Use block locations from HDFS to place regions with their blocks
   *
   * @param regions all regions
   * @param servers all servers
   * @return map of server to the regions it should take, or null if no
   *         assignment is possible (ie. no regions or no servers)
   */
  public Map<ServerName, List<HRegionInfo>> roundRobinAssignment(
      List<HRegionInfo> regions, List<ServerName> servers) {
    if (regions.isEmpty() || servers.isEmpty()) {
      return null;
    }
    Map<ServerName, List<HRegionInfo>> assignments =
      new TreeMap<ServerName,List<HRegionInfo>>();
    int numRegions = regions.size();
    int numServers = servers.size();
    int max = (int)Math.ceil((float)numRegions/numServers); //smallest that bigger than or equals to x
    int serverIdx = 0;
    if (numServers > 1) {
      serverIdx = RANDOM.nextInt(numServers);//used for randomly select a first rs
    }
    int regionIdx = 0;
    for (int j = 0; j < numServers; j++) {	//iterate all regions then assign by index % servers will be more simiple
      ServerName server = servers.get((j + serverIdx) % numServers);
      List<HRegionInfo> serverRegions = new ArrayList<HRegionInfo>(max); //max:the only optimization of this algorithm
      for (int i=regionIdx; i<numRegions; i += numServers) {
        serverRegions.add(regions.get(i % numRegions));
      }
      assignments.put(server, serverRegions);
      regionIdx++;
    }
    return assignments;
  }

=============

blow are the logs from master when creating table:

2014-07-18 16:39:14,334 DEBUG [IPC Server handler 18 on 60000] ClientScanner.java:90 Creating scanner over .META. starting at key 't1,,'
2014-07-18 16:39:14,334 DEBUG [IPC Server handler 18 on 60000] ClientScanner.java:198 Advancing internal scanner to startKey at 't1,,'
2014-07-18 16:39:14,379 INFO [MASTER_TABLE_OPERATIONS-cluster-03,60000,1402881344300-0] CreateTableHandler.java:125 Attemping to create the table t1
2014-07-18 16:39:14,425 INFO [MASTER_TABLE_OPERATIONS-cluster-03,60000,1402881344300-0] HRegion.java:3685 creating HRegion t1 HTD == {NAME => 't1', FAMILIES => [{NAME => 'f1', DATA_BLOCK_ENCODING => 'NONE', BLOOMFILTER => 'NONE', REPLICATION_SCOPE => '0', VERSIONS => '5', COMPRESSION => 'NONE', MIN_VERSIONS => '0', TTL => '2147483647', KEEP_DELETED_CELLS => 'false', BLOCKSIZE => '65536', IN_MEMORY => 'false', ENCODE_ON_DISK => 'true', BLOCKCACHE => 'true'}]} RootDir = hdfs://host03:54310/hbase Table name == t1
2014-07-18 16:39:14,430 INFO [MASTER_TABLE_OPERATIONS-cluster-03,60000,1402881344300-0] HLog.java:455 FileSystem doesn't support getDefaultBlockSize
2014-07-18 16:39:14,433 INFO [MASTER_TABLE_OPERATIONS-cluster-03,60000,1402881344300-0] HLog.java:426 HLog configuration: blocksize=128 MB, rollsize=121.6 MB, enabled=true, optionallogflushinternal=1000ms
2014-07-18 16:39:14,446 DEBUG [MASTER_TABLE_OPERATIONS-cluster-03,60000,1402881344300-0] SequenceFileLogWriter.java:193 using new createWriter -- HADOOP-6840
2014-07-18 16:39:14,447 DEBUG [MASTER_TABLE_OPERATIONS-cluster-03,60000,1402881344300-0] SequenceFileLogWriter.java:204 Path=hdfs://host03:54310/hbase/t1/7846f70ff612136e14a1c48283deb102/.logs/hlog.1405672754433, syncFs=true, hflush=false, compression=false
2014-07-18 16:39:14,447 INFO [MASTER_TABLE_OPERATIONS-cluster-03,60000,1402881344300-0] HLog.java:650  for /hbase/t1/7846f70ff612136e14a1c48283deb102/.logs/hlog.1405672754433
2014-07-18 16:39:14,448 INFO [MASTER_TABLE_OPERATIONS-cluster-03,60000,1402881344300-0] HLog.java:498 Using getNumCurrentReplicas--HDFS-826
2014-07-18 16:39:14,456 INFO [MASTER_TABLE_OPERATIONS-cluster-03,60000,1402881344300-0] HRegion.java:425 Setting up tabledescriptor config now ...
2014-07-18 16:39:14,464 DEBUG [MASTER_TABLE_OPERATIONS-cluster-03,60000,1402881344300-0] HRegion.java:419 Instantiated t1,,1405672754325.7846f70ff612136e14a1c48283deb102.
2014-07-18 16:39:14,465 DEBUG [MASTER_TABLE_OPERATIONS-cluster-03,60000,1402881344300-0] FSUtils.java:154 Creating file:hdfs://host03:54310/hbase/t1/7846f70ff612136e14a1c48283deb102/.tmp/.regioninfowith permission:rwxrwxrwx
2014-07-18 16:39:14,484 INFO [StoreOpenerThread-t1,,1405672754325.7846f70ff612136e14a1c48283deb102.-1] Store.java:226 time to purge deletes set to 0ms in store null
2014-07-18 16:39:14,508 INFO [StoreOpenerThread-t1,,1405672754325.7846f70ff612136e14a1c48283deb102.-1] ChecksumType.java:73 org.apache.hadoop.util.PureJavaCrc32 not available.
2014-07-18 16:39:14,508 INFO [StoreOpenerThread-t1,,1405672754325.7846f70ff612136e14a1c48283deb102.-1] ChecksumType.java:80 Checksum can use java.util.zip.CRC32
2014-07-18 16:39:14,508 INFO [StoreOpenerThread-t1,,1405672754325.7846f70ff612136e14a1c48283deb102.-1] ChecksumType.java:116 org.apache.hadoop.util.PureJavaCrc32C not available. 
2014-07-18 16:39:14,523 INFO [MASTER_TABLE_OPERATIONS-cluster-03,60000,1402881344300-0] HRegion.java:577 Onlined t1,,1405672754325.7846f70ff612136e14a1c48283deb102.; next sequenceid=1
2014-07-18 16:39:14,530 INFO [MASTER_TABLE_OPERATIONS-cluster-03,60000,1402881344300-0] MetaEditor.java:163 Added 1 regions in META
2014-07-18 16:39:14,530 DEBUG [MASTER_TABLE_OPERATIONS-cluster-03,60000,1402881344300-0] HRegion.java:870 Closing t1,,1405672754325.7846f70ff612136e14a1c48283deb102.: disabling compactions & flushes
2014-07-18 16:39:14,531 DEBUG [MASTER_TABLE_OPERATIONS-cluster-03,60000,1402881344300-0] HRegion.java:900 Updates disabled for region t1,,1405672754325.7846f70ff612136e14a1c48283deb102.
2014-07-18 16:39:14,532 DEBUG [StoreCloserThread-t1,,1405672754325.7846f70ff612136e14a1c48283deb102.-1] Store.java:639 closed f1
2014-07-18 16:39:14,533 INFO [MASTER_TABLE_OPERATIONS-cluster-03,60000,1402881344300-0] HRegion.java:948 Closed t1,,1405672754325.7846f70ff612136e14a1c48283deb102.
2014-07-18 16:39:14,534 INFO [MASTER_TABLE_OPERATIONS-cluster-03,60000,1402881344300-0.logSyncer] HLog.java:1240 MASTER_TABLE_OPERATIONS-cluster-03,60000,1402881344300-0.logSyncer exiting
2014-07-18 16:39:14,534 DEBUG [MASTER_TABLE_OPERATIONS-cluster-03,60000,1402881344300-0] HLog.java:1002 closing hlog writer in hdfs://host03:54310/hbase/t1/7846f70ff612136e14a1c48283deb102/.logs
2014-07-18 16:39:14,545 DEBUG [MASTER_TABLE_OPERATIONS-cluster-03,60000,1402881344300-0] HLog.java:970 Moved 1 log files to /hbase/t1/7846f70ff612136e14a1c48283deb102/.oldlogs
2014-07-18 16:39:14,546 INFO [MASTER_TABLE_OPERATIONS-cluster-03,60000,1402881344300-0] AssignmentManager.java:2258 Bulk assigning 1 region(s) round-robin across 14 server(s)
2014-07-18 16:39:14,548 DEBUG [cluster-03,60000,1402881344300-StartupBulkAssigner-0] AssignmentManager.java:1377 Bulk assigning 1 region(s) to cluster-05,60020,1405411368652
2014-07-18 16:39:14,550 DEBUG [cluster-03,60000,1402881344300-StartupBulkAssigner-0] ZKAssign.java:169 master:60000-0x545ef23b01a0ad5-0x545ef23b01a0ad5-0x545ef23b01a0ad5 Async create of unassigned node for 7846f70ff612136e14a1c48283deb102 with OFFLINE state
2014-07-18 16:39:14,550 DEBUG [MASTER_TABLE_OPERATIONS-cluster-03,60000,1402881344300-0] AssignmentManager.java:2393 Timeout-on-RIT=1000
2014-07-18 16:39:14,553 DEBUG [main-EventThread] AssignmentManager.java:1483 rs=t1,,1405672754325.7846f70ff612136e14a1c48283deb102. state=OFFLINE, ts=1405672754550, server=null, server=cluster-05,60020,1405411368652
2014-07-18 16:39:14,554 DEBUG [main-EventThread] AssignmentManager.java:1514 rs=t1,,1405672754325.7846f70ff612136e14a1c48283deb102. state=OFFLINE, ts=1405672754550, server=null
2014-07-18 16:39:14,554 INFO [cluster-03,60000,1402881344300-StartupBulkAssigner-0] AssignmentManager.java:1410 cluster-05,60020,1405411368652 unassigned znodes=1 of total=1
2014-07-18 16:39:14,554 DEBUG [cluster-03,60000,1402881344300-StartupBulkAssigner-0] ServerManager.java:549 New connection to cluster-05,60020,1405411368652
2014-07-18 16:39:14,560 DEBUG [cluster-03,60000,1402881344300-StartupBulkAssigner-0] AssignmentManager.java:1454 Bulk assigning done for cluster-05,60020,1405411368652
2014-07-18 16:39:14,564 DEBUG [main-EventThread] AssignmentManager.java:702 Handling transition=RS_ZK_REGION_OPENING, server=cluster-05,60020,1405411368652, region=7846f70ff612136e14a1c48283deb102
2014-07-18 16:39:14,633 DEBUG [main-EventThread] AssignmentManager.java:702 Handling transition=RS_ZK_REGION_OPENING, server=cluster-05,60020,1405411368652, region=7846f70ff612136e14a1c48283deb102
2014-07-18 16:39:14,639 DEBUG [main-EventThread] AssignmentManager.java:702 Handling transition=RS_ZK_REGION_OPENED, server=cluster-05,60020,1405411368652, region=7846f70ff612136e14a1c48283deb102
2014-07-18 16:39:14,639 DEBUG [MASTER_OPEN_REGION-cluster-03,60000,1402881344300-3] OpenedRegionHandler.java:147 Handling OPENED event for t1,,1405672754325.7846f70ff612136e14a1c48283deb102. from cluster-05,60020,1405411368652; deleting unassigned node
2014-07-18 16:39:14,639 DEBUG [MASTER_OPEN_REGION-cluster-03,60000,1402881344300-3] ZKAssign.java:483 master:60000-0x545ef23b01a0ad5-0x545ef23b01a0ad5-0x545ef23b01a0ad5 Deleting existing unassigned node for 7846f70ff612136e14a1c48283deb102 that is in expected state RS_ZK_REGION_OPENED
2014-07-18 16:39:14,642 DEBUG [main-EventThread] AssignmentManager.java:1136 The znode of region t1,,1405672754325.7846f70ff612136e14a1c48283deb102. has been deleted.
2014-07-18 16:39:14,642 DEBUG [MASTER_OPEN_REGION-cluster-03,60000,1402881344300-3] ZKAssign.java:512 master:60000-0x545ef23b01a0ad5-0x545ef23b01a0ad5-0x545ef23b01a0ad5 Successfully deleted unassigned node for region 7846f70ff612136e14a1c48283deb102 in expected state RS_ZK_REGION_OPENED
2014-07-18 16:39:14,642 INFO [main-EventThread] AssignmentManager.java:1148 The master has opened the region t1,,1405672754325.7846f70ff612136e14a1c48283deb102. that was online on cluster-05,60020,1405411368652
2014-07-18 16:39:14,643 INFO [MASTER_TABLE_OPERATIONS-cluster-03,60000,1402881344300-0] AssignmentManager.java:2263 Bulk assigning done
2014-07-18 16:40:03,986 DEBUG [326031821@qtp-47973429-17] MetaScanner.java:200 Scanning .META. starting at row=t1,,00000000000000 for max=10 rows using org.apache.hadoop.hbase.client.HConnectionManager$HConnectionImplementation@679b2faf
2014-07-18 16:40:03,989 DEBUG [326031821@qtp-47973429-17] HConnectionManager.java:1241 Cached location for t1,,1405672754325.7846f70ff612136e14a1c48283deb102. is cluster-05:60020
2014-07-18 16:40:03,993 INFO [326031821@qtp-47973429-17] ZooKeeper.java:433 Initiating client connection, connectString=host06:2181,host05:2181,host02:2181,host03:2181,host07:2181 sessionTimeout=180000 watcher=catalogtracker-on-org.apache.hadoop.hbase.client.HConnectionManager$HConnectionImplementation@679b2faf
2014-07-18 16:40:03,993 INFO [326031821@qtp-47973429-17-SendThread()] ClientCnxn.java:933 Opening socket connection to server /192.168.100.107:2181
2014-07-18 16:40:03,994 INFO [326031821@qtp-47973429-17] RecoverableZooKeeper.java:98 The identifier of this process is 18174@cluster08
2014-07-18 16:40:03,994 DEBUG [326031821@qtp-47973429-17] CatalogTracker.java:236 Starting catalog tracker org.apache.hadoop.hbase.catalog.CatalogTracker@75dcb817
2014-07-18 16:40:03,994 WARN [326031821@qtp-47973429-17-SendThread(cluster-02:2181)] ZooKeeperSaslClient.java:123 SecurityException: java.lang.SecurityException: Unable to locate a login configuration occurred when trying to find JAAS configuration.
2014-07-18 16:40:03,994 INFO [326031821@qtp-47973429-17-SendThread(cluster-02:2181)] ZooKeeperSaslClient.java:125 Client will not SASL-authenticate because the default JAAS configuration section 'Client' could not be found. If you are not using SASL, you may ignore this. On the other hand, if you expected SASL to work, please fix your JAAS configuration.
2014-07-18 16:40:03,995 INFO [326031821@qtp-47973429-17-SendThread(cluster-02:2181)] ClientCnxn.java:846 Socket connection established to cluster-02/192.168.100.107:2181, initiating session
2014-07-18 16:40:03,998 INFO [326031821@qtp-47973429-17-SendThread(cluster-02:2181)] ClientCnxn.java:1175 Session establishment complete on server cluster-02/192.168.100.107:2181, sessionid = 0x245ef23b5f4027c, negotiated timeout = 40000
2014-07-18 16:40:04,000 DEBUG [326031821@qtp-47973429-17] MetaScanner.java:200 Scanning .META. starting at row= for max=2147483647 rows using org.apache.hadoop.hbase.client.HConnectionManager$HConnectionImplementation@679b2faf
2014-07-18 16:40:04,094 DEBUG [326031821@qtp-47973429-17] ClientScanner.java:90 Creating scanner over .META. starting at key 't1,,'
2014-07-18 16:40:04,094 DEBUG [326031821@qtp-47973429-17] ClientScanner.java:198 Advancing internal scanner to startKey at 't1,,'
2014-07-18 16:40:04,128 DEBUG [326031821@qtp-47973429-17] ClientScanner.java:90 Creating scanner over .META. starting at key 't1,,'
2014-07-18 16:40:04,128 DEBUG [326031821@qtp-47973429-17] ClientScanner.java:198 Advancing internal scanner to startKey at 't1,,'
2014-07-18 16:40:04,163 DEBUG [326031821@qtp-47973429-17] CatalogTracker.java:253 Stopping catalog tracker org.apache.hadoop.hbase.catalog.CatalogTracker@75dcb817
2014-07-18 16:40:04,165 INFO [326031821@qtp-47973429-17] ZooKeeper.java:679 Session: 0x245ef23b5f4027c closed
2014-07-18 16:40:04,165 INFO [326031821@qtp-47973429-17-EventThread] ClientCnxn.java:511 EventThread shut down
2014-07-18 16:40:04,166 DEBUG [326031821@qtp-47973429-17] MetaScanner.java:200 Scanning .META. starting at row=t1,,00000000000000 for max=2147483647 rows using org.apache.hadoop.hbase.client.HConnectionManager$HConnectionImplementation@679b2faf

 

and logs from rs:

2014-07-18 16:39:15,755 INFO [PRI IPC Server handler 4 on 60020] HRegionServer.java:2801 Received request to open 1 region(s)
2014-07-18 16:39:15,756 INFO [PRI IPC Server handler 4 on 60020] HRegionServer.java:2755 Received request to open region: t1,,1405672754325.7846f70ff612136e14a1c48283deb102.
2014-07-18 16:39:15,760 DEBUG [RS_OPEN_REGION-cluster-05,60020,1405411368652-0] ZKAssign.java:757 regionserver:60020-0x145ef23b27d0d3b Attempting to transition node 7846f70ff612136e14a1c48283deb102 from M_ZK_REGION_OFFLINE to RS_ZK_REGION_OPENING
2014-07-18 16:39:15,763 DEBUG [RS_OPEN_REGION-cluster-05,60020,1405411368652-0] ZKAssign.java:820 regionserver:60020-0x145ef23b27d0d3b Successfully transitioned node 7846f70ff612136e14a1c48283deb102 from M_ZK_REGION_OFFLINE to RS_ZK_REGION_OPENING
2014-07-18 16:39:15,763 DEBUG [RS_OPEN_REGION-cluster-05,60020,1405411368652-0] HRegion.java:3745 Opening region: {NAME => 't1,,1405672754325.7846f70ff612136e14a1c48283deb102.', STARTKEY => '', ENDKEY => '', ENCODED => 7846f70ff612136e14a1c48283deb102,}
2014-07-18 16:39:15,763 INFO [RS_OPEN_REGION-cluster-05,60020,1405411368652-0] HRegion.java:425 Setting up tabledescriptor config now ...
2014-07-18 16:39:15,764 DEBUG [RS_OPEN_REGION-cluster-05,60020,1405411368652-0] HRegion.java:419 Instantiated t1,,1405672754325.7846f70ff612136e14a1c48283deb102.
2014-07-18 16:39:15,826 INFO [StoreOpenerThread-t1,,1405672754325.7846f70ff612136e14a1c48283deb102.-1] Store.java:226 time to purge deletes set to 0ms in store null
2014-07-18 16:39:15,828 INFO [RS_OPEN_REGION-cluster-05,60020,1405411368652-0] HRegion.java:577 Onlined t1,,1405672754325.7846f70ff612136e14a1c48283deb102.; next sequenceid=1
2014-07-18 16:39:15,829 DEBUG [RS_OPEN_REGION-cluster-05,60020,1405411368652-0] ZKAssign.java:757 regionserver:60020-0x145ef23b27d0d3b Attempting to transition node 7846f70ff612136e14a1c48283deb102 from RS_ZK_REGION_OPENING to RS_ZK_REGION_OPENING
2014-07-18 16:39:15,832 DEBUG [RS_OPEN_REGION-cluster-05,60020,1405411368652-0] ZKAssign.java:820 regionserver:60020-0x145ef23b27d0d3b Successfully transitioned node 7846f70ff612136e14a1c48283deb102 from RS_ZK_REGION_OPENING to RS_ZK_REGION_OPENING
2014-07-18 16:39:15,832 INFO [PostOpenDeployTasks:7846f70ff612136e14a1c48283deb102] HRegionServer.java:1651 Post open deploy tasks for region=t1,,1405672754325.7846f70ff612136e14a1c48283deb102., daughter=false
2014-07-18 16:39:15,835 INFO [PostOpenDeployTasks:7846f70ff612136e14a1c48283deb102] MetaEditor.java:261 Updated row t1,,1405672754325.7846f70ff612136e14a1c48283deb102. with server=cluster-05,60020,1405411368652
2014-07-18 16:39:15,835 INFO [PostOpenDeployTasks:7846f70ff612136e14a1c48283deb102] HRegionServer.java:1676 Done with post open deploy task for region=t1,,1405672754325.7846f70ff612136e14a1c48283deb102., daughter=false
2014-07-18 16:39:15,835 DEBUG [RS_OPEN_REGION-cluster-05,60020,1405411368652-0] ZKAssign.java:757 regionserver:60020-0x145ef23b27d0d3b Attempting to transition node 7846f70ff612136e14a1c48283deb102 from RS_ZK_REGION_OPENING to RS_ZK_REGION_OPENED
2014-07-18 16:39:15,838 DEBUG [RS_OPEN_REGION-cluster-05,60020,1405411368652-0] ZKAssign.java:820 regionserver:60020-0x145ef23b27d0d3b Successfully transitioned node 7846f70ff612136e14a1c48283deb102 from RS_ZK_REGION_OPENING to RS_ZK_REGION_OPENED
2014-07-18 16:39:15,838 DEBUG [RS_OPEN_REGION-cluster-05,60020,1405411368652-0] OpenRegionHandler.java:284 region transitioned to opened in zookeeper: {NAME => 't1,,1405672754325.7846f70ff612136e14a1c48283deb102.', STARTKEY => '', ENDKEY => '', ENCODED => 7846f70ff612136e14a1c48283deb102,}, server: cluster-05,60020,1405411368652
2014-07-18 16:39:15,838 DEBUG [RS_OPEN_REGION-cluster-05,60020,1405411368652-0] OpenRegionHandler.java:140 Opened t1,,1405672754325.7846f70ff612136e14a1c48283deb102. on server:cluster-05,60020,1405411368652

 

 

 

ref:
hbase高级部分:compact/split/balance及其它维护原理-delete table 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值