summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorRoeland Jago Douma <rullzer@users.noreply.github.com>2020-09-24 14:57:17 +0200
committerGitHub <noreply@github.com>2020-09-24 14:57:17 +0200
commit0e2f316ece9a0f5ec5db271f3a5c50a767c76030 (patch)
tree542dbbb0ecc8e95e07330df3da5b8b5e4327432f
parentacba3da7c877fbb470078489fe6346fbf157d317 (diff)
parentb497067ead79d617a09d081f580b1cd930fcb771 (diff)
downloadnextcloud-server-0e2f316ece9a0f5ec5db271f3a5c50a767c76030.tar.gz
nextcloud-server-0e2f316ece9a0f5ec5db271f3a5c50a767c76030.zip
Merge pull request #23015 from nextcloud/bugfix/noid/warn-on-slow-dashboard-widgets
Log slow dashboard widgets
-rw-r--r--lib/private/Dashboard/Manager.php9
-rw-r--r--lib/private/InitialStateService.php10
2 files changed, 19 insertions, 0 deletions
diff --git a/lib/private/Dashboard/Manager.php b/lib/private/Dashboard/Manager.php
index bc57326dff0..94b80a3b4a4 100644
--- a/lib/private/Dashboard/Manager.php
+++ b/lib/private/Dashboard/Manager.php
@@ -95,7 +95,16 @@ class Manager implements IManager {
}
try {
+ $startTime = microtime(true);
$widget->load();
+ $endTime = microtime(true);
+ $duration = $endTime - $startTime;
+ if ($duration > 1) {
+ \OC::$server->getLogger()->error('Dashboard widget {widget} took {duration} seconds to load.', [
+ 'widget' => $widget->getId(),
+ 'duration' => round($duration, 2),
+ ]);
+ }
} catch (Throwable $e) {
\OC::$server->getLogger()->logException($e, [
'message' => 'Error during dashboard widget loading: ' . $e->getMessage(),
diff --git a/lib/private/InitialStateService.php b/lib/private/InitialStateService.php
index 55ce9c41726..c74eb683bd9 100644
--- a/lib/private/InitialStateService.php
+++ b/lib/private/InitialStateService.php
@@ -72,7 +72,17 @@ class InitialStateService implements IInitialStateService {
private function invokeLazyStateCallbacks(): void {
foreach ($this->lazyStates as $app => $lazyStates) {
foreach ($lazyStates as $key => $lazyState) {
+ $startTime = microtime(true);
$this->provideInitialState($app, $key, $lazyState());
+ $endTime = microtime(true);
+ $duration = $endTime - $startTime;
+ if ($duration > 1) {
+ $this->logger->warning('Lazy initial state provider for {key} took {duration} seconds.', [
+ 'app' => $app,
+ 'key' => $key,
+ 'duration' => round($duration, 2),
+ ]);
+ }
}
}
$this->lazyStates = [];