Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
SkyAPM
SkyAPM-php-sdk
提交
114c4187
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,体验更适合开发者的 AI 搜索 >>
提交
114c4187
编写于
7月 12, 2019
作者:
H
heyanlong
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
predis
上级
c769fed3
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
121 addition
and
4 deletion
+121
-4
php_skywalking.h
php_skywalking.h
+10
-0
skywalking.c
skywalking.c
+111
-4
未找到文件。
php_skywalking.h
浏览文件 @
114c4187
...
...
@@ -95,6 +95,16 @@ extern zend_module_entry skywalking_module_entry;
#define SKYWALKING_TIME "ti"
#define SKYWALKING_LOG_DATA "ld"
#define REDIS_KEY_KEY "|dump|exists|expire|expireat|move|persist|pexpire|pexpireat|pttl|rename|renamenx|sort|ttl|type|"
#define REDIS_KEY_STRING "|append|bitcount|bitfield|decr|decrby|get|getbit|getrange|getset|incr|incrby|incrbyfloat|psetex|set|setbit|setex|setnx|setrange|strlen|"
#define REDIS_OPERATION_STRING "|bitop|"
#define REDIS_KEY_HASH "|hdel|hexists|hget|hgetall|hincrby|hincrbyfloat|hkeys|hlen|hmget|hmset|hscan|hset|hsetnx|hvals|hstrlen|"
#define REDIS_KEY_LIST "|lindex|linsert|llen|lpop|lpush|lpushx|lrange|lrem|lset|ltrim|rpop|rpush|rpushx|"
#define REDIS_KEY_SET "|sadd|scard|sismember|smembers|spop|srandmember|srem|sscan|"
#define REDIS_KEY_SORT "|zadd|zcard|zcount|zincrby|zrange|zrangebyscore|zrank|zrem|zremrangebyrank|zremrangebyscore|zrevrange|zrevrangebyscore|zrevrank|zscore|zscan|zrangebylex|zrevrangebylex|zremrangebylex|zlexcount|"
#define REDIS_KEY_HLL "|pfadd|watch|"
#define REDIS_KEY_GEO "|geoadd|geohash|geopos|geodist|georadius|georadiusbymember|"
#define RAND_RANGE(__n, __min, __max, __tmax) \
...
...
skywalking.c
浏览文件 @
114c4187
...
...
@@ -104,7 +104,113 @@ const zend_function_entry class_skywalking[] = {
ZEND_API
void
sky_execute_ex
(
zend_execute_data
*
execute_data
)
{
ori_execute_ex
(
execute_data
);
zend_function
*
zf
=
execute_data
->
func
;
const
char
*
class_name
=
(
zf
->
common
.
scope
!=
NULL
&&
zf
->
common
.
scope
->
name
!=
NULL
)
?
ZSTR_VAL
(
zf
->
common
.
scope
->
name
)
:
NULL
;
const
char
*
function_name
=
zf
->
common
.
function_name
==
NULL
?
NULL
:
ZSTR_VAL
(
zf
->
common
.
function_name
);
char
*
operationName
=
NULL
;
if
(
class_name
!=
NULL
)
{
if
(
strcmp
(
class_name
,
"Predis
\\
Client"
)
==
0
&&
strcmp
(
function_name
,
"__call"
)
==
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
(
function_name
)
+
3
);
strcpy
(
operationName
,
class_name
);
strcat
(
operationName
,
"->"
);
strcat
(
operationName
,
Z_STRVAL_P
(
p
));
}
}
}
}
if
(
operationName
!=
NULL
)
{
zval
tags
;
array_init
(
&
tags
);
if
(
strcmp
(
class_name
,
"Predis
\\
Client"
)
==
0
&&
strcmp
(
function_name
,
"__call"
)
==
0
)
{
uint32_t
arg_count
=
ZEND_CALL_NUM_ARGS
(
execute_data
);
zval
*
fname
=
ZEND_CALL_ARG
(
execute_data
,
1
);
for
(
int
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
)
{
zend_ulong
num_key
;
zval
*
entry
;
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
));
// first params
if
(
num_key
==
0
)
{
switch
(
Z_TYPE_P
(
entry
))
{
case
IS_STRING
:
// string
if
(
strstr
(
REDIS_KEY_STRING
,
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
:
break
;
}
}
efree
(
fnamewall
);
}
ZEND_HASH_FOREACH_END
();
}
}
}
zval
temp
;
zval
*
spans
=
NULL
;
zval
*
span_id
=
NULL
;
zval
*
last_span
=
NULL
;
char
*
l_millisecond
;
long
millisecond
;
array_init
(
&
temp
);
spans
=
get_spans
();
last_span
=
zend_hash_index_find
(
Z_ARRVAL_P
(
spans
),
zend_hash_num_elements
(
Z_ARRVAL_P
(
spans
))
-
1
);
span_id
=
zend_hash_str_find
(
Z_ARRVAL_P
(
last_span
),
"spanId"
,
sizeof
(
"spanId"
)
-
1
);
add_assoc_long
(
&
temp
,
"spanId"
,
Z_LVAL_P
(
span_id
)
+
1
);
add_assoc_long
(
&
temp
,
"parentSpanId"
,
0
);
l_millisecond
=
get_millisecond
();
millisecond
=
zend_atol
(
l_millisecond
,
strlen
(
l_millisecond
));
efree
(
l_millisecond
);
add_assoc_long
(
&
temp
,
"startTime"
,
millisecond
);
add_assoc_long
(
&
temp
,
"spanType"
,
1
);
add_assoc_long
(
&
temp
,
"spanLayer"
,
1
);
add_assoc_long
(
&
temp
,
"componentId"
,
COMPONENT_JEDIS
);
add_assoc_string
(
&
temp
,
"operationName"
,
operationName
);
add_assoc_string
(
&
temp
,
"peer"
,
""
);
efree
(
operationName
);
ori_execute_ex
(
execute_data
);
l_millisecond
=
get_millisecond
();
millisecond
=
zend_atol
(
l_millisecond
,
strlen
(
l_millisecond
));
efree
(
l_millisecond
);
add_assoc_zval
(
&
temp
,
"tags"
,
&
tags
);
add_assoc_long
(
&
temp
,
"endTime"
,
millisecond
);
add_assoc_long
(
&
temp
,
"isError"
,
0
);
zend_hash_next_index_insert
(
Z_ARRVAL_P
(
spans
),
&
temp
);
}
else
{
ori_execute_ex
(
execute_data
);
}
}
ZEND_API
void
sky_execute_internal
(
zend_execute_data
*
execute_data
,
zval
*
return_value
)
{
...
...
@@ -166,6 +272,7 @@ ZEND_API void sky_execute_internal(zend_execute_data *execute_data, zval *return
switch
(
Z_TYPE_P
(
p
))
{
case
IS_STRING
:
add_assoc_string
(
&
tags
,
"db.statement"
,
Z_STRVAL_P
(
p
));
break
;
}
}
...
...
@@ -1182,9 +1289,9 @@ PHP_MINIT_FUNCTION (skywalking) {
return
SUCCESS
;
}
//
ori_execute_ex = zend_execute_ex;
//
zend_execute_ex = sky_execute_ex;
//
ori_execute_ex
=
zend_execute_ex
;
zend_execute_ex
=
sky_execute_ex
;
ori_execute_internal
=
zend_execute_internal
;
zend_execute_internal
=
sky_execute_internal
;
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录