前言
本次實(shí)踐主要是介紹 PHP 服務(wù)通過無侵入的方式接入觀測云進(jìn)行全面的可觀測。
環(huán)境信息
- 主機(jī)環(huán)境:CentOS 7.8
- PHP:7.4.33
- MySQL:5.7

接入方案
準(zhǔn)備工作
安裝 DataKit
# 需要把token 改成觀測云空間的實(shí)際token值(可在觀測云控制臺-->集成-->Datakit 上面獲取)
DK_DATAWAY="https://openway.guance.com?token=tkn_xxxxxx" bash -c "$(curl -L https://static.guance.com/datakit/install.sh)"
開啟 ddtrace 采集器
cp /usr/local/datakit/conf.d/ddtrace/ddtrace.conf.sample? /usr/local/datakit/conf.d/ddtrace/ddtrace.conf
重啟 Datakit
# 在主機(jī)終端輸入命令
datakit service -R
查看采集器是否開啟
# 在主機(jī)終端輸入命令
datakit monitor
準(zhǔn)備測試環(huán)境
安裝 Nginx、PHP 和 MySQL
可以通過 yum 命令行的方式安裝 Nginx、PHP、PHP-FPM、MySQL,注意版本信息。
編寫代碼
在 MySQL 數(shù)據(jù)庫中創(chuàng)建 demo_db 表:
CREATE DATABASE demo_db;
USE demo_db;
CREATE TABLE users (
? id INT AUTO_INCREMENT PRIMARY KEY,
? name VARCHAR(50),
? email VARCHAR(100)
);
插入一條 users 記錄:
INSERT INTO users (name, email) VALUES ('John Doe', 'john@example.com');
前端 index.html 頁面代碼如下:
<!DOCTYPE html>
<html>
<head>
? ? <title>NGINX, PHP-FPM, and MySQL Demo</title>
</head>
<body>
? ? <h1>User List</h1>
? ? <ul id="user-list"></ul>
? ? <script>
? ? ? ? fetch('/index.php')
? ? ? ? ? ? .then(response => response.json())
? ? ? ? ? ? .then(data => {
? ? ? ? ? ? ? ? const userList = document.getElementById('user-list');
? ? ? ? ? ? ? ? data.forEach(user => {
? ? ? ? ? ? ? ? ? ? const li = document.createElement('li');
? ? ? ? ? ? ? ? ? ? li.textContent = `${user.name} - ${user.email}`;
? ? ? ? ? ? ? ? ? ? userList.appendChild(li);
? ? ? ? ? ? ? ? });
? ? ? ? ? ? })
? ? ? ? ? ? .catch(error => console.error('Error fetching data:', error));
? ? </script>
</body>
</html>
在同級目錄下創(chuàng)建一個(gè)新的 PHP 后端腳本來處理前端的請求,例如 `index.php` :
<?php
$host = 'localhost';
$username = 'your_mysql_username';
$password = 'your_mysql_password';
$database = 'demo_db';
// 創(chuàng)建 MySQL 連接
$mysqli = new mysqli($host, $username, $password, $database);
// 檢查連接是否成功
if ($mysqli->connect_error) {
? ? die('數(shù)據(jù)庫連接失敗:' . $mysqli->connect_error);
}
// 查詢用戶信息
$query = "SELECT * FROM users";
$result = $mysqli->query($query);
// 處理查詢結(jié)果
$users = array();
if ($result->num_rows > 0) {
? ? while ($row = $result->fetch_assoc()) {
? ? ? ? $users[] = $row;
? ? }
}
// 關(guān)閉數(shù)據(jù)庫連接
$mysqli->close();
// 將結(jié)果以 JSON 格式返回給前端
header('Content-Type: application/json');
echo json_encode($users);
請注意,以上代碼中的 `your_mysql_username` 和 `your_mysql_password` 應(yīng)該被替換為你的 MySQL 數(shù)據(jù)庫的用戶名和密碼。同時(shí),`demo_db` 應(yīng)該是你創(chuàng)建的 MySQL 數(shù)據(jù)庫名,并且其中包含了 `users` 表來存儲用戶信息。如果你的 MySQL 配置和數(shù)據(jù)庫結(jié)構(gòu)正確,當(dāng)你在瀏覽器中打開 `index.html` 頁面時(shí),應(yīng)該能夠看到從數(shù)據(jù)庫中獲取的用戶列表顯示在頁面上。
PHP 配置
安裝 php-mysqlnd 。
yum install php-mysqlnd
vi /etc/php.ini
#添加一行代碼
extension=mysqli
下載 ddtrace-php 安裝腳本。
curl -LO https://github.com/DataDog/dd-trace-php/releases/latest/download/datadog-setup.php
在下載目錄上執(zhí)行命令安裝,這一步時(shí)間略長。
php datadog-setup.php --php-bin=all
執(zhí)行如下命令查看是否安裝成功。
php -m | grep ddtrace
通過 `service php-fpm start` 啟動 PHP-FPM 。
找到對應(yīng)的 php-fpm 配置文件,通常路徑為 `/etc/php-fpm.d/www.conf` ,增加如下配置:
env[DD_AGENT_HOST] = localhost
env[DD_TRACE_AGENT_PORT] = 9529
env[DD_SERVICE] = my-app
接入驗(yàn)證
通過瀏覽器訪問 nginx 所在服務(wù)器的 index.html 頁面 `http://xx.xx.xx.xx/index.html` ,可以查看到頁面信息(訪問前注意開通相關(guān)防火墻規(guī)則或安全組策略)。

實(shí)踐效果
根據(jù)以上實(shí)驗(yàn)過程可實(shí)現(xiàn)應(yīng)用鏈路數(shù)據(jù)展示,以下為具體的截圖。


