use LimitGroup for uploads
This commit is contained in:
parent
074934be03
commit
bea007deb7
1 changed files with 31 additions and 3 deletions
|
@ -18,7 +18,6 @@ import (
|
||||||
|
|
||||||
"github.com/jmorganca/ollama/api"
|
"github.com/jmorganca/ollama/api"
|
||||||
"github.com/jmorganca/ollama/format"
|
"github.com/jmorganca/ollama/format"
|
||||||
"golang.org/x/sync/errgroup"
|
|
||||||
)
|
)
|
||||||
|
|
||||||
var blobUploadManager sync.Map
|
var blobUploadManager sync.Map
|
||||||
|
@ -137,8 +136,37 @@ func (b *blobUpload) Run(ctx context.Context, opts *registryOptions) {
|
||||||
}
|
}
|
||||||
defer b.file.Close()
|
defer b.file.Close()
|
||||||
|
|
||||||
g, inner := errgroup.WithContext(ctx)
|
g, inner := NewLimitGroup(ctx, numUploadParts)
|
||||||
g.SetLimit(numUploadParts)
|
|
||||||
|
go func() {
|
||||||
|
ticker := time.NewTicker(time.Second)
|
||||||
|
var n int64 = 1
|
||||||
|
var maxDelta float64
|
||||||
|
var buckets []int64
|
||||||
|
for {
|
||||||
|
select {
|
||||||
|
case <-ticker.C:
|
||||||
|
buckets = append(buckets, b.Completed.Load())
|
||||||
|
if len(buckets) < 2 {
|
||||||
|
continue
|
||||||
|
} else if len(buckets) > 10 {
|
||||||
|
buckets = buckets[1:]
|
||||||
|
}
|
||||||
|
|
||||||
|
delta := float64((buckets[len(buckets)-1] - buckets[0])) / float64(len(buckets))
|
||||||
|
slog.Debug(fmt.Sprintf("delta: %s/s max_delta: %s/s", format.HumanBytes(int64(delta)), format.HumanBytes(int64(maxDelta))))
|
||||||
|
if delta > maxDelta*1.5 {
|
||||||
|
maxDelta = delta
|
||||||
|
g.SetLimit(n)
|
||||||
|
n++
|
||||||
|
}
|
||||||
|
|
||||||
|
case <-ctx.Done():
|
||||||
|
return
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}()
|
||||||
|
|
||||||
for i := range b.Parts {
|
for i := range b.Parts {
|
||||||
part := &b.Parts[i]
|
part := &b.Parts[i]
|
||||||
select {
|
select {
|
||||||
|
|
Loading…
Reference in a new issue