PHP 服務(wù)實(shí)現(xiàn)監(jiān)控可觀測性最佳實(shí)踐

前言

本次實(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ù)展示,以下為具體的截圖。


?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容