Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
SkyAPM
SkyAPM-php-sdk
提交
2d572800
S
SkyAPM-php-sdk
项目概览
SkyAPM
/
SkyAPM-php-sdk
通知
14
Star
1
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
S
SkyAPM-php-sdk
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
2d572800
编写于
8月 07, 2019
作者:
H
heyanlong
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
fix predis
上级
10172501
变更
1
显示空白变更内容
内联
并排
Showing
1 changed file
with
46 addition
and
70 deletion
+46
-70
skywalking.c
skywalking.c
+46
-70
未找到文件。
skywalking.c
浏览文件 @
2d572800
...
...
@@ -26,6 +26,7 @@
#include "main/SAPI.h"
/* for sapi_module */
#include "zend_smart_str.h"
/* for smart_str */
#include <zend_interfaces.h>
#include "php.h"
#include "php_ini.h"
#include "ext/standard/info.h"
...
...
@@ -102,7 +103,6 @@ PHP_FUNCTION(skywalking_get_trace_info)
array_init
(
&
empty
);
RETURN_ZVAL
(
&
empty
,
0
,
1
);
}
// return array
RETURN_ZVAL
(
&
SKYWALKING_G
(
UpstreamSegment
),
1
,
0
)
}
...
...
@@ -168,18 +168,22 @@ ZEND_API void sky_execute_ex(zend_execute_data *execute_data) {
char
*
operationName
=
NULL
;
if
(
class_name
!=
NULL
)
{
if
(
strcmp
(
class_name
,
"Predis
\\
Client"
)
==
0
&&
strcmp
(
function_name
,
"
__call
"
)
==
0
)
{
if
(
strcmp
(
class_name
,
"Predis
\\
Client"
)
==
0
&&
strcmp
(
function_name
,
"
executeCommand
"
)
==
0
)
{
// params
uint32_t
arg_count
=
ZEND_CALL_NUM_ARGS
(
execute_data
);
if
(
arg_count
)
{
zval
*
p
=
ZEND_CALL_ARG
(
execute_data
,
1
);
if
(
Z_TYPE_P
(
p
)
==
IS_STRING
)
{
operationName
=
(
char
*
)
emalloc
(
strlen
(
class_name
)
+
strlen
(
Z_STRVAL_P
(
p
))
+
3
);
zval
*
id
=
(
zval
*
)
emalloc
(
sizeof
(
zval
));
zend_call_method
(
p
,
Z_OBJCE_P
(
p
),
NULL
,
ZEND_STRL
(
"getid"
),
id
,
0
,
NULL
,
NULL
);
if
(
Z_TYPE_P
(
id
)
==
IS_STRING
)
{
operationName
=
(
char
*
)
emalloc
(
strlen
(
class_name
)
+
strlen
(
Z_STRVAL_P
(
id
))
+
3
);
strcpy
(
operationName
,
class_name
);
strcat
(
operationName
,
"->"
);
strcat
(
operationName
,
Z_STRVAL_P
(
p
));
strcat
(
operationName
,
Z_STRVAL_P
(
id
));
}
efree
(
id
);
}
}
}
...
...
@@ -188,77 +192,49 @@ ZEND_API void sky_execute_ex(zend_execute_data *execute_data) {
zval
tags
;
array_init
(
&
tags
);
if
(
strcmp
(
class_name
,
"Predis
\\
Client"
)
==
0
&&
strcmp
(
function_name
,
"
__call
"
)
==
0
)
{
if
(
strcmp
(
class_name
,
"Predis
\\
Client"
)
==
0
&&
strcmp
(
function_name
,
"
executeCommand
"
)
==
0
)
{
add_assoc_string
(
&
tags
,
"db.type"
,
"redis"
);
uint32_t
arg_count
=
ZEND_CALL_NUM_ARGS
(
execute_data
);
zval
*
fname
=
ZEND_CALL_ARG
(
execute_data
,
1
);
int
i
;
for
(
i
=
1
;
i
<
arg_count
+
1
;
++
i
)
{
if
(
i
==
1
)
{
continue
;
}
zval
*
pam
=
ZEND_CALL_ARG
(
execute_data
,
i
);
if
(
Z_TYPE_P
(
pam
)
==
IS_ARRAY
)
{
zval
*
p
=
ZEND_CALL_ARG
(
execute_data
,
1
);
zval
*
id
=
(
zval
*
)
emalloc
(
sizeof
(
zval
));
zval
*
arguments
=
(
zval
*
)
emalloc
(
sizeof
(
zval
));
zend_call_method
(
p
,
Z_OBJCE_P
(
p
),
NULL
,
ZEND_STRL
(
"getid"
),
id
,
0
,
NULL
,
NULL
);
zend_call_method
(
p
,
Z_OBJCE_P
(
p
),
NULL
,
ZEND_STRL
(
"getarguments"
),
arguments
,
0
,
NULL
,
NULL
);
if
(
Z_TYPE_P
(
arguments
)
==
IS_ARRAY
)
{
zend_ulong
num_key
;
zval
*
entry
;
int
is_string_command
=
0
;
smart_str
command
=
{
0
};
ZEND_HASH_FOREACH_NUM_KEY_VAL
(
Z_ARRVAL_P
(
pam
),
num_key
,
entry
)
smart_str_appends
(
&
command
,
Z_STRVAL_P
(
id
));
smart_str_appends
(
&
command
,
" "
);
ZEND_HASH_FOREACH_NUM_KEY_VAL
(
Z_ARRVAL_P
(
arguments
),
num_key
,
entry
)
{
char
*
fnamewall
=
(
char
*
)
emalloc
(
strlen
(
Z_STRVAL_P
(
fname
))
+
3
);
sprintf
(
fnamewall
,
"|%s|"
,
Z_STRVAL_P
(
fname
));
// strtolower for matching redis key
fnamewall
=
php_strtolower
(
fnamewall
,
strlen
(
fnamewall
));
// first params
if
(
num_key
==
0
)
{
switch
(
Z_TYPE_P
(
entry
))
{
case
IS_STRING
:
is_string_command
=
1
;
smart_str_appends
(
&
command
,
php_strtolower
(
Z_STRVAL_P
(
fname
),
Z_STRLEN_P
(
fname
)));
smart_str_appends
(
&
command
,
Z_STRVAL_P
(
entry
));
smart_str_appends
(
&
command
,
" "
);
// string
if
(
strstr
(
REDIS_KEY_STRING
,
fnamewall
)
||
strstr
(
REDIS_KEY_KEY
,
fnamewall
)
||
strstr
(
REDIS_KEY_HASH
,
fnamewall
)
||
strstr
(
REDIS_KEY_LIST
,
fnamewall
)
||
strstr
(
REDIS_KEY_SET
,
fnamewall
)
||
strstr
(
REDIS_KEY_SORT
,
fnamewall
)
||
strstr
(
REDIS_KEY_HLL
,
fnamewall
)
||
strstr
(
REDIS_KEY_GEO
,
fnamewall
)
)
{
// add tag key
add_assoc_string
(
&
tags
,
"redis.key"
,
Z_STRVAL_P
(
entry
));
}
else
if
(
strstr
(
REDIS_OPERATION_STRING
,
fnamewall
))
{
// add tag operation
add_assoc_string
(
&
tags
,
"redis.operation"
,
Z_STRVAL_P
(
entry
));
}
break
;
case
IS_ARRAY
:
// @todo
break
;
}
}
// collect command params for string command
if
(
is_string_command
==
1
)
{
if
(
Z_TYPE_P
(
entry
)
!=
IS_STRING
)
{
convert_to_string
(
entry
);
}
default:
convert_to_string
(
entry
)
smart_str_appends
(
&
command
,
Z_STRVAL_P
(
entry
));
smart_str_appends
(
&
command
,
" "
);
break
;
}
efree
(
fnamewall
);
}
ZEND_HASH_FOREACH_END
();
// store command to tags
if
(
command
.
s
)
{
smart_str_0
(
&
command
);
add_assoc_string
(
&
tags
,
"redis.command"
,
ZSTR_VAL
(
php_trim
(
command
.
s
,
NULL
,
0
,
3
)
));
add_assoc_string
(
&
tags
,
"redis.command"
,
ZSTR_VAL
(
command
.
s
));
smart_str_free
(
&
command
);
}
}
}
zval_ptr_dtor
(
id
);
zval_ptr_dtor
(
arguments
);
efree
(
id
);
efree
(
arguments
);
}
zval
temp
;
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录