NAME
DBIx::BatchChunker::LoopState - Loop state object for DBIx::BatchChunker
VERSION
version v1.0.2
SYNOPSIS
sub chunk_method {
my ($bc, $rs) = @_;
my $loop_state = $bc->loop_state;
# introspect stuff
}
DESCRIPTION
This is the loop state object used during BatchChunker runs. It only exists within the BatchChunker execution loop, and would generally only be accessible through the coderef or method referenced within that loop.
This is a quasi-private object and its API may be subject to change, but the module is in a pretty stable state at this point. While permissions are available to write to the attributes, it is highly recommended to not do so unless you know exactly what you doing. These are mostly available for introspection of loop progress.
ATTRIBUTES
batch_chunker
Reference back to the parent DBIx::BatchChunker object.
progress_bar
The progress bar being used in the loop. This may be different than "progress_bar" in DBIx::BatchChunker, since it could be auto-generated.
If you're trying to access the progress bar for debug or display purposes, it's best to use this attribute:
my $progress_bar = $bc->loop_state->progress_bar;
$progress_bar->message('Found something here');
total_timer
Epoch timer for the start of the entire operation.
chunk_timer
Epoch timer for the start of each chunk.
start
The real start ID that the loop is currently on. May continue to exist within iterations if chunk resizing is trying to find a valid range. Otherwise, this value will become undef when a chunk is finally processed.
end
The real end ID that the loop is currently looking at. This is always redefined at the beginning of the loop.
prev_end
Last "processed" value of "end". This also includes skipped blocks. Used in "start" calculations and to determine if the end of the loop has been reached.
Initially undef
, if no blocks have been processed yet.
last_range
A hashref of min/max values used for the bisecting of one block, measured in chunk multipliers. Cleared out after a block has been processed or skipped.
last_timings
An arrayref of hashrefs, containing data for the previous 5 runs. This data is used for runtime targeting.
multiplier_range
The range (in units of "chunk_size") between the start and end IDs. This starts at 1 (at the beginning of the loop), but may expand or shrink depending on chunk count checks. Resets after block processing.
multiplier_step
Determines how fast "multiplier_range" increases, so that chunk resizing happens at an accelerated pace. Speeds or slows depending on what kind of limits the chunk count checks are hitting. Resets after block processing.
checked_count
A check counter to make sure the chunk resizing isn't taking too long. After ten checks, it will give up, assuming the block is safe to process.
chunk_size
The current chunk size, which might be adjusted by runtime targeting.
chunk_count
Records the results of the COUNT(*)
query for chunk resizing.
prev_check
A short string recording what happened during the last chunk resizing check. Exists purely for debugging purposes.
prev_runtime
The number of seconds the previously processed chunk took to run, not including sleep time.
AUTHOR
Grant Street Group <developers@grantstreet.com>
COPYRIGHT AND LICENSE
This software is Copyright (c) 2018 - 2025 by Grant Street Group.
This is free software, licensed under:
The Artistic License 2.0 (GPL Compatible)