Rumah > hujung hadapan web > tutorial js > Pengesanan Teragih dalam Next.js

Pengesanan Teragih dalam Next.js

Mary-Kate Olsen
Lepaskan: 2024-11-07 05:52:03
asal
1061 orang telah melayarinya

Distributed Tracing in Next.js

Apabila aplikasi moden semakin diedarkan, terutamanya dengan peningkatan perkhidmatan mikro dan seni bina tanpa pelayan, pemantauan dan penyahpepijatan sistem ini menjadi lebih kompleks. Pengesanan yang diedarkan membantu pembangun menjejaki permintaan semasa mereka bergerak melalui pelbagai perkhidmatan, memberikan gambaran yang jelas tentang kesesakan prestasi, ralat dan isu kependaman. Apabila bekerja dengan Next.js, rangka kerja React yang berkuasa, melaksanakan pengesanan teragih boleh meningkatkan kebolehmerhatian apl anda dan mendayakan diagnostik prestasi yang lebih baik.

Dalam artikel ini, kita akan menyelami konsep pengesanan teragih, cara ia digunakan pada Next.js dan langkah yang boleh anda ambil untuk melaksanakannya.

Apakah Pengesanan Teragih?

Pengesanan teragih ialah kaedah yang digunakan untuk menjejak permintaan melalui sistem teragih, terutamanya apabila permintaan merentasi berbilang perkhidmatan atau komponen. Tidak seperti pengelogan tradisional atau pemantauan prestasi aplikasi (APM), mengedarkan jahitan pengesanan bersama-sama aliran permintaan merentasi sempadan, menjadikannya mudah untuk mengenal pasti tempat kelewatan atau ralat berlaku.

Konsep utama dalam pengesanan teragih:

  • Jejak: Jejak mewakili perjalanan permintaan semasa ia bergerak melalui sistem yang diedarkan. Ia terdiri daripada berbilang rentang.
  • Span: Setiap span mewakili satu operasi dalam perjalanan, seperti panggilan API, pertanyaan pangkalan data atau memaparkan komponen. Span mengandungi metadata tentang masa mula dan tamat operasi, bersama-sama dengan sebarang teg atau acara.
  • Penyebaran konteks: Pengesanan teragih bergantung pada penyebaran konteks jejak merentas sempadan perkhidmatan, memastikan bahagian sistem yang berbeza boleh menyumbang kepada jejak yang sama.

Mengapa Menggunakan Pengesanan Teragih dalam Next.js?

Next.js, sebagai rangka kerja tindanan penuh, boleh melibatkan gabungan pemaparan bahagian pelayan dan pelanggan, bersama-sama dengan laluan API yang boleh berinteraksi dengan perkhidmatan luaran. Apabila membina aplikasi berskala besar dengan berbilang komponen dan perkhidmatan, mengenal pasti kesesakan prestasi dan memastikan kesihatan sistem adalah kritikal.

Pengesanan teragih membantu pembangun Next.js:

  • Pantau prestasi laluan API: Fahami prestasi laluan sebelah pelayan, kenal pasti pertanyaan pangkalan data yang perlahan atau panggilan API luaran dan optimumkan kesesakan.
  • Tingkatkan pengalaman pengguna: Pantau tempoh masa yang diambil untuk halaman Next.js yang berbeza untuk dipaparkan, sama ada melalui pemaparan sisi pelayan (SSR), penjanaan tapak statik (SSG) atau pemaparan sebelah pelanggan.
  • Ralat nyahpepijat merentas perkhidmatan: Jika apl Next.js anda berkomunikasi dengan berbilang perkhidmatan mikro atau perkhidmatan pihak ketiga, pengesanan boleh membantu menjejak cara data mengalir merentas perkhidmatan tersebut, membantu anda menentukan dari mana ralat atau isu kependaman berasal.

Cara Melaksanakan Pengesanan Teragih dalam Next.js

Untuk melaksanakan pengesanan teragih dalam Next.js, kami boleh memanfaatkan perpustakaan sumber terbuka seperti OpenTelemetry, yang menyediakan asas untuk mengumpul jejak yang diedarkan atau penyelesaian proprietari seperti Datadog, New Relic dan lain-lain yang menawarkan ciri yang lebih maju untuk pengesanan.

Langkah 1: Sediakan OpenTelemetry

OpenTelemetry ialah standard sumber terbuka yang menyediakan alatan untuk mengumpul dan mengeksport data surih. Ia disokong oleh pelbagai vendor dan platform awan.

  1. Pasang pakej OpenTelemetry: Mulakan dengan memasang pakej OpenTelemetry yang diperlukan. Anda memerlukan pakej teras dan pakej khusus untuk Node.js dan rangka kerja HTTP anda.
   npm install @opentelemetry/api @opentelemetry/sdk-node @opentelemetry/instrumentation-http @opentelemetry/exporter-jaeger
Salin selepas log masuk
Salin selepas log masuk

Persediaan ini termasuk:

  • @opentelemetry/api: API pengesanan teras.
  • @opentelemetry/sdk-node: Node.js SDK untuk menangkap jejak.
  • @opentelemetry/instrumentation-http: Instrumentasi untuk panggilan HTTP.
  • @opentelemetry/exporter-jaeger: Contoh pengeksport kepada Jaeger, iaitu sistem pengesanan teragih sumber terbuka.
  1. Buat fail persediaan pengesanan: Dalam projek Next.js anda, cipta fail yang dipanggil tracing.js untuk mengkonfigurasi dan memulakan OpenTelemetry.
   const { NodeTracerProvider } = require('@opentelemetry/sdk-node');
   const { SimpleSpanProcessor } = require('@opentelemetry/sdk-trace-base');
   const { JaegerExporter } = require('@opentelemetry/exporter-jaeger');
   const { HttpInstrumentation } = require('@opentelemetry/instrumentation-http');

   const provider = new NodeTracerProvider();

   // Configure exporter
   const exporter = new JaegerExporter({
     endpoint: 'http://localhost:14268/api/traces', // Jaeger endpoint
   });

   provider.addSpanProcessor(new SimpleSpanProcessor(exporter));

   // Register the provider globally
   provider.register();

   // Initialize HTTP instrumentation
   new HttpInstrumentation().setTracerProvider(provider);
Salin selepas log masuk
Salin selepas log masuk
  1. Alat laluan API anda: Anda boleh membuat rentang secara manual dalam laluan API Next.js anda dengan menggunakan API OpenTelemetry.
   import { trace } from '@opentelemetry/api';

   export default async function handler(req, res) {
     const tracer = trace.getTracer('default');
     const span = tracer.startSpan('api-route-handler');

     try {
       // Simulate some async work
       await new Promise((resolve) => setTimeout(resolve, 100));
       res.status(200).json({ message: 'Hello from the API' });
     } catch (error) {
       span.recordException(error);
       res.status(500).json({ error: 'Internal Server Error' });
     } finally {
       span.end();
     }
   }
Salin selepas log masuk

Ini mewujudkan rentang yang menjejaki pelaksanaan laluan API anda. Jika terdapat ralat, rentang akan menangkap pengecualian itu.

  1. Tangkap pengesanan sebelah pelanggan (Pilihan): Untuk pengesanan sisi klien (cth., mengukur tempoh masa halaman yang diambil untuk memaparkan atau memuatkan data), anda boleh menyediakan konfigurasi OpenTelemetry yang serupa dalam penyemak imbas. Anda juga akan mengkonfigurasi pengeksport untuk menghantar data surih ke hujung belakang.

Langkah 2: Gunakan Vendor Pengesanan

Sebagai alternatif, anda boleh menggunakan alatan pihak ketiga seperti Datadog, New Relic atau AWS X-Ray, yang menyediakan keupayaan pengesanan yang lebih komprehensif dan disepadukan dengan alatan pemantauan prestasi yang lain.

Sebagai contoh, untuk menyepadukan Datadog ke dalam aplikasi Next.js:

  1. Pasang pakej Datadog:
   npm install @opentelemetry/api @opentelemetry/sdk-node @opentelemetry/instrumentation-http @opentelemetry/exporter-jaeger
Salin selepas log masuk
Salin selepas log masuk
  1. Mulakan pengesanan: Buat fail dd-tracing.js dan konfigurasikan pengesanan Datadog untuk aplikasi anda.
   const { NodeTracerProvider } = require('@opentelemetry/sdk-node');
   const { SimpleSpanProcessor } = require('@opentelemetry/sdk-trace-base');
   const { JaegerExporter } = require('@opentelemetry/exporter-jaeger');
   const { HttpInstrumentation } = require('@opentelemetry/instrumentation-http');

   const provider = new NodeTracerProvider();

   // Configure exporter
   const exporter = new JaegerExporter({
     endpoint: 'http://localhost:14268/api/traces', // Jaeger endpoint
   });

   provider.addSpanProcessor(new SimpleSpanProcessor(exporter));

   // Register the provider globally
   provider.register();

   // Initialize HTTP instrumentation
   new HttpInstrumentation().setTracerProvider(provider);
Salin selepas log masuk
Salin selepas log masuk
  1. Pantau dan analisis: Selepas menghantar jejak ke Datadog, gunakan papan pemuka mereka untuk menggambarkan laluan permintaan, mengenal pasti kesesakan dan memantau sistem.

Langkah 3: Analisis Jejak

Setelah sistem pengesanan anda disediakan, anda boleh melihat dan menganalisis jejak menggunakan alat seperti Jaeger, Datadog atau mana-mana bahagian belakang pengesanan. Alat ini akan menunjukkan kepada anda paparan air terjun bagi setiap jejak, membantu anda memahami cara permintaan mengalir melalui aplikasi anda dan tempat isu prestasi timbul.

Kesimpulan

Pengesanan teragih memberikan keterlihatan penting ke dalam aplikasi moden, terutamanya yang dibina dengan rangka kerja seperti Next.js yang mengendalikan kedua-dua logik sisi klien dan pelayan. Dengan melaksanakan pengesanan teragih, anda memperoleh cerapan mendalam tentang prestasi apl anda, membolehkan anda mendiagnosis dan membetulkan kesesakan dengan cekap. Sama ada anda memilih penyelesaian sumber terbuka seperti OpenTelemetry atau alat komersial seperti Datadog, pengesanan diedarkan akan membantu anda memastikan aplikasi Next.js anda dioptimumkan, boleh dipercayai dan berskala.

Atas ialah kandungan terperinci Pengesanan Teragih dalam Next.js. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

sumber:dev.to
Kenyataan Laman Web ini
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
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan