Ich würde denken, dass die Beats von Natur aus gestaffelt sind , da der nächste Tick durch die Browserzeit time()
innerhalb der scheduleNextTick()
Methode in der /wp-includes/js/heartbeat.js
Datei bestimmt wird:
var delta = time() - settings.lastTick,
interval = settings.mainInterval;
wo es verwendet wird, um den nächsten Tick mit der setTimeout
Funktion zu planen :
if ( delta < interval ) {
settings.beatTimer = window.setTimeout(
function() {
connect();
},
interval - delta
);
} else {
connect();
}
Die Browserzeit ist definiert als:
function time() {
return (new Date()).getTime();
}
Die connect()
Methode enthält den Ajax-Aufruf und verwendetalways()
.always( function() {
settings.connecting = false;
scheduleNextTick();
})
um den nächsten Tick zu planen.
Die verfügbaren Tick-Intervalle sind 5s, 15s, 30s und 60s.
Bei einer großen Anzahl sehr aktiver Benutzer mit einem kurzen Tick-Intervall scheinen die Beats möglicherweise gleichzeitig zu erfolgen.
Es ist immer gut, einige Daten zu haben, damit Sie die Ticks der angemeldeten Benutzer mit dem heartbeat_tick
Haken protokollieren können :
add_action( 'heartbeat_tick',
function( $response, $screen_id )
{
$file = WP_CONTENT_DIR . '/ticks.log'; // Edit this filepath to your needs.
if( file_exists( $file ) && is_writeable( $file ) )
{
file_put_contents(
$file,
sprintf( "%s - Tick from user_id : %d - from screen_id : %s" . PHP_EOL,
date( 'c' ),
get_current_user_id(),
$screen_id
),
FILE_APPEND | LOCK_EX
);
}
}
, 11, 2 );
Hier ist ein Beispiel aus der ticks.log
Datei:
2014-09-01T12:41:04+00:00 - Tick from user_id : 1 - from screen_id : edit-post
2014-09-01T12:41:19+00:00 - Tick from user_id : 1 - from screen_id : edit-post
2014-09-01T12:41:34+00:00 - Tick from user_id : 1 - from screen_id : edit-post
2014-09-01T12:41:56+00:00 - Tick from user_id : 1 - from screen_id : post
2014-09-01T12:42:11+00:00 - Tick from user_id : 1 - from screen_id : post
2014-09-01T12:42:20+00:00 - Tick from user_id : 3 - from screen_id : upload
2014-09-01T12:42:38+00:00 - Tick from user_id : 1 - from screen_id : post
2014-09-01T12:43:05+00:00 - Tick from user_id : 1 - from screen_id : post
2014-09-01T12:43:08+00:00 - Tick from user_id : 3 - from screen_id : attachment
2014-09-01T12:43:20+00:00 - Tick from user_id : 1 - from screen_id : post
2014-09-01T12:43:36+00:00 - Tick from user_id : 1 - from screen_id : post
2014-09-01T12:44:17+00:00 - Tick from user_id : 3 - from screen_id : profile