Skip to content
项目
群组
代码片段
帮助
当前项目
正在载入...
登录 / 注册
切换导航面板
Z
ZLMediaKit
概览
Overview
Details
Activity
Cycle Analytics
版本库
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
问题
0
Issues
0
列表
Board
标记
里程碑
合并请求
0
Merge Requests
0
CI / CD
CI / CD
流水线
作业
日程表
图表
维基
Wiki
代码片段
Snippets
成员
Collapse sidebar
Close sidebar
活动
图像
聊天
创建新问题
作业
提交
Issue Boards
Open sidebar
张翔宇
ZLMediaKit
Commits
272eca12
Commit
272eca12
authored
Jun 18, 2022
by
xiongziliang
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
hook重试新增延时功能
parent
06f5bda8
隐藏空白字符变更
内嵌
并排
正在显示
2 个修改的文件
包含
37 行增加
和
33 行删除
+37
-33
conf/config.ini
+4
-2
server/WebHook.cpp
+33
-31
没有找到文件。
conf/config.ini
查看文件 @
272eca12
...
...
@@ -157,8 +157,10 @@ on_server_keepalive=https://127.0.0.1/index/hook/on_server_keepalive
timeoutSec
=
10
#keepalive hook触发间隔,单位秒,float类型
alive_interval
=
10.0
#hook通知重试次数
retry
=
2
#hook通知失败重试次数,正整数。为0不重试,1时重试一次,以此类推
retry
=
1
#hook通知失败重试延时,单位秒,float型
retry_delay
=
3.0
[cluster]
#设置源站拉流url模板, 格式跟printf类似,第一个%s指定app,第二个%s指定stream_id,
...
...
server/WebHook.cpp
查看文件 @
272eca12
/*
/*
* Copyright (c) 2016 The ZLMediaKit project authors. All Rights Reserved.
*
* This file is part of ZLMediaKit(https://github.com/xia-chu/ZLMediaKit).
...
...
@@ -48,6 +48,7 @@ const string kOnServerKeepalive = HOOK_FIELD"on_server_keepalive";
const
string
kAdminParams
=
HOOK_FIELD
"admin_params"
;
const
string
kAliveInterval
=
HOOK_FIELD
"alive_interval"
;
const
string
kRetry
=
HOOK_FIELD
"retry"
;
const
string
kRetryDelay
=
HOOK_FIELD
"retry_delay"
;
onceToken
token
([](){
mINI
::
Instance
()[
kEnable
]
=
false
;
...
...
@@ -69,8 +70,8 @@ onceToken token([](){
mINI
::
Instance
()[
kOnServerKeepalive
]
=
""
;
mINI
::
Instance
()[
kAdminParams
]
=
"secret=035c73f7-bb6b-4889-a715-d9eb2d1925cc"
;
mINI
::
Instance
()[
kAliveInterval
]
=
30.0
;
mINI
::
Instance
()[
kRetry
]
=
0
;
mINI
::
Instance
()[
kRetry
]
=
1
;
mINI
::
Instance
()[
kRetryDelay
]
=
3.0
;
},
nullptr
);
}
//namespace Hook
...
...
@@ -88,8 +89,6 @@ static onceToken token([]() {
}
//namespace Cluster
void
do_http_process
(
HttpRequester
::
Ptr
&
requester
,
const
string
&
url
,
const
string
&
bodyStr
,
const
function
<
void
(
const
Value
&
,
const
string
&
)
>
&
func
,
int
retry
,
float
timeout_sec
);
static
void
parse_http_response
(
const
SockException
&
ex
,
const
Parser
&
res
,
const
function
<
void
(
const
Value
&
,
const
string
&
)
>
&
fun
){
if
(
ex
)
{
...
...
@@ -152,10 +151,10 @@ string getVhost(const HttpArgs &value) {
return
val
!=
value
.
end
()
?
val
->
second
:
""
;
}
void
do_http_hook
(
const
string
&
url
,
const
ArgsType
&
body
,
const
function
<
void
(
const
Value
&
,
const
string
&
)
>
&
func
)
{
void
do_http_hook
(
const
string
&
url
,
const
ArgsType
&
body
,
const
function
<
void
(
const
Value
&
,
const
string
&
)
>
&
func
,
uint32_t
retry
)
{
GET_CONFIG
(
string
,
mediaServerId
,
General
::
kMediaServerId
);
GET_CONFIG
(
float
,
hook_timeoutSec
,
Hook
::
kTimeoutSec
);
GET_CONFIG
(
int
,
hook_retry
,
Hook
::
kRetr
y
);
GET_CONFIG
(
float
,
retry_delay
,
Hook
::
kRetryDela
y
);
const_cast
<
ArgsType
&>
(
body
)[
"mediaServerId"
]
=
mediaServerId
;
HttpRequester
::
Ptr
requester
(
new
HttpRequester
);
...
...
@@ -167,35 +166,38 @@ void do_http_hook(const string &url,const ArgsType &body,const function<void(con
if
(
!
vhost
.
empty
())
{
requester
->
addHeader
(
"X-VHOST"
,
vhost
);
}
do_http_process
(
requester
,
url
,
bodyStr
,
func
,
hook_retry
,
hook_timeoutSec
);
}
Ticker
ticker
;
requester
->
startRequester
(
url
,
[
url
,
func
,
bodyStr
,
body
,
requester
,
ticker
,
retry
](
const
SockException
&
ex
,
const
Parser
&
res
)
mutable
{
onceToken
token
(
nullptr
,
[
&
]()
mutable
{
requester
.
reset
();
});
parse_http_response
(
ex
,
res
,
[
&
](
const
Value
&
obj
,
const
string
&
err
)
{
if
(
!
err
.
empty
())
{
// hook失败
WarnL
<<
"hook "
<<
url
<<
" "
<<
ticker
.
elapsedTime
()
<<
"ms,failed"
<<
err
<<
":"
<<
bodyStr
;
if
(
retry
--
>
0
)
{
requester
->
getPoller
()
->
doDelayTask
(
MAX
(
retry_delay
,
0.0
)
*
1000
,
[
url
,
body
,
func
,
retry
]
{
do_http_hook
(
url
,
body
,
func
,
retry
);
return
0
;
});
//重试不需要触发回调
return
;
}
}
else
if
(
ticker
.
elapsedTime
()
>
500
)
{
//hook成功,但是hook响应超过500ms,打印警告日志
DebugL
<<
"hook "
<<
url
<<
" "
<<
ticker
.
elapsedTime
()
<<
"ms,success:"
<<
bodyStr
;
}
void
do_http_process
(
HttpRequester
::
Ptr
&
requester
,
const
string
&
url
,
const
string
&
bodyStr
,
const
function
<
void
(
const
Value
&
,
const
string
&
)
>
&
func
,
int
retry
,
float
timeout_sec
){
std
::
shared_ptr
<
Ticker
>
pTicker
(
new
Ticker
);
requester
->
startRequester
(
url
,
[
url
,
func
,
bodyStr
,
requester
,
pTicker
,
retry
,
timeout_sec
](
const
SockException
&
ex
,
const
Parser
&
res
)
mutable
{
onceToken
token
(
nullptr
,
[
&
]()
mutable
{
requester
.
reset
();
});
parse_http_response
(
ex
,
res
,
[
&
](
const
Value
&
obj
,
const
string
&
err
)
{
if
(
func
)
{
func
(
obj
,
err
);
}
if
(
!
err
.
empty
())
{
WarnL
<<
"hook "
<<
url
<<
" "
<<
pTicker
->
elapsedTime
()
<<
"ms,failed"
<<
err
<<
":"
<<
bodyStr
;
}
else
if
(
pTicker
->
elapsedTime
()
>
500
)
{
DebugL
<<
"hook "
<<
url
<<
" "
<<
pTicker
->
elapsedTime
()
<<
"ms,success:"
<<
bodyStr
;
}
//尾部递归重试
if
(
!
err
.
empty
()
&&
retry
--
>
0
)
{
//WarnL << "----------------hook retry------------------ " << retry ;
HttpRequester
::
Ptr
requester
(
new
HttpRequester
);
do_http_process
(
requester
,
url
,
bodyStr
,
func
,
retry
,
timeout_sec
);
}
});
},
timeout_sec
);
},
hook_timeoutSec
);
}
void
do_http_hook
(
const
string
&
url
,
const
ArgsType
&
body
,
const
function
<
void
(
const
Value
&
,
const
string
&
)
>
&
func
)
{
GET_CONFIG
(
uint32_t
,
hook_retry
,
Hook
::
kRetry
);
do_http_hook
(
url
,
body
,
func
,
hook_retry
);
}
static
ArgsType
make_json
(
const
MediaInfo
&
args
){
...
...
编写
预览
Markdown
格式
0%
重试
或
添加新文件
添加附件
取消
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论