SystemController.php 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105
  1. <?php
  2. namespace App\Http\Controllers\Admin;
  3. use App\Utils\CacheKey;
  4. use Illuminate\Http\Request;
  5. use App\Http\Controllers\Controller;
  6. use Illuminate\Support\Facades\Cache;
  7. use Illuminate\Support\Facades\DB;
  8. use Illuminate\Support\Facades\Http;
  9. use Laravel\Horizon\Contracts\JobRepository;
  10. use Laravel\Horizon\Contracts\MasterSupervisorRepository;
  11. use Laravel\Horizon\Contracts\MetricsRepository;
  12. use Laravel\Horizon\Contracts\SupervisorRepository;
  13. use Laravel\Horizon\Contracts\WorkloadRepository;
  14. use Laravel\Horizon\WaitTimeCalculator;
  15. class SystemController extends Controller
  16. {
  17. public function getSystemStatus()
  18. {
  19. return response([
  20. 'data' => [
  21. 'schedule' => $this->getScheduleStatus(),
  22. 'horizon' => $this->getHorizonStatus(),
  23. 'schedule_last_runtime' => Cache::get(CacheKey::get('SCHEDULE_LAST_CHECK_AT', null))
  24. ]
  25. ]);
  26. }
  27. public function getQueueWorkload(WorkloadRepository $workload)
  28. {
  29. return response([
  30. 'data' => collect($workload->get())->sortBy('name')->values()->toArray()
  31. ]);
  32. }
  33. protected function getScheduleStatus():bool
  34. {
  35. return (time() - 120) < Cache::get(CacheKey::get('SCHEDULE_LAST_CHECK_AT', null));
  36. }
  37. protected function getHorizonStatus():bool
  38. {
  39. if (! $masters = app(MasterSupervisorRepository::class)->all()) {
  40. return false;
  41. }
  42. return collect($masters)->contains(function ($master) {
  43. return $master->status === 'paused';
  44. }) ? false : true;
  45. }
  46. public function getQueueStats()
  47. {
  48. return response([
  49. 'data' => [
  50. 'failedJobs' => app(JobRepository::class)->countRecentlyFailed(),
  51. 'jobsPerMinute' => app(MetricsRepository::class)->jobsProcessedPerMinute(),
  52. 'pausedMasters' => $this->totalPausedMasters(),
  53. 'periods' => [
  54. 'failedJobs' => config('horizon.trim.recent_failed', config('horizon.trim.failed')),
  55. 'recentJobs' => config('horizon.trim.recent'),
  56. ],
  57. 'processes' => $this->totalProcessCount(),
  58. 'queueWithMaxRuntime' => app(MetricsRepository::class)->queueWithMaximumRuntime(),
  59. 'queueWithMaxThroughput' => app(MetricsRepository::class)->queueWithMaximumThroughput(),
  60. 'recentJobs' => app(JobRepository::class)->countRecent(),
  61. 'status' => $this->getHorizonStatus(),
  62. 'wait' => collect(app(WaitTimeCalculator::class)->calculate())->take(1),
  63. ]
  64. ]);
  65. }
  66. /**
  67. * Get the total process count across all supervisors.
  68. *
  69. * @return int
  70. */
  71. protected function totalProcessCount()
  72. {
  73. $supervisors = app(SupervisorRepository::class)->all();
  74. return collect($supervisors)->reduce(function ($carry, $supervisor) {
  75. return $carry + collect($supervisor->processes)->sum();
  76. }, 0);
  77. }
  78. /**
  79. * Get the number of master supervisors that are currently paused.
  80. *
  81. * @return int
  82. */
  83. protected function totalPausedMasters()
  84. {
  85. if (! $masters = app(MasterSupervisorRepository::class)->all()) {
  86. return 0;
  87. }
  88. return collect($masters)->filter(function ($master) {
  89. return $master->status === 'paused';
  90. })->count();
  91. }
  92. }