-
Notifications
You must be signed in to change notification settings - Fork 2.1k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Fixes: #1335 Fixes: #1919 Fixes: #1300 * Clean up of meta files are now started only if block which is being uploaded is older than 2 days (only a mitigation). * Blocks without meta.json are handled properly for all compactor phases. * Prepare for future implementation of https://thanos.io/proposals/201901-read-write-operations-bucket.md/ * Added metric for partialUploadAttempt deletions and delayed it. * More tests. Signed-off-by: Bartlomiej Plotka <[email protected]>
- Loading branch information
Showing
12 changed files
with
273 additions
and
500 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,48 @@ | ||
package compact | ||
|
||
import ( | ||
"context" | ||
"time" | ||
|
||
"github.com/go-kit/kit/log" | ||
"github.com/go-kit/kit/log/level" | ||
"github.com/oklog/ulid" | ||
"github.com/prometheus/client_golang/prometheus" | ||
"github.com/thanos-io/thanos/pkg/block" | ||
"github.com/thanos-io/thanos/pkg/objstore" | ||
) | ||
|
||
const ( | ||
// PartialUploadThresholdAge is a time after partial block is assumed aborted and ready to be cleaned. | ||
// Keep it long as it is based on block creation time not upload start time. | ||
PartialUploadThresholdAge = 2 * 24 * time.Hour | ||
) | ||
|
||
func BestEffortCleanAbortedPartialUploads(ctx context.Context, logger log.Logger, fetcher block.MetadataFetcher, bkt objstore.Bucket, deleteAttempts prometheus.Counter) { | ||
level.Info(logger).Log("msg", "started cleaning of aborted partial uploads") | ||
_, partial, err := fetcher.Fetch(ctx) | ||
if err != nil { | ||
level.Warn(logger).Log("msg", "failed to fetch metadata for cleaning of aborted partial uploads; skipping", "err", err) | ||
} | ||
|
||
// Delete partial blocks that are older than partialUploadThresholdAge. | ||
// TODO(bwplotka): This is can cause data loss if blocks are: | ||
// * being uploaded longer than partialUploadThresholdAge | ||
// * being uploaded and started after their partialUploadThresholdAge | ||
// can be assumed in this case. Keep partialUploadThresholdAge long for now. | ||
// Mitigate this by adding ModifiedTime to bkt and check that instead of ULID (block creation time). | ||
for id := range partial { | ||
if ulid.Now()-id.Time() <= uint64(PartialUploadThresholdAge/time.Millisecond) { | ||
// Minimum delay has not expired, ignore for now. | ||
continue | ||
} | ||
|
||
deleteAttempts.Inc() | ||
if err := block.Delete(ctx, logger, bkt, id); err != nil { | ||
level.Warn(logger).Log("msg", "failed to delete aborted partial upload; skipping", "block", id, "thresholdAge", PartialUploadThresholdAge, "err", err) | ||
return | ||
} | ||
level.Info(logger).Log("msg", "deleted aborted partial upload", "block", id, "thresholdAge", PartialUploadThresholdAge) | ||
} | ||
level.Info(logger).Log("msg", "cleaning of aborted partial uploads done") | ||
} |
Oops, something went wrong.