SystemController.php 3.9 KB

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