Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
Turbo码先生
redis
提交
828736e7
R
redis
项目概览
Turbo码先生
/
redis
与 Fork 源项目一致
从无法访问的项目Fork
通知
1
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
R
redis
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
未验证
提交
828736e7
编写于
4月 27, 2020
作者:
S
Salvatore Sanfilippo
提交者:
GitHub
4月 27, 2020
浏览文件
操作
浏览文件
下载
差异文件
Merge pull request #7146 from oranagra/optimize_deferred_reply
optimize memory usage of deferred replies
上级
4447ddc8
fb732f7a
变更
1
显示空白变更内容
内联
并排
Showing
1 changed file
with
31 addition
and
0 deletion
+31
-0
src/networking.c
src/networking.c
+31
-0
未找到文件。
src/networking.c
浏览文件 @
828736e7
...
...
@@ -436,6 +436,36 @@ void addReplyStatusFormat(client *c, const char *fmt, ...) {
sdsfree
(
s
);
}
/* Sometimes we are forced to create a new reply node, and we can't append to
* the previous one, when that happens, we wanna try to trim the unused space
* at the end of the last reply node which we won't use anymore. */
void
trimReplyUnusedTailSpace
(
client
*
c
)
{
listNode
*
ln
=
listLast
(
c
->
reply
);
clientReplyBlock
*
tail
=
ln
?
listNodeValue
(
ln
)
:
NULL
;
/* Note that 'tail' may be NULL even if we have a tail node, becuase when
* addDeferredMultiBulkLength() is used */
if
(
!
tail
)
return
;
/* We only try to trim the space is relatively high (more than a 1/4 of the
* allocation), otherwise there's a high chance realloc will NOP.
* Also, to avoid large memmove which happens as part of realloc, we only do
* that if the used part is small. */
if
(
tail
->
size
-
tail
->
used
>
tail
->
size
/
4
&&
tail
->
used
<
PROTO_REPLY_CHUNK_BYTES
)
{
size_t
old_size
=
tail
->
size
;
tail
=
zrealloc
(
tail
,
tail
->
used
+
sizeof
(
clientReplyBlock
));
/* If realloc was a NOP, we got the same value which has internal frag */
if
(
tail
==
listNodeValue
(
ln
))
return
;
/* take over the allocation's internal fragmentation (at least for
* memory usage tracking) */
tail
->
size
=
zmalloc_usable
(
tail
)
-
sizeof
(
clientReplyBlock
);
c
->
reply_bytes
+=
tail
->
size
-
old_size
;
listNodeValue
(
ln
)
=
tail
;
}
}
/* Adds an empty object to the reply list that will contain the multi bulk
* length, which is not known when this function is called. */
void
*
addReplyDeferredLen
(
client
*
c
)
{
...
...
@@ -443,6 +473,7 @@ void *addReplyDeferredLen(client *c) {
* ready to be sent, since we are sure that before returning to the
* event loop setDeferredAggregateLen() will be called. */
if
(
prepareClientToWrite
(
c
)
!=
C_OK
)
return
NULL
;
trimReplyUnusedTailSpace
(
c
);
listAddNodeTail
(
c
->
reply
,
NULL
);
/* NULL is our placeholder. */
return
listLast
(
c
->
reply
);
}
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录