skywalking-2-客户端-php的安装与使用

发布于:2024-07-11 ⋅ 阅读:(18) ⋅ 点赞:(0)

skywalking的客户端支持php,真的很棒。

官方安装文档:https://skywalking.apache.org/docs/skywalking-php/next/en/setup/service-agent/php-agent/readme/

前置准备

本次使用的php版本是8.2.13:

php -v
PHP 8.2.13 (cli) (built: Nov 21 2023 09:55:59) (NTS gcc x86_64)
Copyright (c) The PHP Group
Zend Engine v4.2.13, Copyright (c) Zend Technologies
    with Zend OPcache v8.2.13, Copyright (c), by Zend Technologies

安装rust:

dnf install rust cargo -y

安装其他扩展:

dnf install clang llvm-devel -y

安装skywalking-php扩展

这里直接用master分支的,有些新特性哦

git clone https://github.com/apache/skywalking-php.git
cd skywalking-php

phpize
./configure --with-php-config=/usr/bin/php-config
make
make install

make这一步注意下报错,一般是依赖库没安装,根据报错信息找下安装即可

php启用skywalking

在php.ini下增加如下配置:

[skywalking_agent]
skywalking_agent.enable = On
skywalking_agent.log_file = /tmp/skywalking-agent.log
skywalking_agent.log_level = INFO
skywalking_agent.server_addr = 127.0.0.1:11800
skywalking_agent.service_name = local-php-dev
skywalking_agent.skywalking_version = 9
skywalking_agent.inject_context = On

这些参数也很好懂,不用特殊说明。关键是skywalking_agent.server_addr和skywalking_agent.service_name参数注意下。
skywalking_agent.server_addr指向的就是服务端,我这里都是部署在同一个机器上,所以地址是127.0.0.1。
skywalking_agent.service_name定义了skywalking的服务,当它能探测到时,在ui上会自动出来

测试验证

重启php-fpm,访问测试文件skywalking.php

<?php
echo sprintf("SW_SERVICE_NAME: %s <br>", $_SERVER["SW_SERVICE_NAME"]);  // get service name
echo sprintf("SW_INSTANCE_NAME: %s  <br>", $_SERVER["SW_INSTANCE_NAME"]); // get instance name
echo sprintf("SW_TRACE_ID: %s  <br>", $_SERVER["SW_TRACE_ID"]); // get trace id

正常的话在浏览器里会看到如下信息:

SW_SERVICE_NAME: local-php-dev
SW_INSTANCE_NAME: 160853870359529938982011205294883059063@10.0.90.12
SW_TRACE_ID: 41101851062989898248658024978575840395

这里我们拿到了SW_TRACE_ID,这个很好用。
同时在skywalking的管理后台会看到自动出现了一个local-php-dev服务

点进去就能看到我们的访问请求啦

后续

通过服务端和客户端的安装部署,我们揭开了skywalking全链路跟踪的序幕,接下来就是深入使用了,go go go。