mirror of
https://mau.dev/maunium/synapse.git
synced 2024-12-15 22:13:50 +01:00
As daemonizing will make a new process, defer call to init.
This commit is contained in:
parent
ef520d8d0e
commit
4ceaa7433a
1 changed files with 23 additions and 13 deletions
|
@ -401,7 +401,7 @@ def run(hs):
|
||||||
start_time = clock.time()
|
start_time = clock.time()
|
||||||
|
|
||||||
stats = {}
|
stats = {}
|
||||||
stats_process = None
|
stats_process = []
|
||||||
|
|
||||||
@defer.inlineCallbacks
|
@defer.inlineCallbacks
|
||||||
def phone_stats_home():
|
def phone_stats_home():
|
||||||
|
@ -428,10 +428,13 @@ def run(hs):
|
||||||
|
|
||||||
daily_sent_messages = yield hs.get_datastore().count_daily_sent_messages()
|
daily_sent_messages = yield hs.get_datastore().count_daily_sent_messages()
|
||||||
stats["daily_sent_messages"] = daily_sent_messages
|
stats["daily_sent_messages"] = daily_sent_messages
|
||||||
if stats_process is not None:
|
if len(stats_process) > 0:
|
||||||
with stats_process.oneshot():
|
stats["memory_rss"] = 0
|
||||||
stats["memory_rss"] = stats_process.memory_info().rss
|
stats["cpu_average"] = 0
|
||||||
stats["cpu_average"] = int(stats_process.cpu_info(interval=None))
|
for process in stats_process:
|
||||||
|
with process.oneshot():
|
||||||
|
stats["memory_rss"] += process.memory_info().rss
|
||||||
|
stats["cpu_average"] += int(process.cpu_percent(interval=None))
|
||||||
|
|
||||||
logger.info("Reporting stats to matrix.org: %s" % (stats,))
|
logger.info("Reporting stats to matrix.org: %s" % (stats,))
|
||||||
try:
|
try:
|
||||||
|
@ -442,25 +445,32 @@ def run(hs):
|
||||||
except Exception as e:
|
except Exception as e:
|
||||||
logger.warn("Error reporting stats: %s", e)
|
logger.warn("Error reporting stats: %s", e)
|
||||||
|
|
||||||
if hs.config.report_stats:
|
def performance_stats_init():
|
||||||
try:
|
try:
|
||||||
import psutil
|
import psutil
|
||||||
stats_process = psutil.Process()
|
process = psutil.Process()
|
||||||
# Ensure we can fetch both, and make the initial request for cpu_percent
|
# Ensure we can fetch both, and make the initial request for cpu_percent
|
||||||
# so the next request will use this as the initial point.
|
# so the next request will use this as the initial point.
|
||||||
stats_process.memory_info().rss
|
process.memory_info().rss
|
||||||
stats_process.cpu_percent(interval=None)
|
process.cpu_percent(interval=None)
|
||||||
|
logger.info("report_stats can use psutil")
|
||||||
|
stats_process.append(process)
|
||||||
except (ImportError, AttributeError):
|
except (ImportError, AttributeError):
|
||||||
logger.warn(
|
logger.warn(
|
||||||
"report_stats enabled but psutil is not installed or incorrect version."
|
"report_stats enabled but psutil is not installed or incorrect version."
|
||||||
" Disabling reporting of memory/cpu stats."
|
" Disabling reporting of memory/cpu stats."
|
||||||
" Ensuring psutil is available will help matrix track performance changes across releases."
|
" Ensuring psutil is available will help matrix track performance changes"
|
||||||
|
" across releases."
|
||||||
)
|
)
|
||||||
stats_process = None
|
|
||||||
|
|
||||||
|
if hs.config.report_stats:
|
||||||
logger.info("Scheduling stats reporting for 3 hour intervals")
|
logger.info("Scheduling stats reporting for 3 hour intervals")
|
||||||
clock.looping_call(phone_stats_home, 3 * 60 * 60 * 1000)
|
clock.looping_call(phone_stats_home, 3 * 60 * 60 * 1000)
|
||||||
|
|
||||||
|
# We need to defer this init for the cases that we daemonize
|
||||||
|
# otherwise the process ID we get is that of the non-daemon process
|
||||||
|
clock.call_later(15, performance_stats_init)
|
||||||
|
|
||||||
# We wait 5 minutes to send the first set of stats as the server can
|
# We wait 5 minutes to send the first set of stats as the server can
|
||||||
# be quite busy the first few minutes
|
# be quite busy the first few minutes
|
||||||
clock.call_later(5 * 60, phone_stats_home)
|
clock.call_later(5 * 60, phone_stats_home)
|
||||||
|
|
Loading…
Reference in a new issue