Rumah  >  Artikel  >  pembangunan bahagian belakang  >  Bagaimana untuk melaksanakan fungsi pengesanan log yang diedarkan dalam perkhidmatan mikro PHP

Bagaimana untuk melaksanakan fungsi pengesanan log yang diedarkan dalam perkhidmatan mikro PHP

WBOY
WBOYasal
2023-09-25 15:29:02956semak imbas

Bagaimana untuk melaksanakan fungsi pengesanan log yang diedarkan dalam perkhidmatan mikro PHP

Cara melaksanakan fungsi pengesanan log teragih dalam perkhidmatan mikro PHP

Tinjauan:

#🎜 yang diedarkan Dengan pembangunan 🎜# sistem, seni bina perkhidmatan mikro telah menjadi penyelesaian yang popular. Dalam seni bina ini, aplikasi dibahagikan kepada berbilang perkhidmatan kecil yang boleh digunakan, skala dan diurus secara bebas. Walau bagaimanapun, apabila bilangan perkhidmatan meningkat, pengurusan log menjadi semakin sukar. Dalam seni bina perkhidmatan mikro yang kompleks, adalah perlu untuk dapat menjejaki aliran permintaan dan maklumat log agregat untuk analisis dan pemantauan seterusnya. Dalam artikel ini, saya akan memperkenalkan cara untuk melaksanakan fungsi pengesanan log teragih dalam perkhidmatan mikro PHP dan memberikan contoh kod khusus.

Langkah pelaksanaan:

    Pasang dan konfigurasikan Zipkin
Zipkin ialah sistem pengesanan yang boleh diedarkan , menyimpan dan melihat data surih daripada sistem yang diedarkan. Pertama, Zipkin perlu dipasang dan dikonfigurasikan pada sistem. Anda boleh menggunakan Docker untuk membina pelayan Zipkin dengan cepat Untuk langkah pemasangan tertentu, sila rujuk dokumentasi rasmi Zipkin.

    Tambah pustaka klien PHP Zipkin
Zipkin menyediakan perpustakaan pelanggan untuk pelbagai bahasa pengaturcaraan, termasuk PHP. Anda boleh menggunakan Composer untuk memasang pustaka klien PHP Zipkin Perintah pemasangan khusus adalah seperti berikut:

composer require openzipkin/zipkin

    Ubah suai kod perkhidmatan
dalam. setiap perkhidmatan mikro Dalam kod, permintaan perlu dijejaki dan maklumat penjejakan direkodkan. Berikut ialah contoh kod mikroperkhidmatan PHP:

<?php

use ZipkinInstrumentationHttpClientPsr18Client;
use ZipkinInstrumentationHttpClientPsr18HttpMiddleware;
use ZipkinSamplerBinarySampler;
use ZipkinSpan;
use ZipkinTimestamp;
use ZipkinTracingBuilder;
use ZipkinOpenTracingSpanContext;
use ZipkinOpenTracingTracer;


// 初始化Zipkin追踪器
$tracing = TracingBuilder::create()
    ->havingLocalEndpoint('your_service_name') // 这里填写当前服务的名称
    ->havingSampler(BinarySampler::createAsAlwaysSample())
    ->build();

// 创建一个Zipkin追踪器,用于记录追踪信息
$tracer = new Tracer($tracing);

// 定义一个中间件,用于追踪请求
$middleware = new Psr18HttpMiddleware($tracer);

// 创建一个HTTP客户端,使用Zipkin中间件处理请求
$client = new Psr18Client($middleware);

// 发送HTTP请求
$request = new GuzzleHttpPsr7Request('GET', 'http://example.com');
$response = $client->sendRequest($request);

// 创建一个Zipkin span,记录该请求的追踪信息
$span = $tracer->startActiveSpan('my_span');
$spanContext = new SpanContext($tracer->getTracer(), $span->getContext());

// 添加追踪信息到请求头
$request = $request->withHeader('X-B3-TraceId', $spanContext->getTraceId());
$request = $request->withHeader('X-B3-SpanId', $spanContext->getSpanId());
$request = $request->withHeader('X-B3-ParentSpanId', $spanContext->getParentId());
$request = $request->withHeader('X-B3-Sampled', $spanContext->isSampled() ? '1' : '0');
$request = $request->withHeader('X-B3-Flags', $spanContext->getFlags());

// 发送带有追踪信息的HTTP请求
$response = $client->sendRequest($request);

// 结束span
$span->addEvent($timestamp, 'sent');

// 输出收到的响应
echo $response->getBody();

// 关闭Zipkin追踪器
$tracing->close();

Melalui kod di atas, kami boleh merekodkan maklumat penjejakan setiap permintaan dan menambahkannya pada pengepala permintaan dan menghantarnya ke perkhidmatan seterusnya. Dengan cara ini, setiap perkhidmatan akan merekodkan maklumat penjejakannya sendiri dan mengagregat serta menganalisisnya melalui Zipkin.

    Lihat data penjejakan
Selepas melengkapkan langkah di atas, anda boleh mengakses antara muka web Zipkin melalui penyemak imbas untuk melihat data penjejakan. Dalam antara muka web, anda boleh melihat laluan penjejakan, penggunaan masa dan maklumat lain bagi setiap permintaan. Anda boleh menggunakan fungsi carian untuk mencari permintaan khusus untuk penyelesaian masalah dan analisis.

Ringkasan:

Dalam seni bina perkhidmatan mikro yang kompleks, adalah sangat penting untuk melaksanakan fungsi pengesanan log teragih. Dengan menggunakan Zipkin dan pustaka klien PHP Zipkin, kami boleh melaksanakan fungsi pengesanan log teragih dengan mudah dalam perkhidmatan mikro PHP. Dengan merekodkan maklumat penjejakan setiap permintaan dan menghantarnya ke perkhidmatan seterusnya, kami boleh menjejaki aliran permintaan dan mengagregatkan maklumat log untuk analisis dan pemantauan seterusnya. Saya harap artikel ini akan membantu anda dalam melaksanakan fungsi pengesanan log teragih dalam perkhidmatan mikro PHP!

Atas ialah kandungan terperinci Bagaimana untuk melaksanakan fungsi pengesanan log yang diedarkan dalam perkhidmatan mikro PHP. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn