mirror of
https://mau.dev/maunium/synapse.git
synced 2024-12-14 18:13:54 +01:00
Support running multiple media repos. (#7706)
This requires a new config option to specify which media repo should be responsible for running background jobs to e.g. clear out expired URL preview caches.
This commit is contained in:
parent
434716e1d3
commit
b44bdd7f7b
4 changed files with 28 additions and 4 deletions
1
changelog.d/7706.feature
Normal file
1
changelog.d/7706.feature
Normal file
|
@ -0,0 +1 @@
|
||||||
|
Add support for running multiple media repository workers. See [docs/workers.md](docs/workers.md) for instructions.
|
|
@ -307,7 +307,12 @@ expose the `media` resource. For example:
|
||||||
- media
|
- media
|
||||||
```
|
```
|
||||||
|
|
||||||
Note this worker cannot be load-balanced: only one instance should be active.
|
Note that if running multiple media repositories they must be on the same server
|
||||||
|
and you must configure a single instance to run the background tasks, e.g.:
|
||||||
|
|
||||||
|
```yaml
|
||||||
|
media_instance_running_background_jobs: "media-repository-1"
|
||||||
|
```
|
||||||
|
|
||||||
### `synapse.app.client_reader`
|
### `synapse.app.client_reader`
|
||||||
|
|
||||||
|
|
|
@ -94,6 +94,12 @@ class ContentRepositoryConfig(Config):
|
||||||
else:
|
else:
|
||||||
self.can_load_media_repo = True
|
self.can_load_media_repo = True
|
||||||
|
|
||||||
|
# Whether this instance should be the one to run the background jobs to
|
||||||
|
# e.g clean up old URL previews.
|
||||||
|
self.media_instance_running_background_jobs = config.get(
|
||||||
|
"media_instance_running_background_jobs",
|
||||||
|
)
|
||||||
|
|
||||||
self.max_upload_size = self.parse_size(config.get("max_upload_size", "10M"))
|
self.max_upload_size = self.parse_size(config.get("max_upload_size", "10M"))
|
||||||
self.max_image_pixels = self.parse_size(config.get("max_image_pixels", "32M"))
|
self.max_image_pixels = self.parse_size(config.get("max_image_pixels", "32M"))
|
||||||
self.max_spider_size = self.parse_size(config.get("max_spider_size", "10M"))
|
self.max_spider_size = self.parse_size(config.get("max_spider_size", "10M"))
|
||||||
|
|
|
@ -82,6 +82,15 @@ class PreviewUrlResource(DirectServeResource):
|
||||||
self.primary_base_path = media_repo.primary_base_path
|
self.primary_base_path = media_repo.primary_base_path
|
||||||
self.media_storage = media_storage
|
self.media_storage = media_storage
|
||||||
|
|
||||||
|
# We run the background jobs if we're the instance specified (or no
|
||||||
|
# instance is specified, where we assume there is only one instance
|
||||||
|
# serving media).
|
||||||
|
instance_running_jobs = hs.config.media.media_instance_running_background_jobs
|
||||||
|
self._worker_run_media_background_jobs = (
|
||||||
|
instance_running_jobs is None
|
||||||
|
or instance_running_jobs == hs.get_instance_name()
|
||||||
|
)
|
||||||
|
|
||||||
self.url_preview_url_blacklist = hs.config.url_preview_url_blacklist
|
self.url_preview_url_blacklist = hs.config.url_preview_url_blacklist
|
||||||
self.url_preview_accept_language = hs.config.url_preview_accept_language
|
self.url_preview_accept_language = hs.config.url_preview_accept_language
|
||||||
|
|
||||||
|
@ -94,9 +103,10 @@ class PreviewUrlResource(DirectServeResource):
|
||||||
expiry_ms=60 * 60 * 1000,
|
expiry_ms=60 * 60 * 1000,
|
||||||
)
|
)
|
||||||
|
|
||||||
self._cleaner_loop = self.clock.looping_call(
|
if self._worker_run_media_background_jobs:
|
||||||
self._start_expire_url_cache_data, 10 * 1000
|
self._cleaner_loop = self.clock.looping_call(
|
||||||
)
|
self._start_expire_url_cache_data, 10 * 1000
|
||||||
|
)
|
||||||
|
|
||||||
def render_OPTIONS(self, request):
|
def render_OPTIONS(self, request):
|
||||||
request.setHeader(b"Allow", b"OPTIONS, GET")
|
request.setHeader(b"Allow", b"OPTIONS, GET")
|
||||||
|
@ -397,6 +407,8 @@ class PreviewUrlResource(DirectServeResource):
|
||||||
"""
|
"""
|
||||||
# TODO: Delete from backup media store
|
# TODO: Delete from backup media store
|
||||||
|
|
||||||
|
assert self._worker_run_media_background_jobs
|
||||||
|
|
||||||
now = self.clock.time_msec()
|
now = self.clock.time_msec()
|
||||||
|
|
||||||
logger.debug("Running url preview cache expiry")
|
logger.debug("Running url preview cache expiry")
|
||||||
|
|
Loading…
Reference in a new issue