Compare commits

..

2 Commits

Author SHA1 Message Date
rony5394
ef37f17378 Added more proper waiting mechanism. 2026-05-24 13:13:27 +02:00
rony5394
778bab644f Switched originalScale storage 2026-05-19 14:20:22 +02:00
4 changed files with 66 additions and 16 deletions

View File

@@ -5,6 +5,7 @@ import (
"encoding/json"
"errors"
"os"
"time"
"github.com/docker/docker/api/types/registry"
);
@@ -24,6 +25,7 @@ type Config struct {
HelperServiceName string
StorageContainerName string
PrepullImageServiceName string
ServiceScaleTimeout time.Duration
}
}
@@ -45,6 +47,7 @@ func GetConfig()(Config, error){
cfg.Constants.HelperServiceName = "blazenaHelper";
cfg.Constants.StorageContainerName = "blazenaStorage";
cfg.Constants.PrepullImageServiceName = "blazenaPrepull";
cfg.Constants.ServiceScaleTimeout = time.Second * 15;
err = json.Unmarshal(rawConfig, &cfg);

View File

@@ -8,7 +8,6 @@ import (
"os"
"os/signal"
"strings"
"sync"
"syscall"
"time"
@@ -23,7 +22,6 @@ import (
// Add mutex.
var ApiClient *client.Client;
var scale sync.Map;
var token string = "12345";
var theConfig cfg.Config;

View File

@@ -3,7 +3,10 @@ package docker
import (
"context"
"io"
"log/slog"
"net/http"
"os"
"strconv"
"time"
"encoding/json"
@@ -53,16 +56,16 @@ func scaleDown(w http.ResponseWriter, r *http.Request){
newScale := uint64(0);
updatedSpec.Mode.Replicated.Replicas = &newScale;
updatedSpec.Labels["blazena.scaledDown"] = "true";
scale.Store(serviceId, *originalScale);
updatedSpec.Labels["blazena.originalScale"] = strconv.FormatUint(*originalScale, 10);
_, err = ApiClient.ServiceUpdate(context.Background(), serviceId, inspectresoult.Version, updatedSpec, swarm.ServiceUpdateOptions{});
if(err != nil){
panic("Failed to update service."+ err.Error());
}
ctx, cancel := context.WithTimeout(context.Background(), theConfig.Constants.ServiceScaleTimeout);
defer cancel();
//TODO: Add proper wait system
time.Sleep(15 * time.Second);
waitForScale(serviceId, ctx, 0);
}
func scaleUp(w http.ResponseWriter, r *http.Request){
@@ -99,22 +102,62 @@ func scaleUp(w http.ResponseWriter, r *http.Request){
return;
}
originalScale, ok := scale.Load(serviceId);
if(!ok){
originalScale := inspectresoult.Spec.Labels["blazena.originalScale"];
if(originalScale == ""){
panic("Its not okay!");
}
originalScaleChecked, ok := originalScale.(uint64);
if(!ok){
panic("Its very not okay!")
originalScaleChecked, err := strconv.ParseUint(originalScale, 10, 64);
if(err != nil){
panic("Its very not okay!"+ err.Error())
}
updatedSpec := inspectresoult.Spec;
updatedSpec.Mode.Replicated.Replicas = &originalScaleChecked;
delete(updatedSpec.Labels, "blazena.scaledDown");
delete(updatedSpec.Labels, "blazena.originalScale");
ApiClient.ServiceUpdate(context.Background(), serviceId, inspectresoult.Version, updatedSpec, swarm.ServiceUpdateOptions{});
//TODO: Add proper wait system
time.Sleep(15 * time.Second);
ctx, cancel := context.WithTimeout(context.Background(), theConfig.Constants.ServiceScaleTimeout);
defer cancel();
waitForScale(serviceId, ctx, int(originalScaleChecked));
}
func waitForScale(serviceId string, ctx context.Context, desiredCount int){
startTime := time.Now();
for ctx.Err() == nil {
tasks, err := ApiClient.TaskList(context.Background(), swarm.TaskListOptions{});
if err != nil {
slog.Error("Failed to list tasks.", slog.Any("propagatedError", err));
os.Exit(1);
}
var running int;
for _, task := range tasks {
if task.ServiceID != serviceId {
continue;
}
if task.Status.State == swarm.TaskStateRunning{
running ++;
}
}
if running == desiredCount {
slog.Debug("Rescaled Service",
slog.String("serviceId", serviceId),
slog.Any("took", time.Since(startTime)),
slog.Any("targetScale", desiredCount),
);
return;
}
time.Sleep(1*time.Second);
}
if ctx.Err() == context.DeadlineExceeded{
slog.Error("Failed to rescale service in given time.", slog.Any("serviceId", serviceId));
}
}

12
main.go
View File

@@ -1,12 +1,14 @@
package main
import (
"log/slog"
"os"
"time"
cfg "github.com/rony5394/blazena/config"
"github.com/rony5394/blazena/docker"
"github.com/rony5394/blazena/host"
cfg "github.com/rony5394/blazena/config"
"log/slog"
);
)
/*
If the exit code is X then it means Y:
@@ -39,6 +41,8 @@ func main() {
slog.Debug("Config", slog.Any("Value", config));
startTime := time.Now();
mode := os.Args[1];
switch mode {
case "docker":
@@ -53,4 +57,6 @@ func main() {
default:
panic("Invalid runtime mode!");
}
slog.Debug("Whole run took", slog.String("time", time.Since(startTime).String()));
}