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.
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.
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:
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:
//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
}
//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
}
$ go run main.go
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!