HBASE-17488 WALEdit should be lazily instantiated (ChiaPing Tsai)
This commit is contained in:
parent
2ee3c73f76
commit
2285c57a35
|
@ -3234,11 +3234,12 @@ public class HRegion implements HeapSize, PropagatingConfigurationObserver, Regi
|
||||||
if (fromCP != null) {
|
if (fromCP != null) {
|
||||||
cellCount += fromCP.size();
|
cellCount += fromCP.size();
|
||||||
}
|
}
|
||||||
for (List<Cell> cells : familyMaps[i].values()) {
|
if (getEffectiveDurability(mutation.getDurability()) != Durability.SKIP_WAL) {
|
||||||
cellCount += cells.size();
|
for (List<Cell> cells : familyMaps[i].values()) {
|
||||||
|
cellCount += cells.size();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
walEdit = new WALEdit(cellCount, replay);
|
|
||||||
lock(this.updatesLock.readLock(), numReadyToWrite);
|
lock(this.updatesLock.readLock(), numReadyToWrite);
|
||||||
locked = true;
|
locked = true;
|
||||||
|
|
||||||
|
@ -3260,6 +3261,8 @@ public class HRegion implements HeapSize, PropagatingConfigurationObserver, Regi
|
||||||
if (cpMutations == null) {
|
if (cpMutations == null) {
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
Mutation mutation = batchOp.getMutation(i);
|
||||||
|
boolean skipWal = getEffectiveDurability(mutation.getDurability()) == Durability.SKIP_WAL;
|
||||||
// Else Coprocessor added more Mutations corresponding to the Mutation at this index.
|
// Else Coprocessor added more Mutations corresponding to the Mutation at this index.
|
||||||
for (int j = 0; j < cpMutations.length; j++) {
|
for (int j = 0; j < cpMutations.length; j++) {
|
||||||
Mutation cpMutation = cpMutations[j];
|
Mutation cpMutation = cpMutations[j];
|
||||||
|
@ -3272,12 +3275,22 @@ public class HRegion implements HeapSize, PropagatingConfigurationObserver, Regi
|
||||||
// Returned mutations from coprocessor correspond to the Mutation at index i. We can
|
// Returned mutations from coprocessor correspond to the Mutation at index i. We can
|
||||||
// directly add the cells from those mutations to the familyMaps of this mutation.
|
// directly add the cells from those mutations to the familyMaps of this mutation.
|
||||||
mergeFamilyMaps(familyMaps[i], cpFamilyMap); // will get added to the memstore later
|
mergeFamilyMaps(familyMaps[i], cpFamilyMap); // will get added to the memstore later
|
||||||
|
|
||||||
|
// The durability of returned mutation is replaced by the corresponding mutation.
|
||||||
|
// If the corresponding mutation contains the SKIP_WAL, we shouldn't count the
|
||||||
|
// cells of returned mutation.
|
||||||
|
if (!skipWal) {
|
||||||
|
for (List<Cell> cells : cpFamilyMap.values()) {
|
||||||
|
cellCount += cells.size();
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// STEP 3. Build WAL edit
|
// STEP 3. Build WAL edit
|
||||||
|
walEdit = new WALEdit(cellCount, replay);
|
||||||
Durability durability = Durability.USE_DEFAULT;
|
Durability durability = Durability.USE_DEFAULT;
|
||||||
for (int i = firstIndex; i < lastIndexExclusive; i++) {
|
for (int i = firstIndex; i < lastIndexExclusive; i++) {
|
||||||
// Skip puts that were determined to be invalid during preprocessing
|
// Skip puts that were determined to be invalid during preprocessing
|
||||||
|
|
Loading…
Reference in New Issue