Skip to content
This repository has been archived by the owner on Oct 9, 2023. It is now read-only.

Commit

Permalink
Remove shard prefix from upload location (#489)
Browse files Browse the repository at this point in the history
Signed-off-by: Manuel Rombach <[email protected]>

Signed-off-by: Manuel Rombach <[email protected]>
  • Loading branch information
manuelrombach authored Nov 15, 2022
1 parent 4cc2381 commit 0e1cc8b
Show file tree
Hide file tree
Showing 2 changed files with 8 additions and 22 deletions.
21 changes: 5 additions & 16 deletions dataproxy/service.go
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,6 @@ import (
"encoding/base64"
"fmt"
"net/url"
"strings"
"time"

"github.com/flyteorg/flyteplugins/go/tasks/pluginmachinery/ioutils"
Expand Down Expand Up @@ -64,7 +63,7 @@ func (s Service) CreateUploadLocation(ctx context.Context, req *service.CreateUp
md5 := base64.StdEncoding.EncodeToString(req.ContentMd5)
urlSafeMd5 := base32.StdEncoding.EncodeToString(req.ContentMd5)

storagePath, err := createShardedStorageLocation(ctx, s.shardSelector, s.dataStore, s.cfg.Upload,
storagePath, err := createStorageLocation(ctx, s.dataStore, s.cfg.Upload,
req.Project, req.Domain, urlSafeMd5, req.Filename)
if err != nil {
return nil, err
Expand Down Expand Up @@ -135,23 +134,13 @@ func (s Service) validateCreateDownloadLocationRequest(req *service.CreateDownlo
return nil
}

// createShardedStorageLocation creates a location in storage destination to maximize read/write performance in most
// block stores. The final location should look something like: s3://<my bucket>/<shard length>/<file name>
func createShardedStorageLocation(ctx context.Context, shardSelector ioutils.ShardSelector, store *storage.DataStore,
// createStorageLocation creates a location in storage destination to maximize read/write performance in most
// block stores. The final location should look something like: s3://<my bucket>/<file name>
func createStorageLocation(ctx context.Context, store *storage.DataStore,
cfg config.DataProxyUploadConfig, keyParts ...string) (storage.DataReference, error) {
keySuffixArr := make([]string, 0, 4)
if len(cfg.StoragePrefix) > 0 {
keySuffixArr = append(keySuffixArr, cfg.StoragePrefix)
}

keySuffixArr = append(keySuffixArr, keyParts...)
prefix, err := shardSelector.GetShardPrefix(ctx, []byte(strings.Join(keySuffixArr, "/")))
if err != nil {
return "", err
}

storagePath, err := store.ConstructReference(ctx, store.GetBaseContainerFQN(ctx),
append([]string{prefix}, keySuffixArr...)...)
append([]string{cfg.StoragePrefix}, keyParts...)...)
if err != nil {
return "", fmt.Errorf("failed to construct datastore reference. Error: %w", err)
}
Expand Down
9 changes: 3 additions & 6 deletions dataproxy/service_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -14,7 +14,6 @@ import (
"github.com/flyteorg/flytestdlib/promutils/labeled"

"github.com/flyteorg/flyteidl/gen/pb-go/flyteidl/service"
"github.com/flyteorg/flyteplugins/go/tasks/pluginmachinery/ioutils"

"github.com/flyteorg/flyteadmin/pkg/config"
"github.com/flyteorg/flytestdlib/promutils"
Expand All @@ -36,16 +35,14 @@ func init() {
labeled.SetMetricKeys(contextutils.DomainKey)
}

func Test_createShardedStorageLocation(t *testing.T) {
selector, err := ioutils.NewBase36PrefixShardSelector(context.TODO())
assert.NoError(t, err)
func Test_createStorageLocation(t *testing.T) {
dataStore, err := storage.NewDataStore(&storage.Config{Type: storage.TypeMemory}, promutils.NewTestScope())
assert.NoError(t, err)
loc, err := createShardedStorageLocation(context.Background(), selector, dataStore, config.DataProxyUploadConfig{
loc, err := createStorageLocation(context.Background(), dataStore, config.DataProxyUploadConfig{
StoragePrefix: "blah",
})
assert.NoError(t, err)
assert.Equal(t, "/u8/blah", loc.String())
assert.Equal(t, "/blah", loc.String())
}

func TestCreateUploadLocation(t *testing.T) {
Expand Down

0 comments on commit 0e1cc8b

Please sign in to comment.