Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
hanoi2005
redis
提交
e1e8b1cd
R
redis
项目概览
hanoi2005
/
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,发现更多精彩内容 >>
提交
e1e8b1cd
编写于
2月 08, 2013
作者:
A
antirez
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Set SO_KEEPALIVE on client sockets if configured to do so.
上级
609a3ec1
变更
4
隐藏空白更改
内联
并排
Showing
4 changed file
with
14 addition
and
0 deletion
+14
-0
src/config.c
src/config.c
+10
-0
src/networking.c
src/networking.c
+2
-0
src/redis.c
src/redis.c
+1
-0
src/redis.h
src/redis.h
+1
-0
未找到文件。
src/config.c
浏览文件 @
e1e8b1cd
...
...
@@ -81,6 +81,11 @@ void loadServerConfigFromString(char *config) {
if
(
server
.
maxidletime
<
0
)
{
err
=
"Invalid timeout value"
;
goto
loaderr
;
}
}
else
if
(
!
strcasecmp
(
argv
[
0
],
"tcp-keepalive"
)
&&
argc
==
2
)
{
server
.
tcpkeepalive
=
atoi
(
argv
[
1
]);
if
(
server
.
tcpkeepalive
<
0
)
{
err
=
"Invalid tcp-keepalive value"
;
goto
loaderr
;
}
}
else
if
(
!
strcasecmp
(
argv
[
0
],
"port"
)
&&
argc
==
2
)
{
server
.
port
=
atoi
(
argv
[
1
]);
if
(
server
.
port
<
0
||
server
.
port
>
65535
)
{
...
...
@@ -503,6 +508,10 @@ void configSetCommand(redisClient *c) {
if
(
getLongLongFromObject
(
o
,
&
ll
)
==
REDIS_ERR
||
ll
<
0
||
ll
>
LONG_MAX
)
goto
badfmt
;
server
.
maxidletime
=
ll
;
}
else
if
(
!
strcasecmp
(
c
->
argv
[
2
]
->
ptr
,
"tcp-keepalive"
))
{
if
(
getLongLongFromObject
(
o
,
&
ll
)
==
REDIS_ERR
||
ll
<
0
||
ll
>
INT_MAX
)
goto
badfmt
;
server
.
tcpkeepalive
=
ll
;
}
else
if
(
!
strcasecmp
(
c
->
argv
[
2
]
->
ptr
,
"appendfsync"
))
{
if
(
!
strcasecmp
(
o
->
ptr
,
"no"
))
{
server
.
aof_fsync
=
AOF_FSYNC_NO
;
...
...
@@ -770,6 +779,7 @@ void configGetCommand(redisClient *c) {
config_get_numerical_field
(
"maxmemory"
,
server
.
maxmemory
);
config_get_numerical_field
(
"maxmemory-samples"
,
server
.
maxmemory_samples
);
config_get_numerical_field
(
"timeout"
,
server
.
maxidletime
);
config_get_numerical_field
(
"tcp-keepalive"
,
server
.
tcpkeepalive
);
config_get_numerical_field
(
"auto-aof-rewrite-percentage"
,
server
.
aof_rewrite_perc
);
config_get_numerical_field
(
"auto-aof-rewrite-min-size"
,
...
...
src/networking.c
浏览文件 @
e1e8b1cd
...
...
@@ -59,6 +59,8 @@ redisClient *createClient(int fd) {
if
(
fd
!=
-
1
)
{
anetNonBlock
(
NULL
,
fd
);
anetEnableTcpNoDelay
(
NULL
,
fd
);
if
(
server
.
tcpkeepalive
)
anetKeepAlive
(
NULL
,
fd
,
server
.
tcpkeepalive
);
if
(
aeCreateFileEvent
(
server
.
el
,
fd
,
AE_READABLE
,
readQueryFromClient
,
c
)
==
AE_ERR
)
{
...
...
src/redis.c
浏览文件 @
e1e8b1cd
...
...
@@ -1094,6 +1094,7 @@ void initServerConfig() {
server
.
dbnum
=
REDIS_DEFAULT_DBNUM
;
server
.
verbosity
=
REDIS_NOTICE
;
server
.
maxidletime
=
REDIS_MAXIDLETIME
;
server
.
tcpkeepalive
=
0
;
server
.
client_max_querybuf_len
=
REDIS_MAX_QUERYBUF_LEN
;
server
.
saveparams
=
NULL
;
server
.
loading
=
0
;
...
...
src/redis.h
浏览文件 @
e1e8b1cd
...
...
@@ -551,6 +551,7 @@ struct redisServer {
/* Configuration */
int
verbosity
;
/* Loglevel in redis.conf */
int
maxidletime
;
/* Client timeout in seconds */
int
tcpkeepalive
;
/* Set SO_KEEPALIVE if non-zero. */
size_t
client_max_querybuf_len
;
/* Limit for client query buffer length */
int
dbnum
;
/* Total number of configured DBs */
int
daemonize
;
/* True if running as a daemon */
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录