feat: init metrics
This commit is contained in:
		| @@ -27,7 +27,7 @@ class Logs extends Component | |||||||
|     public $query; |     public $query; | ||||||
|     public $status; |     public $status; | ||||||
|     public $serviceSubType; |     public $serviceSubType; | ||||||
| 
 |     public $cpu; | ||||||
|     public function loadContainers($server_id) |     public function loadContainers($server_id) | ||||||
|     { |     { | ||||||
|         try { |         try { | ||||||
| @@ -49,6 +49,14 @@ class Logs extends Component | |||||||
|             return handleError($e, $this); |             return handleError($e, $this); | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  |     public function loadMetrics() | ||||||
|  |     { | ||||||
|  |         return; | ||||||
|  |         $server = data_get($this->resource, 'destination.server'); | ||||||
|  |         if ($server->isFunctional()) { | ||||||
|  |             $this->cpu = $server->getMetrics(); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|     public function mount() |     public function mount() | ||||||
|     { |     { | ||||||
|         try { |         try { | ||||||
| @@ -95,6 +103,7 @@ class Logs extends Component | |||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|             $this->containers = $this->containers->sort(); |             $this->containers = $this->containers->sort(); | ||||||
|  |             $this->loadMetrics(); | ||||||
|         } catch (\Exception $e) { |         } catch (\Exception $e) { | ||||||
|             return handleError($e, $this); |             return handleError($e, $this); | ||||||
|         } |         } | ||||||
|   | |||||||
| @@ -480,6 +480,23 @@ $schema://$host { | |||||||
|             } |             } | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  |     public function getMetrics() | ||||||
|  |     { | ||||||
|  |         if ($this->is_metrics_enabled) { | ||||||
|  |             $cpu = instant_remote_process(["cat /data/coolify/metrics/cpu.csv | grep 'Overall' | tail -200 | awk -F, '{print $1\",\" \$NF}'"], $this, false); | ||||||
|  |             $cpu = str($cpu)->replace("%", ""); | ||||||
|  |             ray($cpu); | ||||||
|  |             $parsedCollection = collect($cpu)->flatMap(function ($item) { | ||||||
|  |                 return collect(explode("\n", trim($item)))->map(function ($line) { | ||||||
|  |                     list($time, $value) = explode(',', trim($line)); | ||||||
|  |                     // convert $time from nanoseconds to milliseconds for apexcharts
 | ||||||
|  |                     $time = (int) $time / 1000000; | ||||||
|  |                     return [(int) $time, (float) $value]; | ||||||
|  |                 }); | ||||||
|  |             })->toArray(); | ||||||
|  |             return $parsedCollection; | ||||||
|  |         } | ||||||
|  |     } | ||||||
|     public function isServerReady(int $tries = 3) |     public function isServerReady(int $tries = 3) | ||||||
|     { |     { | ||||||
|         if ($this->skipServer()) { |         if ($this->skipServer()) { | ||||||
|   | |||||||
| @@ -54,4 +54,74 @@ | |||||||
|             @endforelse |             @endforelse | ||||||
|         </div> |         </div> | ||||||
|     @endif |     @endif | ||||||
|  |     {{-- <section x-data="apex_app" class="container p-5 mx-auto my-20 bg-white drop-shadow-xl rounded-xl"> | ||||||
|  |         <div class="w-full" x-ref="chart"></div> | ||||||
|  |     </section> | ||||||
|  |     <script src="https://cdn.jsdelivr.net/npm/apexcharts"></script> | ||||||
|  |     <script> | ||||||
|  |         document.addEventListener("alpine:init", () => { | ||||||
|  |             Alpine.data("apex_app", () => ({ | ||||||
|  |                 data: @js($cpu), | ||||||
|  |                 init() { | ||||||
|  |                     let chart = new ApexCharts(this.$refs.chart, this.options); | ||||||
|  |                     chart.render(); | ||||||
|  |                     this.$watch("data", () => { | ||||||
|  |                         chart.updateOptions(this.options); | ||||||
|  |                     }); | ||||||
|  |                 }, | ||||||
|  | 
 | ||||||
|  |                 get options() { | ||||||
|  |                     return { | ||||||
|  |                         colors: [function({ | ||||||
|  |                             value, | ||||||
|  |                             seriesIndex, | ||||||
|  |                             w | ||||||
|  |                         }) { | ||||||
|  |                             if (value < 55) { | ||||||
|  |                                 return '#7E36AF' | ||||||
|  |                             } else { | ||||||
|  |                                 return '#D9534F' | ||||||
|  |                             } | ||||||
|  |                         }, function({ | ||||||
|  |                             value, | ||||||
|  |                             seriesIndex, | ||||||
|  |                             w | ||||||
|  |                         }) { | ||||||
|  |                             if (value < 111) { | ||||||
|  |                                 return '#7E36AF' | ||||||
|  |                             } else { | ||||||
|  |                                 return '#D9534F' | ||||||
|  |                             } | ||||||
|  |                         }], | ||||||
|  |                         xaxis: { | ||||||
|  |                             type: 'datetime' | ||||||
|  |                         }, | ||||||
|  |                         dataLabels: { | ||||||
|  |                             enabled: false | ||||||
|  |                         }, | ||||||
|  |                         series: [{ | ||||||
|  |                             name: "Series name", | ||||||
|  |                             data: this.data | ||||||
|  |                         }], | ||||||
|  |                         tooltip: { | ||||||
|  |                             enabled: true | ||||||
|  |                         }, | ||||||
|  |                         chart: { | ||||||
|  |                             height: 500, | ||||||
|  |                             width: "100%", | ||||||
|  |                             type: "area", | ||||||
|  |                             toolbar: { | ||||||
|  |                                 show: true | ||||||
|  |                             }, | ||||||
|  |                             animations: { | ||||||
|  |                                 initialAnimation: { | ||||||
|  |                                     enabled: false | ||||||
|  |                                 } | ||||||
|  |                             } | ||||||
|  |                         }, | ||||||
|  |                     }; | ||||||
|  |                 } | ||||||
|  |             })); | ||||||
|  |         }); | ||||||
|  |     </script> --}} | ||||||
| </div> | </div> | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 Andras Bacsai
					Andras Bacsai