2017-03-27 09:58:26 -04:00
|
|
|
#
|
2023-11-21 15:29:58 -05:00
|
|
|
# This file is licensed under the Affero General Public License (AGPL) version 3.
|
|
|
|
#
|
2024-01-23 06:26:48 -05:00
|
|
|
# Copyright 2017 Vector Creations Ltd
|
2023-11-21 15:29:58 -05:00
|
|
|
# Copyright (C) 2023 New Vector, Ltd
|
|
|
|
#
|
|
|
|
# This program is free software: you can redistribute it and/or modify
|
|
|
|
# it under the terms of the GNU Affero General Public License as
|
|
|
|
# published by the Free Software Foundation, either version 3 of the
|
|
|
|
# License, or (at your option) any later version.
|
|
|
|
#
|
|
|
|
# See the GNU Affero General Public License for more details:
|
|
|
|
# <https://www.gnu.org/licenses/agpl-3.0.html>.
|
|
|
|
#
|
|
|
|
# Originally licensed under the Apache License, Version 2.0:
|
|
|
|
# <http://www.apache.org/licenses/LICENSE-2.0>.
|
|
|
|
#
|
|
|
|
# [This file includes modifications made by New Vector Limited]
|
2017-03-27 09:58:26 -04:00
|
|
|
#
|
|
|
|
#
|
2017-03-27 10:40:37 -04:00
|
|
|
|
|
|
|
"""This module implements the TCP replication protocol used by synapse to
|
|
|
|
communicate between the master process and its workers (when they're enabled).
|
|
|
|
|
2022-05-09 17:46:43 -04:00
|
|
|
Further details can be found in docs/tcp_replication.md
|
2017-03-27 10:40:37 -04:00
|
|
|
|
|
|
|
|
|
|
|
Structure of the module:
|
2020-04-06 04:58:42 -04:00
|
|
|
* handler.py - the classes used to handle sending/receiving commands to
|
|
|
|
replication
|
2017-03-27 10:40:37 -04:00
|
|
|
* command.py - the definitions of all the valid commands
|
2020-04-06 04:58:42 -04:00
|
|
|
* protocol.py - the TCP protocol classes
|
|
|
|
* resource.py - handles streaming stream updates to replications
|
2020-07-09 09:52:58 -04:00
|
|
|
* streams/ - the definitions of all the valid streams
|
2017-03-27 10:40:37 -04:00
|
|
|
|
2020-04-06 04:58:42 -04:00
|
|
|
|
|
|
|
The general interaction of the classes are:
|
|
|
|
|
|
|
|
+---------------------+
|
|
|
|
| ReplicationStreamer |
|
|
|
|
+---------------------+
|
|
|
|
|
|
|
|
|
v
|
|
|
|
+---------------------------+ +----------------------+
|
|
|
|
| ReplicationCommandHandler |---->|ReplicationDataHandler|
|
|
|
|
+---------------------------+ +----------------------+
|
|
|
|
| ^
|
|
|
|
v |
|
|
|
|
+-------------+
|
|
|
|
| Protocols |
|
|
|
|
| (TCP/redis) |
|
|
|
|
+-------------+
|
|
|
|
|
|
|
|
Where the ReplicationDataHandler (or subclasses) handles incoming stream
|
|
|
|
updates.
|
2017-03-27 10:40:37 -04:00
|
|
|
"""
|