RegionServer节点扩展后,需要将一部分原有Region迁移到新的RegionServer中,使各RegionServer负载均衡。
为了验证多了一个节点后的HBase的写性能提升,需要使每次put时List中的RowKey平均分配到现有的所有Region中,以达到使所有RegionServer并发处理的目的。
下面的代码是这种均匀RowKey构建的元代码:
import java.util.ArrayList;
import java.util.List;
public class externTest {
public static long TOTAL_NUMS = 145;
public static int REGION_NUMS = 24;
public static long EACH_PUT_NUMS = 48;
public static void buildString() {
int addition = 0;
String str = null;
List<String> list = new ArrayList<String>();
long curNum = 0;
long putNums = TOTAL_NUMS/EACH_PUT_NUMS; //通常等于总put数-1;
long loopsInOnePut = EACH_PUT_NUMS/REGION_NUMS; //一次put所需的内层循环数,也即是curNum自增数
// 处理循环内的
for (long k = 0; k < putNums; k++) {
for (long i = 0; i < loopsInOnePut; i++) {
for (int j = 0; j < REGION_NUMS; j+