Skip to content

Commit

Permalink
Merge pull request #197 from inovex/gc-after-auth
Browse files Browse the repository at this point in the history
Explicitly run garbage collection after loading credentials
  • Loading branch information
MichaelEischer authored Jan 7, 2025
2 parents 313a29a + eeb4da5 commit 8b8c93f
Showing 1 changed file with 7 additions and 0 deletions.
7 changes: 7 additions & 0 deletions cmd/calendarsync/main.go
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,7 @@ package main
import (
"fmt"
"os"
"runtime"
"time"

"github.com/inovex/CalendarSync/internal/auth"
Expand Down Expand Up @@ -180,6 +181,12 @@ func Run(c *cli.Context) error {
}
log.Info("loaded sink adapter", "adapter", cfg.Sink.Adapter.Type, "calendar", cfg.Sink.Adapter.Calendar)

// By default go runs a garbage collection once the memory usage doubles compared to the last GC run.
// Decrypting the storage in NewSourceAdapterFromConfig/NewSinkAdapterFromConfig requires a lot of memory,
// such that the next GC only trigger once the memory usage double compared to that peak. Explicitly trigger
// a GC to reset the memory usage reference level.
runtime.GC()

if log.GetLevel() == log.DebugLevel {
for _, transformation := range cfg.Transformations {
log.Debug("configured transformer", "name", transformation.Name, "config", transformation.Config)
Expand Down

0 comments on commit 8b8c93f

Please sign in to comment.