Bu proje, RPC akrabası olan bir çağrı sistemi geliştirmek amacıyla oluşturulmuştur. Kullanıcıların doğrudan RPC yazmalarına gerek kalmadan, Servisler arası 2 call tanımı ile kolayca iletişim kurabilirler. Proje, modüler yapısı ve kolay kullanımı ile dikkat çekmektedir. Ayrıca dışarıdan erişilemeyen sidecar ve ek ufak servisler için de proxy modeli de bulunmaktadır. Örnek dashboard dış servisinden -> cluster-controller -> sidecar şeklinde bir erişim tipinde controller-manager üzerinde hem kendi call-servisleri hem de sidecar için proxy katmanı eklenebilir bu durumda direkt olarak sidecar veya herhangi alt servisler için namespace ayırarak ona proxy katmanı ile erişebilirsiniz.
- Go 1.16 veya üzeri
- Node.js 14 veya üzeri
- pnpm
-
Go Modüllerini Yükleyin:
Modül yüklemeye gerek yoktur. Direkt olarak:
github.com/hasirciogli/x-protocol/packages/go/packages
şeklinde import edebilirsiniz.
-
Örnek Server Oluşturun: main.go dosyasını aşağıdaki gibi oluşturun.
package main import ( "encoding/json" "github.com/hasirciogli/x-protocol/packages/go/packages" ) type HelloPayload struct { Message string `json:"message"` Name string `json:"name"` } func main() { server := packages.NewXProtocolServer("localhost", 8080) server.RegisterCall("hello", func(payload json.RawMessage) json.RawMessage { var p HelloPayload p.Message = "hello" p.Name = "world" str, err := json.Marshal(p) if err != nil { return json.RawMessage(`{"error": "` + err.Error() + `"}`) } return json.RawMessage(str) }) server.Start() }
-
Uygulamayı Başlatın: main.go dosyasını aşağıdaki gibi çalıştırın.
go run main.go
-
Nodejs Paketlerini Yükleyin:
pnpm add x-protocol
-
Örnek Client Oluşturun:
import { XProtocolClient } from "x-protocol"; const client = new XProtocolClient("localhost", 8080); const response = await client.call("hello", { name: "world" }); console.log(response);
Özellik | Açıklama |
---|---|
RPC Çağrıları | RPC tabanlı çağrılar ile hızlı iletişim. |
Modüler Yapı | Her bir bileşen ayrı paketlerde. |
Farklı diller | Go, TypeScript, Python, Java, C#, vb. |
Kolay Kullanım | Kullanıcı dostu arayüz ve dokümantasyon. |
RPC çağrıları yapmak için aşağıdaki örnekleri inceleyebilirsiniz:
// Go tarafında x-protocol çağrısı
response, err := client.Call("RegisteredCallAction", args)
if err != nil {
log.Fatal(err)
}
// TypeScript tarafında x-protocol çağrısı
const response = await client.call("RegisteredCallAction", args);
Katkılarınızı bekliyoruz! Lütfen aşağıdaki adımları izleyerek katkıda bulunun:
- Forklayın
- Yeni bir dal oluşturun (
git checkout -b feature/YourFeature
) - Değişikliklerinizi yapın ve commit edin (
git commit -m 'Add some feature'
) - Dalınızı gönderin (
git push origin feature/YourFeature
) - Bir Pull Request açın
Bu proje MIT Lisansı altında lisanslanmıştır.
Herhangi bir sorunuz veya öneriniz varsa, lütfen benimle iletişime geçin:
- E-posta: mhasirciogli@gmail.com
- GitHub: hasirciogli
Teşekkürler! Projemi incelediğiniz için teşekkür ederiz!
.
Test yapılırken homelab kullanıldı cloudflare zerotrust ile dışarıya açılıp ağ gecikmesi ile beraber olası kopmalar göz önüne alınarak test yapıldı. Ayrıca tek makineden yapıldığı için hata oluştu, multi node ile test yapılsaydı veya proxy ile bu hatalar oluşmazdı.
connection-test.ts dosyasında test yapılmıştır. Dilerseniz kendi testlerinizi yapabilirsiniz.
npx tsx connection-test.ts
Test sonucu:
Test tamamlandı!
Test süresi: 241.42 saniye
Toplam istek sayısı: 17000
Başarı sayısı: 16996
Hata sayısı: 4
Başarı oranı: 99.98%
Hata oranı: 0.02%