Class WALEdit
- All Implemented Interfaces:
- HeapSize
 This class is LimitedPrivate for CPs to read-only. The add(org.apache.hadoop.hbase.Cell, byte[]) methods are classified as
 private methods, not for use by CPs.
 
 A particular WALEdit 'type' is the 'meta' type used to mark key operational events in the WAL
 such as compaction, flush, or region open. These meta types do not traverse hbase memstores. They
 are edits made by the hbase system rather than edit data submitted by clients. They only show in
 the WAL. These 'Meta' types have not been formally specified (or made into an explicit class
 type). They evolved organically. HBASE-8457 suggests codifying a WALEdit 'type' by adding a type
 field to WALEdit that gets serialized into the WAL. TODO. Would have to work on the
 consumption-side. Reading WALs on replay we seem to consume a Cell-at-a-time rather than by
 WALEdit. We are already in the below going out of our way to figure particular types -- e.g. if a
 compaction, replay, or close meta Marker -- during normal processing so would make sense to do
 this. Current system is an awkward marking of Cell columnfamily as METAFAMILY and then
 setting qualifier based off meta edit type. For replay-time where we read Cell-at-a-time, there
 are utility methods below for figuring meta type. See also
 createBulkLoadEvent(RegionInfo, WALProtos.BulkLoadDescriptor), etc., for where we create
 meta WALEdit instances.
 
 WALEdit will accumulate a Set of all column family names referenced by the Cells
 add(Cell)'d. This is an optimization. Usually when loading a WALEdit, we have the column
 family name to-hand.. just shove it into the WALEdit if available. Doing this, we can save on a
 parse of each Cell to figure column family down the line when we go to add the WALEdit to the WAL
 file. See the hand-off in FSWALEntry Constructor.
- See Also:
- 
Field SummaryFieldsModifier and TypeFieldDescriptionstatic final byte[]static final byte[]Deprecated.Since 2.3.0.private Set<byte[]>All the Cell families incells.static final byte[]Deprecated.Since 2.3.0.static final byte[]static final byte[]Deprecated.Since 2.3.0.static final byte[]Deprecated.Since 2.3.0.private static final byte[]We use this define figuring if we are carrying a close event.private static final byte[]private static final Stringprivate static final StringQualifier for region event meta 'Marker' WALEdits start with theREGION_EVENT_PREFIXprefix ('HBASE::REGION_EVENT::').private final booleanstatic final byte[]PeriodicallyReplicationMarkerChorewill create marker edits with family asMETAFAMILYandREPLICATION_MARKERas qualifier and an empty value.
- 
Constructor SummaryConstructors
- 
Method SummaryModifier and TypeMethodDescriptionvoidAppend the given map of family->edits to a WALEdit data structure.private WALEditprivate voidaddFamily(byte[] family) static WALEditcreateBulkLoadEvent(RegionInfo hri, org.apache.hadoop.hbase.shaded.protobuf.generated.WALProtos.BulkLoadDescriptor bulkLoadDescriptor) Create a bulk loader WALEditstatic WALEditcreateCompaction(RegionInfo hri, org.apache.hadoop.hbase.shaded.protobuf.generated.WALProtos.CompactionDescriptor c) Returns A Marker WALEdit that hascserialized as its valuestatic WALEditcreateFlushWALEdit(RegionInfo hri, org.apache.hadoop.hbase.shaded.protobuf.generated.WALProtos.FlushDescriptor f) static byte[]createRegionEventDescriptorQualifier(org.apache.hadoop.hbase.shaded.protobuf.generated.WALProtos.RegionEventDescriptor.EventType t) static WALEditcreateRegionEventWALEdit(byte[] rowForRegion, org.apache.hadoop.hbase.shaded.protobuf.generated.WALProtos.RegionEventDescriptor regionEventDesc) static WALEditcreateRegionEventWALEdit(RegionInfo hri, org.apache.hadoop.hbase.shaded.protobuf.generated.WALProtos.RegionEventDescriptor regionEventDesc) static WALEditcreateReplicationMarkerEdit(byte[] rowKey, long timestamp) Creates a replication tracker edit withMETAFAMILYfamily andREPLICATION_MARKERqualifier and has null value.longstatic org.apache.hadoop.hbase.shaded.protobuf.generated.WALProtos.BulkLoadDescriptorgetBulkLoadDescriptor(Cell cell) Deserialized and returns a BulkLoadDescriptor from the passed in CellgetCells()static org.apache.hadoop.hbase.shaded.protobuf.generated.WALProtos.CompactionDescriptorgetCompaction(Cell kv) Deserialized and returns a CompactionDescriptor is the KeyValue contains one.Set<byte[]>For use by FSWALEntry ONLY.static org.apache.hadoop.hbase.shaded.protobuf.generated.WALProtos.FlushDescriptorgetFlushDescriptor(Cell cell) private Set<byte[]>static org.apache.hadoop.hbase.shaded.protobuf.generated.WALProtos.RegionEventDescriptorgetRegionEventDescriptor(Cell cell) static byte[]longheapSize()Return the approximate 'exclusive deep size' of implementing object.static booleanisCompactionMarker(Cell cell) Returns true if the given cell is a serializedWALProtos.CompactionDescriptorbooleanisEmpty()booleanstatic booleanisMetaEditFamily(byte[] f) Deprecated.Since 2.3.0.static booleanisMetaEditFamily(Cell cell) Replaying WALs can read Cell-at-a-time so need this method in those cases.booleanPublic so can be accessed from regionserver.wal package.booleanisReplay()static booleanChecks whether this edit is a replication marker edit.intreadFromCells(Codec.Decoder cellDecoder, int expectedCount) Reads WALEdit from cells.voidThis is not thread safe.intsize()toString()
- 
Field Details- 
METAFAMILY
- 
METAROWDeprecated.Since 2.3.0. Not used.
- 
COMPACTIONDeprecated.Since 2.3.0. Make it protected, internal-use only. UseisCompactionMarker(Cell)
- 
FLUSHDeprecated.Since 2.3.0. Make it protected, internal-use only.
- 
REGION_EVENT_STRQualifier for region event meta 'Marker' WALEdits start with theREGION_EVENT_PREFIXprefix ('HBASE::REGION_EVENT::'). After the prefix, we note the type of the event which we get from the RegionEventDescriptor protobuf instance type (A RegionEventDescriptor protobuf instance is written as the meta Marker Cell value). Adding a type suffix means we do not have to deserialize the protobuf to figure out what type of event this is.. .just read the qualifier suffix. For example, a close region event descriptor will have a qualifier of HBASE::REGION_EVENT::REGION_CLOSE. See WAL.proto and the EventType in RegionEventDescriptor protos for all possible event types.- See Also:
 
- 
REGION_EVENT_PREFIX_STR- See Also:
 
- 
REGION_EVENT_PREFIX
- 
REGION_EVENTDeprecated.Since 2.3.0. Remove. Not for external use. Not used.
- 
REGION_EVENT_CLOSEWe use this define figuring if we are carrying a close event.
- 
BULK_LOAD
- 
REPLICATION_MARKERPeriodicallyReplicationMarkerChorewill create marker edits with family asMETAFAMILYandREPLICATION_MARKERas qualifier and an empty value. org.apache.hadoop.hbase.replication.regionserver.ReplicationSourceWALReader will populate the Replication Marker edit with region_server_name, wal_name and wal_offset encoded inWALProtos.ReplicationMarkerDescriptorobject.Replicationwill change the REPLICATION_SCOPE for this edit to GLOBAL so that it can replicate. On the sink cluster,ReplicationSinkwill convert the ReplicationMarkerDescriptor into a Put mutation to REPLICATION_SINK_TRACKER_TABLE_NAME_STR table.
- 
replay
- 
cells
- 
families
 
- 
- 
Constructor Details- 
WALEditpublic WALEdit()
- 
WALEditDeprecated.since 2.0.1 and will be removed in 4.0.0. UseWALEdit(int, boolean)instead.- See Also:
 
- 
WALEditDeprecated.since 2.0.1 and will be removed in 4.0.0. UseWALEdit(int, boolean)instead.- See Also:
 
- 
WALEdit- Parameters:
- cellCount- Pass so can pre-size the WALEdit. Optimization.
 
 
- 
- 
Method Details- 
getOrCreateFamilies
- 
getFamiliesFor use by FSWALEntry ONLY. An optimization.- Returns:
- All families in getCells(); may be null.
 
- 
isMetaEditFamilyDeprecated.Since 2.3.0. Do not expose. Make protected.- Returns:
- True is fisMETAFAMILY
 
- 
isMetaEditFamilyReplaying WALs can read Cell-at-a-time so need this method in those cases.
- 
isMetaEdit- Returns:
- True if this is a meta edit; has one edit only and its columnfamily is
         METAFAMILY.
 
- 
isReplay- Returns:
- True when current WALEdit is created by log replay. Replication skips WALEdits from replay.
 
- 
add
- 
add
- 
isEmpty
- 
size
- 
getCells
- 
setCellsThis is not thread safe. This will change the WALEdit and shouldn't be used unless you are sure that nothing else depends on the contents being immutable.- Parameters:
- cells- the list of cells that this WALEdit now contains.
 
- 
readFromCellsReads WALEdit from cells.- Parameters:
- cellDecoder- Cell decoder.
- expectedCount- Expected cell count.
- Returns:
- Number of KVs read.
- Throws:
- IOException
 
- 
heapSizeDescription copied from interface:HeapSizeReturn the approximate 'exclusive deep size' of implementing object. Includes count of payload and hosting object sizings.
- 
estimatedSerializedSizeOf
- 
toString
- 
createFlushWALEditpublic static WALEdit createFlushWALEdit(RegionInfo hri, org.apache.hadoop.hbase.shaded.protobuf.generated.WALProtos.FlushDescriptor f) 
- 
getFlushDescriptorpublic static org.apache.hadoop.hbase.shaded.protobuf.generated.WALProtos.FlushDescriptor getFlushDescriptor(Cell cell) throws IOException - Throws:
- IOException
 
- 
createRegionEventWALEditpublic static WALEdit createRegionEventWALEdit(RegionInfo hri, org.apache.hadoop.hbase.shaded.protobuf.generated.WALProtos.RegionEventDescriptor regionEventDesc) - Returns:
- A meta Marker WALEdit that has a single Cell whose value is the passed in
         regionEventDescserialized and whose row is this region, columnfamily isMETAFAMILYand qualifier isREGION_EVENT_PREFIX+WALProtos.RegionEventDescriptor.getEventType(); for example HBASE::REGION_EVENT::REGION_CLOSE.
 
- 
createRegionEventWALEdit@Private public static WALEdit createRegionEventWALEdit(byte[] rowForRegion, org.apache.hadoop.hbase.shaded.protobuf.generated.WALProtos.RegionEventDescriptor regionEventDesc) 
- 
createRegionEventDescriptorQualifier@Private public static byte[] createRegionEventDescriptorQualifier(org.apache.hadoop.hbase.shaded.protobuf.generated.WALProtos.RegionEventDescriptor.EventType t) - Returns:
- Cell qualifier for the passed in RegionEventDescriptor Type; e.g. we'll return something like a byte array with HBASE::REGION_EVENT::REGION_OPEN in it.
 
- 
isRegionCloseMarkerPublic so can be accessed from regionserver.wal package.- Returns:
- True if this is a Marker Edit and it is a RegionClose type.
 
- 
getRegionEventDescriptorpublic static org.apache.hadoop.hbase.shaded.protobuf.generated.WALProtos.RegionEventDescriptor getRegionEventDescriptor(Cell cell) throws IOException - Returns:
- Returns a RegionEventDescriptor made by deserializing the content of the passed in
         cell, IFF thecellis a RegionEventDescriptor type WALEdit.
- Throws:
- IOException
 
- 
createCompactionpublic static WALEdit createCompaction(RegionInfo hri, org.apache.hadoop.hbase.shaded.protobuf.generated.WALProtos.CompactionDescriptor c) Returns A Marker WALEdit that hascserialized as its value
- 
getRowForRegion
- 
getCompactionpublic static org.apache.hadoop.hbase.shaded.protobuf.generated.WALProtos.CompactionDescriptor getCompaction(Cell kv) throws IOException Deserialized and returns a CompactionDescriptor is the KeyValue contains one.- Parameters:
- kv- the key value
- Returns:
- deserialized CompactionDescriptor or null.
- Throws:
- IOException
 
- 
isCompactionMarkerReturns true if the given cell is a serializedWALProtos.CompactionDescriptor- See Also:
 
- 
createBulkLoadEventpublic static WALEdit createBulkLoadEvent(RegionInfo hri, org.apache.hadoop.hbase.shaded.protobuf.generated.WALProtos.BulkLoadDescriptor bulkLoadDescriptor) Create a bulk loader WALEdit- Parameters:
- hri- The RegionInfo for the region in which we are bulk loading
- bulkLoadDescriptor- The descriptor for the Bulk Loader
- Returns:
- The WALEdit for the BulkLoad
 
- 
getBulkLoadDescriptorpublic static org.apache.hadoop.hbase.shaded.protobuf.generated.WALProtos.BulkLoadDescriptor getBulkLoadDescriptor(Cell cell) throws IOException Deserialized and returns a BulkLoadDescriptor from the passed in Cell- Parameters:
- cell- the key value
- Returns:
- deserialized BulkLoadDescriptor or null.
- Throws:
- IOException
 
- 
addAppend the given map of family->edits to a WALEdit data structure. This does not write to the WAL itself. Note that as an optimization, we will stamp the Set of column families into the WALEdit to save on our having to calculate column families subsequently down in the actual WAL writing.- Parameters:
- familyMap- map of family->edits
 
- 
addFamily
- 
addCell
- 
createReplicationMarkerEditCreates a replication tracker edit withMETAFAMILYfamily andREPLICATION_MARKERqualifier and has null value.- Parameters:
- rowKey- rowkey
- timestamp- timestamp
 
- 
isReplicationMarkerEditChecks whether this edit is a replication marker edit.- Parameters:
- edit- edit
- Returns:
- true if the cell within an edit has column = METAFAMILY and qualifier = REPLICATION_MARKER, false otherwise
 
 
-