Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
SkyAPM
SkyAPM-php-sdk
提交
040df5bb
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,发现更多精彩内容 >>
提交
040df5bb
编写于
8月 02, 2019
作者:
w60514603
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
add redis c extension support
上级
ed26ed1c
变更
2
显示空白变更内容
内联
并排
Showing
2 changed file
with
71 addition
and
14 deletion
+71
-14
php_skywalking.h
php_skywalking.h
+2
-0
skywalking.c
skywalking.c
+69
-14
未找到文件。
php_skywalking.h
浏览文件 @
040df5bb
...
...
@@ -151,6 +151,8 @@ static void write_log( char *text);
static
void
request_init
();
static
void
zval_b64_encode
(
zval
*
out
,
char
*
in
);
static
void
zval_b64_decode
(
zval
*
out
,
char
*
in
);
static
char
*
sky_redis_fnamewall
(
const
char
*
function_name
);
static
int
sky_redis_key_func
(
char
*
fnamewall
);
void
sky_curl_exec_handler
(
INTERNAL_FUNCTION_PARAMETERS
);
void
sky_curl_setopt_handler
(
INTERNAL_FUNCTION_PARAMETERS
);
...
...
skywalking.c
浏览文件 @
040df5bb
...
...
@@ -154,6 +154,28 @@ static char *pcre_match(char *pattern, int len, char *subject) {
}
static
char
*
sky_redis_fnamewall
(
const
char
*
function_name
)
{
char
*
fnamewall
=
(
char
*
)
emalloc
(
strlen
(
function_name
)
+
3
);
sprintf
(
fnamewall
,
"|%s|"
,
function_name
);
fnamewall
=
php_strtolower
(
fnamewall
,
strlen
(
fnamewall
));
return
fnamewall
;
}
static
int
sky_redis_key_func
(
char
*
fnamewall
)
{
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
)
)
{
return
1
;
}
return
0
;
}
ZEND_API
void
sky_execute_ex
(
zend_execute_data
*
execute_data
)
{
if
(
application_instance
==
0
)
{
...
...
@@ -205,11 +227,7 @@ ZEND_API void sky_execute_ex(zend_execute_data *execute_data) {
smart_str
command
=
{
0
};
ZEND_HASH_FOREACH_NUM_KEY_VAL
(
Z_ARRVAL_P
(
pam
),
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
));
char
*
fnamewall
=
sky_redis_fnamewall
(
Z_STRVAL_P
(
fname
));
// first params
if
(
num_key
==
0
)
{
switch
(
Z_TYPE_P
(
entry
))
{
...
...
@@ -219,15 +237,7 @@ ZEND_API void sky_execute_ex(zend_execute_data *execute_data) {
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
if
(
sky_redis_key_func
(
fnamewall
)
==
1
)
{
// 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
));
...
...
@@ -370,6 +380,18 @@ ZEND_API void sky_execute_internal(zend_execute_data *execute_data, zval *return
}
}
}
}
else
if
(
strcmp
(
class_name
,
"Redis"
)
==
0
||
strcmp
(
class_name
,
"RedisCluster"
)
==
0
)
{
char
*
fnamewall
=
sky_redis_fnamewall
(
function_name
);
if
(
sky_redis_key_func
(
fnamewall
)
==
1
)
{
componentId
=
COMPONENT_JEDIS
;
component
=
(
char
*
)
emalloc
(
strlen
(
"Redis"
)
+
1
);
strcpy
(
component
,
"Redis"
);
operationName
=
(
char
*
)
emalloc
(
strlen
(
class_name
)
+
strlen
(
function_name
)
+
3
);
strcpy
(
operationName
,
class_name
);
strcat
(
operationName
,
"->"
);
strcat
(
operationName
,
function_name
);
}
efree
(
fnamewall
);
}
}
else
if
(
function_name
!=
NULL
)
{
if
(
strcmp
(
function_name
,
"mysqli_query"
)
==
0
)
{
...
...
@@ -508,6 +530,39 @@ ZEND_API void sky_execute_internal(zend_execute_data *execute_data, zval *return
}
}
}
}
else
if
(
strcmp
(
class_name
,
"Redis"
)
==
0
||
strcmp
(
class_name
,
"RedisCluster"
)
==
0
)
{
add_assoc_string
(
&
tags
,
"db.type"
,
"redis"
);
uint32_t
arg_count
=
ZEND_CALL_NUM_ARGS
(
execute_data
);
smart_str
command
=
{
0
};
smart_str_appends
(
&
command
,
php_strtolower
((
char
*
)
function_name
,
strlen
((
char
*
)
function_name
)));
smart_str_appends
(
&
command
,
" "
);
int
is_string_command
=
1
;
int
i
;
for
(
i
=
1
;
i
<
arg_count
+
1
;
++
i
)
{
zval
*
p
=
ZEND_CALL_ARG
(
execute_data
,
i
);
if
(
Z_TYPE_P
(
p
)
==
IS_ARRAY
)
{
is_string_command
=
0
;
break
;
}
if
(
Z_TYPE_P
(
p
)
!=
IS_STRING
)
{
convert_to_string
(
p
);
}
if
(
i
==
1
)
{
add_assoc_string
(
&
tags
,
"redis.key"
,
Z_STRVAL_P
(
p
));
}
smart_str_appends
(
&
command
,
php_strtolower
(
Z_STRVAL_P
(
p
),
Z_STRLEN_P
(
p
)));
smart_str_appends
(
&
command
,
" "
);
}
// store command to tags
if
(
command
.
s
)
{
smart_str_0
(
&
command
);
if
(
is_string_command
)
{
add_assoc_string
(
&
tags
,
"redis.command"
,
ZSTR_VAL
(
php_trim
(
command
.
s
,
NULL
,
0
,
3
)));
}
smart_str_free
(
&
command
);
}
}
zval
temp
;
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录