WL#7364: RBR: Enhanced Applier Thread Progress Details

Affects: Server-8.0   —   Status: Complete

EXECUTIVE SUMMARY
=================

This worklog aims at improving/fixing the stats that are shown through
SHOW PROCESSLIST, INFORMATION_SCHEMA.PROCESSLIST,
PERFORMANCE_SCHEMA.THREADS and PERFORMANCE_SCHEMA.EVENTS_STAGES_* for
the SQL thread when it is applying row events. This is motivated by
the fact that users do not have a clue of what is happening when the
SQL thread is applying a ROW event. In fact, currently wrong
information can be reported through PROCESSLIST.  Therefore, users
should at least be able to see through PERFORMANCE_SCHEMA tables what
is the correct state of the SQL thread and what exactly it is doing at
the moment.  This minimal information is of great help to troubleshoot
Row-based Replication problems.

The work on this worklog should be later extended with further
PERFORMANCE_SCHEMA additions that export many more stats for RBR.

SOLUTION
========

- Fix the command field: set it to NULL (or QUERY(?))

- Put in the "Info" field the contents of Rows_query_log_event.

- Fix a proper THD_STAGE_INFO for when the thread is applying
  row events.

- Add RBR stages for reporting how far the SQL thread has processed
  each ROW event (lets call it bundle of RBR changes).

  This is reported through performance_schema stages tables.