Commit a99b89e9 authored by Robert May's avatar Robert May

Remove string duplication in BlobStitcher

Concatenates blobs using an array instead, prevents duplicating
large strings in memory.

Changelog: performance
parent 7c36265f
...@@ -19,9 +19,9 @@ module Gitlab ...@@ -19,9 +19,9 @@ module Gitlab
yield new_blob(current_blob_data) if current_blob_data yield new_blob(current_blob_data) if current_blob_data
current_blob_data = msg.to_h.slice(:oid, :path, :size, :revision, :mode) current_blob_data = msg.to_h.slice(:oid, :path, :size, :revision, :mode)
current_blob_data[:data] = msg.data.dup current_blob_data[:data_parts] = [msg.data]
else else
current_blob_data[:data] << msg.data current_blob_data[:data_parts] << msg.data
end end
end end
...@@ -31,6 +31,8 @@ module Gitlab ...@@ -31,6 +31,8 @@ module Gitlab
private private
def new_blob(blob_data) def new_blob(blob_data)
data = blob_data[:data_parts].join
Gitlab::Git::Blob.new( Gitlab::Git::Blob.new(
id: blob_data[:oid], id: blob_data[:oid],
mode: blob_data[:mode].to_s(8), mode: blob_data[:mode].to_s(8),
...@@ -38,8 +40,8 @@ module Gitlab ...@@ -38,8 +40,8 @@ module Gitlab
path: blob_data[:path], path: blob_data[:path],
size: blob_data[:size], size: blob_data[:size],
commit_id: blob_data[:revision], commit_id: blob_data[:revision],
data: blob_data[:data], data: data,
binary: Gitlab::Git::Blob.binary?(blob_data[:data]) binary: Gitlab::Git::Blob.binary?(data)
) )
end end
end end
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment