From 901d62567ded012dac9e50cc796eea106e1ab166 Mon Sep 17 00:00:00 2001
From: Pavel Karpy
Date: Thu, 16 Feb 2023 15:33:33 +0300
Subject: [PATCH] [#57] node: Broadcast link objects
It boosts object assembling by an _average_ container node.
Signed-off-by: Pavel Karpy
---
CHANGELOG.md | 1 +
pkg/services/object/put/distributed.go | 5 +++++
2 files changed, 6 insertions(+)
diff --git a/CHANGELOG.md b/CHANGELOG.md
index cc2843adeb..9821edbd09 100644
--- a/CHANGELOG.md
+++ b/CHANGELOG.md
@@ -13,6 +13,7 @@ Changelog for FrostFS Node
### Changed
- `common.PrintVerbose` prints via `cobra.Command.Printf` (#1962)
- Env prefix in configuration changed to `FROSTFS_*` (#43)
+- Link object is broadcast throughout the whole container now (#57)
### Fixed
- Increase payload size metric on shards' `put` operation (#1794)
diff --git a/pkg/services/object/put/distributed.go b/pkg/services/object/put/distributed.go
index 4c3220acf2..40a42a33a1 100644
--- a/pkg/services/object/put/distributed.go
+++ b/pkg/services/object/put/distributed.go
@@ -141,6 +141,11 @@ func (t *distributedTarget) Close() (*transformer.AccessIdentifiers, error) {
return nil, fmt.Errorf("(%T) could not validate payload content: %w", t, err)
}
+ if len(t.obj.Children()) > 0 {
+ // enabling extra broadcast for linking objects
+ t.traversal.extraBroadcastEnabled = true
+ }
+
return t.iteratePlacement(t.sendObject)
}