diff options
author | Richard van der Hoff <1389908+richvdh@users.noreply.github.com> | 2020-08-04 10:03:41 +0100 |
---|---|---|
committer | GitHub <noreply@github.com> | 2020-08-04 10:03:41 +0100 |
commit | 916cf2d439c406dd08310714ae31216608ea6fa6 (patch) | |
tree | 1b7207659c07dfe86483b22abd305b5f32e9cb14 /synapse/app | |
parent | Remove signature check on v1 identity server lookups (#8001) (diff) | |
download | synapse-916cf2d439c406dd08310714ae31216608ea6fa6.tar.xz |
re-implement daemonize (#8011)
This has long been something I've wanted to do. Basically the `Daemonize` code is both too flexible and not flexible enough, in that it offers a bunch of features that we don't use (changing UID, closing FDs in the child, logging to syslog) and doesn't offer a bunch that we could do with (redirecting stdout/err to a file instead of /dev/null; having the parent not exit until the child is running). As a first step, I've lifted the Daemonize code and removed the bits we don't use. This should be a non-functional change. Fixing everything else will come later.
Diffstat (limited to 'synapse/app')
-rw-r--r-- | synapse/app/_base.py | 16 |
1 files changed, 3 insertions, 13 deletions
diff --git a/synapse/app/_base.py b/synapse/app/_base.py index 373a80a4a7..fa40c68f53 100644 --- a/synapse/app/_base.py +++ b/synapse/app/_base.py @@ -12,7 +12,6 @@ # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. # See the License for the specific language governing permissions and # limitations under the License. - import gc import logging import os @@ -22,7 +21,6 @@ import sys import traceback from typing import Iterable -from daemonize import Daemonize from typing_extensions import NoReturn from twisted.internet import defer, error, reactor @@ -34,6 +32,7 @@ from synapse.config.server import ListenerConfig from synapse.crypto import context_factory from synapse.logging.context import PreserveLoggingContext from synapse.util.async_helpers import Linearizer +from synapse.util.daemonize import daemonize_process from synapse.util.rlimit import change_resource_limit from synapse.util.versionstring import get_version_string @@ -129,17 +128,8 @@ def start_reactor( if print_pidfile: print(pid_file) - daemon = Daemonize( - app=appname, - pid=pid_file, - action=run, - auto_close_fds=False, - verbose=True, - logger=logger, - ) - daemon.start() - else: - run() + daemonize_process(pid_file, logger) + run() def quit_with_error(error_string: str) -> NoReturn: |