mirror of
https://github.com/element-hq/synapse
synced 2024-10-05 17:42:42 +00:00
9cae44f49e
When a local device list change is added to `device_lists_changes_in_room`, the `converted_to_destinations` flag is set to `FALSE` and the `_handle_new_device_update_async` background process is started. This background process looks for unconverted rows in `device_lists_changes_in_room`, copies them to `device_lists_outbound_pokes` and updates the flag. To update the `converted_to_destinations` flag, the database performs a `DELETE` and `INSERT` internally, which fragments the table. To avoid this, track unconverted rows using a `(stream ID, room ID)` position instead of the flag. From now on, the `converted_to_destinations` column indicates rows that need converting to outbound pokes, but does not indicate whether the conversion has already taken place. Closes #14037. Signed-off-by: Sean Quah <seanq@matrix.org> |
||
---|---|---|
.. | ||
.gitignore | ||
14376.misc | ||
14393.bugfix | ||
14400.misc | ||
14403.misc | ||
14404.misc | ||
14412.misc | ||
14449.misc | ||
14452.misc | ||
14468.misc | ||
14476.misc | ||
14479.misc | ||
14487.misc | ||
14490.misc | ||
14491.feature | ||
14499.doc | ||
14500.misc | ||
14501.misc | ||
14502.misc | ||
14503.misc | ||
14504.misc | ||
14505.misc | ||
14508.feature | ||
14510.feature | ||
14516.misc |