Rumah >pembangunan bahagian belakang >Golang >Mari kita bincangkan tentang cara menggunakan Golang untuk melaksanakan perkhidmatan Sidecar

Mari kita bincangkan tentang cara menggunakan Golang untuk melaksanakan perkhidmatan Sidecar

PHPz
PHPzasal
2023-04-06 09:11:311081semak imbas

Sidecar ialah penyelesaian dalam sistem teragih yang tidak mempunyai sokongan yang sesuai untuk panggilan antara perkhidmatan disebabkan topologi perkhidmatan atau beberapa sebab. Dalam panggilan antara perkhidmatan, Sidecar bertindak sebagai proksi, mengedarkan semua permintaan masuk dan keluar kepada perkhidmatan lain, pengimbangan beban, pembentukan trafik, pemprosesan keselamatan, dsb. Topik kali ini ialah pelaksanaan Sidecar di Golang Seterusnya, artikel ini akan memperkenalkan secara terperinci kepentingan pembinaan Sidecar, cara Sidecar berfungsi, dan cara menggunakan Golang untuk melaksanakan perkhidmatan Sidecar.

  1. Maksud Sidecar

Pertama sekali, peranan Sidecar perlu diperjelaskan. Dalam seni bina berorientasikan perkhidmatan, banyak perkhidmatan perlu memanggil satu sama lain Dalam kes ini, beberapa masalah akan timbul. Sebagai contoh, jika perkhidmatan A ingin mengakses perkhidmatan B, maka ia perlu membangunkan pelanggan panggilan Dalam klien ini, kita perlu menentukan kaedah panggilan, alamat, port, protokol, dll. Semakin banyak perkhidmatan yang ada, semakin rumit. hubungan panggilan akan menjadi. Menggunakan Sidecar, kami hanya perlu menggunakan Sidecar dalam setiap contoh perkhidmatan, yang boleh memintas semua permintaan dan memproses permintaan dengan sewajarnya, dengan itu menghapuskan kerumitan hubungan akses dan menyediakan kaedah Panggilan yang lebih mudah.

  1. Cara Sidecar berfungsi

Aliran kerja utama Sidecar adalah seperti berikut:

Langkah 1: Sidecar bertanggungjawab untuk memintas semua permintaan pelanggan.

Langkah 2: Sidecar menukar permintaan yang dipintas kepada protokol biasa, dan kemudian menghantar permintaan itu kepada perkhidmatan.

Langkah 3: Apabila respons perkhidmatan tiba, Sidecar mengeluarkan respons daripada perkhidmatan, melakukan penukaran terbalik dan mengembalikan respons kepada pelanggan.

Rajah seni bina dengan fungsi Sidecar adalah seperti berikut:

  1. Langkah asas untuk melaksanakan Sidecar di Golang

Pertama sekali, anda perlu menentukan pelanggan yang perlu dipanggil oleh banyak perkhidmatan Nama dan alamat serta pelabuhan untuk membuat panggilan, kami memanggil penemuan perkhidmatan ini. Langkah khusus adalah seperti berikut:

Langkah 1: Penemuan perkhidmatan: Sidecar perlu mempelajari maklumat penemuan perkhidmatan aplikasi semasa daripada pusat konfigurasi atau pusat pendaftaran. Maklumat penemuan perkhidmatan ini merekodkan semua perkhidmatan aplikasi dan alamat dan maklumat pelabuhannya. Maklumat ini boleh digunakan untuk membolehkan Sidecar menyelesaikan panggilan perkhidmatan.

Langkah 2: Tetapan proksi: Sidecar perlu memintas permintaan dan melakukan tetapan proksi. Jika permintaan pelanggan mempunyai pengecam yang sepadan, permintaan itu ditukar kepada format protokol biasa dan dihantar kepada perkhidmatan Jika tidak, Sidecar menolaknya.

Melalui langkah di atas, anda boleh melaksanakan perkhidmatan Sidecar di Golang. Pelaksanaan kod boleh merujuk kepada proses berikut:

  1. Tulis klien penemuan perkhidmatan:

//Tentukan alamat penemuan perkhidmatan
const discoverUrl = "https://srv . discover.local/path"

taip antara muka ServiceDiscoveryClient{
FindService(serviceName string) ([]rentetan, ralat)
}

func NewServiceDiscoveryClient() ServiceDiscoveryClient {
return &serviceDiscoveryClient{discoverUrl}
}

taip serviceDiscoveryClient struct{
url string
}

func (c* serviceDiscoveryClient) FindService(serviceName string) ([]rentetan , ralat){
//Minta alamat dan pelabuhan perkhidmatan daripada pusat penemuan perkhidmatan
}

  1. Tulis perkhidmatan proksi Sidecar:

//Tentukan Port proksi dan nama perkhidmatan
const proxyPort int = 1000
const serviceName string = "my-service"

type Proxy interface {
Start() error
Stop () ralat
}

func NewProxy(serviceDiscoveryClient ServiceDiscoveryClient) Proxy {
//Initialize Sidecar proxy
}

type proksi struct {
serviceDiscoveryClient ServiceDiscoveryClient
}

func (p* proxy) Start() error {
//Mula mendengar port dan memintas permintaan
}

func (p* proksi) Stop( ) ralat {
//Berhenti mendengar port
}

  1. Mulakan fail boleh laku untuk memanggil perkhidmatan:

$ go run main.go

  1. Rajah aliran kerja untuk Golang melaksanakan perkhidmatan Sidecar adalah seperti berikut:

Sidecar in Golang

Dalam proses melaksanakan proses ini, anda juga boleh merujuk kepada kod sumber projek sumber terbuka GitHub yang berkaitan untuk memperdalam pemahaman anda tentang prinsip kerja dan pelaksanaan Sidecar.

Ringkasan

Artikel ini terutamanya memperkenalkan pengetahuan asas dan proses perkhidmatan Sidecar dan Golang untuk melaksanakan perkhidmatan Sidecar. Perlu diingat bahawa pelaksanaan perkhidmatan Sidecar perlu dibina bersama-sama dengan rangka kerja mikroperkhidmatan yang berkaitan, seperti Netflix's Zuul, Spring's Spring Cloud, Alibaba Cloud's DuoMi, dsb. Dalam sistem teragih, menggunakan Sidecar boleh menyelesaikan sepenuhnya masalah kerumitan penggunaan perkhidmatan, mencapai komunikasi yang lebih fleksibel dan cekap antara perkhidmatan, dan meningkatkan kestabilan dan skalabiliti perkhidmatan.

Atas ialah kandungan terperinci Mari kita bincangkan tentang cara menggunakan Golang untuk melaksanakan perkhidmatan Sidecar. 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