From 1658242e00f7afc2e2c89355fdcdfb225eb12208 Mon Sep 17 00:00:00 2001 From: Pavel Karpy Date: Thu, 7 Jul 2022 18:05:50 +0300 Subject: [PATCH] [#1590] node: Smart memory allocation in `GetRange` Allocate memory only if a node chosen as the forwarded request receiver has responded with a successful status. Signed-off-by: Pavel Karpy --- CHANGELOG.md | 1 + pkg/services/object/get/v2/util.go | 7 ++++++- 2 files changed, 7 insertions(+), 1 deletion(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index a6f0962142..4934da5d85 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -14,6 +14,7 @@ Changelog for NeoFS Node - Do not replicate object twice to the same node (#1410) - Concurrent object handling by the Policer (#1411) - Attaching API version to the forwarded requests (#1581) +- Node OOM panics on `GetRange` request with extremely huge range length (#1590) ### Removed diff --git a/pkg/services/object/get/v2/util.go b/pkg/services/object/get/v2/util.go index 01c5ce47cc..7ab7fd0384 100644 --- a/pkg/services/object/get/v2/util.go +++ b/pkg/services/object/get/v2/util.go @@ -250,7 +250,8 @@ func (s *Service) toRangePrm(req *objectV2.GetRangeRequest, stream objectSvc.Get return nil, fmt.Errorf("could not create Get payload range stream: %w", err) } - payload := make([]byte, 0, body.GetRange().GetLength()) + // allocate memory only after receiving a successful response + var payload []byte resp := new(objectV2.GetRangeResponse) @@ -283,6 +284,10 @@ func (s *Service) toRangePrm(req *objectV2.GetRangeRequest, stream objectSvc.Get case nil: return nil, fmt.Errorf("unexpected range type %T", v) case *objectV2.GetRangePartChunk: + if payload == nil { + payload = make([]byte, 0, body.GetRange().GetLength()) + } + payload = append(payload, v.GetChunk()...) case *objectV2.SplitInfo: si := object.NewSplitInfoFromV2(v)