feat: notify user of disk cleanup init
This commit is contained in:
parent
18d26904e2
commit
7bfeb6c177
@ -14,12 +14,12 @@ protected function schedule(Schedule $schedule): void
|
|||||||
{
|
{
|
||||||
if (isDev()) {
|
if (isDev()) {
|
||||||
$schedule->command('horizon:snapshot')->everyMinute();
|
$schedule->command('horizon:snapshot')->everyMinute();
|
||||||
// $schedule->job(new DockerCleanupJob)->everyOddHour();
|
$schedule->job(new DockerCleanupJob)->everyOddHour();
|
||||||
// $schedule->job(new InstanceAutoUpdateJob(true))->everyMinute();
|
// $schedule->job(new InstanceAutoUpdateJob(true))->everyMinute();
|
||||||
} else {
|
} else {
|
||||||
$schedule->command('horizon:snapshot')->everyFiveMinutes();
|
$schedule->command('horizon:snapshot')->everyFiveMinutes();
|
||||||
$schedule->job(new DockerCleanupJob)->everyTenMinutes();
|
|
||||||
$schedule->job(new ProxyCheckJob)->everyFiveMinutes();
|
$schedule->job(new ProxyCheckJob)->everyFiveMinutes();
|
||||||
|
$schedule->job(new DockerCleanupJob)->everyTenMinutes();
|
||||||
$schedule->job(new InstanceAutoUpdateJob)->everyTenMinutes();
|
$schedule->job(new InstanceAutoUpdateJob)->everyTenMinutes();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -36,16 +36,25 @@ public function handle(): void
|
|||||||
} else {
|
} else {
|
||||||
$docker_root_filesystem = instant_remote_process(['stat --printf=%m $(docker info --format "{{json .DockerRootDir}}" |sed \'s/"//g\')'], $server);
|
$docker_root_filesystem = instant_remote_process(['stat --printf=%m $(docker info --format "{{json .DockerRootDir}}" |sed \'s/"//g\')'], $server);
|
||||||
}
|
}
|
||||||
$disk_usage = json_decode(instant_remote_process(['df -hP | awk \'BEGIN {printf"{\"disks\":["}{if($1=="Filesystem")next;if(a)printf",";printf"{\"mount\":\""$6"\",\"size\":\""$2"\",\"used\":\""$3"\",\"avail\":\""$4"\",\"use%\":\""$5"\"}";a++;}END{print"]}";}\''], $server), true);
|
$disk_percentage_before = $this->get_disk_usage($server, $docker_root_filesystem);
|
||||||
$mount_point = collect(data_get($disk_usage, 'disks'))->where('mount', $docker_root_filesystem)->first();
|
if ($disk_percentage_before >= $server->settings->cleanup_after_percentage) {
|
||||||
if (Str::of(data_get($mount_point, 'use%'))->trim()->replace('%', '')->value() >= $server->settings->cleanup_after_percentage) {
|
|
||||||
instant_remote_process(['docker image prune -af'], $server);
|
instant_remote_process(['docker image prune -af'], $server);
|
||||||
instant_remote_process(['docker container prune -f --filter "label=coolify.managed=true"'], $server);
|
instant_remote_process(['docker container prune -f --filter "label=coolify.managed=true"'], $server);
|
||||||
instant_remote_process(['docker builder prune -af'], $server);
|
instant_remote_process(['docker builder prune -af'], $server);
|
||||||
|
$disk_percentage_after = $this->get_disk_usage($server, $docker_root_filesystem);
|
||||||
|
if ($disk_percentage_after < $disk_percentage_before) {
|
||||||
|
ray('Saved ' . ($disk_percentage_before - $disk_percentage_after) . '% disk space on ' . $server->name);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} catch (\Exception $e) {
|
} catch (\Exception $e) {
|
||||||
Log::error($e->getMessage());
|
Log::error($e->getMessage());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private function get_disk_usage(Server $server, string $docker_root_filesystem) {
|
||||||
|
$disk_usage = json_decode(instant_remote_process(['df -hP | awk \'BEGIN {printf"{\"disks\":["}{if($1=="Filesystem")next;if(a)printf",";printf"{\"mount\":\""$6"\",\"size\":\""$2"\",\"used\":\""$3"\",\"avail\":\""$4"\",\"use%\":\""$5"\"}";a++;}END{print"]}";}\''], $server), true);
|
||||||
|
$mount_point = collect(data_get($disk_usage, 'disks'))->where('mount', $docker_root_filesystem)->first();
|
||||||
|
return Str::of(data_get($mount_point, 'use%'))->trim()->replace('%', '')->value();
|
||||||
|
}
|
||||||
}
|
}
|
@ -84,6 +84,10 @@ public function muxFilename()
|
|||||||
{
|
{
|
||||||
return "{$this->ip}_{$this->port}_{$this->user}";
|
return "{$this->ip}_{$this->port}_{$this->user}";
|
||||||
}
|
}
|
||||||
|
public function team()
|
||||||
|
{
|
||||||
|
return $this->belongsTo(Team::class);
|
||||||
|
}
|
||||||
static public function ownedByCurrentTeam(array $select = ['*'])
|
static public function ownedByCurrentTeam(array $select = ['*'])
|
||||||
{
|
{
|
||||||
$selectArray = collect($select)->concat(['id']);
|
$selectArray = collect($select)->concat(['id']);
|
||||||
@ -102,4 +106,4 @@ static public function destinationsByServer(string $server_id)
|
|||||||
$swarmDocker = collect($server->swarmDockers->all());
|
$swarmDocker = collect($server->swarmDockers->all());
|
||||||
return $standaloneDocker->concat($swarmDocker);
|
return $standaloneDocker->concat($swarmDocker);
|
||||||
}
|
}
|
||||||
}
|
}
|
@ -1,3 +1,3 @@
|
|||||||
<?php
|
<?php
|
||||||
|
|
||||||
return '4.0.0-beta.17';
|
return '4.0.0-beta.18';
|
@ -4,7 +4,7 @@
|
|||||||
"version": "3.12.32"
|
"version": "3.12.32"
|
||||||
},
|
},
|
||||||
"v4": {
|
"v4": {
|
||||||
"version": "4.0.0-beta.17"
|
"version": "4.0.0-beta.18"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
Loading…
Reference in New Issue
Block a user