Dalam reka bentuk seni bina aplikasi Internet hari ini, sistem teragih telah menjadi kebiasaan. Dalam sistem yang begitu kompleks, mencari titik kerosakan apabila masalah berlaku adalah tugas yang sangat mencabar. Untuk menyelesaikan masalah ini, pembangun perlu menggunakan alat pengesanan yang diedarkan untuk mendedahkan misteri kotak hitam aplikasi. Artikel ini akan memperkenalkan Sleuth dan Zipkin, dua alat pengesanan teragih yang popular, untuk membantu pembangun memantau dan menyahpepijat sistem yang diedarkan dengan lebih baik.
Dengan percambahan perkhidmatan mikroseni bina dan sistem teragih yang kompleks, menjejaki aliran permintaan dan respons merentas komponen dan perkhidmatan menjadi kritikal. DisedarkanMenjejakVisualisasiproses pelaksanaan aplikasi, mendedahkan kesesakan prestasi, kebergantungan dan anomali.
Sleuth: Alat pengesan Spring Boot
Sleuth ialah pengesanan teragih ringan rangka kerja untuk aplikasi Spring Boot. Ia berintegrasi dengan spring cloud Sleuth Starter untuk menyediakan keupayaan penjejakan di luar kotak. Cuma tambah kebergantungan untuk menangkap peristiwa secara automatik seperti permintaan Http, Pangkalan data panggilan dan panggilan perkhidmatan jauh.
Kod contoh:
@Configuration public class SleuthConfig { @Bean public Sampler sampler() { return Sampler.ALWAYS_SAMPLE; } }
Zipkin: alat visualisasi untuk menjejak data
Zipkin ialah platform sumber terbuka untuk mengumpul, menyimpan dan menanyakan data penjejakan. Ia menyediakan antara muka pengguna interaktif yang membolehkan pengguna meneroka data surih secara intuitif dan mengenal pasti kebergantungan dan isu prestasi.
Kod contoh:
import io.zipkin.reporter.AsyncReporter; import io.zipkin.reporter.okhttp3.Okhttpsender; import io.zipkin.zipkin2.Span; // 使用 OkHttp 发送器将追踪数据发送到 Zipkin 服务器 OkHttpSender sender = OkHttpSender.newBuilder().endpoint("http://localhost:9411/api/v2/spans").build(); // 使用异步报告器,提高性能 AsyncReporter reporter = AsyncReporter.newBuilder(sender).build(); // 上报追踪信息到 Zipkin 服务器 reporter.report(span);
Perkahwinan Sleuth dan Zipkin
Integrasi Sleuth dengan Zipkin membolehkan pengeksportan data penjejakan dengan mudah daripada aplikasi Sleuth ke platform Zipkin. Penyepaduan ini boleh dilakukan melalui spring Cloud Sleuth Zipkin Starter.
Kod contoh:
@Configuration public class SleuthZipkinConfig { @Bean public ZipkinSender sender() { return new ZipkinSender(); } @Bean public SpanReporter reporter() { return new SpanReporter.Builder(sender()).build(); } }
Faedah pengesanan yang diedarkan
Pengesanan teragih mempunyai kelebihan berikut dalam aplikasi pembangunan dan penyelenggaraan:
Kesimpulan
Sleuth dan Zipkin ialah gabungan kuat pengesanan teragih, membolehkan pembangun mendapatkan cerapan tentang logik dalaman aplikasi, meningkatkan prestasi dan kebolehpercayaan. Dengan menyepadukan dua alat ini ke dalam sistem yang diedarkan, anda boleh meningkatkan kebolehmerhatian aplikasi dengan ketara dan memperoleh cerapan yang anda perlukan untuk mengawal, mengoptimumkan dan menyelesaikan masalah.
Atas ialah kandungan terperinci Sleuth dan Zipkin: Pengesanan diedarkan, membongkar misteri kotak hitam aplikasi. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!