Kurulum
@grpc/grpc-js ve yaml isteğe bağlı peer bağımlılıklardır. Yalnızca gRPC istemcisini (veya YAML yapılandırmasını) kullanıyorsanız kurun.
İstemciyi oluşturma
Tüm seçeneklerin ayarlı olduğu bir istemci:Builder yöntemleri
.url(url) - Birincil gRPC uç noktası. ORBITFLARE_GRPC_URL ortam değişkenine düşer.
.urls([...]) - Tek çağrıda birincil + yedekler. İlk eleman birincildir.
.fallbackUrl(url) / .fallbackUrls([...]) - Yedek uç noktalar ekler. Bağlantı hatasında SDK aralarında döner.
.retry(policy) - Yeniden bağlanma geri çekilmesini denetler. Bağlantı koptuğunda SDK önce initialDelayMs bekler, sonra her denemede gecikmeyi iki katına çıkarır (maxDelayMs ile sınırlı). maxAttempts değerini 0 yaparak sonsuz yeniden deneme ayarlayın. Varsayılan: 100 ms başlangıç, 30 sn üst sınır, 2x çarpan, sonsuz.
.timeoutSecs(n) - İstek başına gRPC zaman aşımı. Varsayılan: 30.
.keepaliveSecs(n) - TCP keepalive aralığı. İşletim sistemi bu aralıkta ölü bağlantıları TCP düzeyinde tespit etmek için probe gönderir. Varsayılan: 60.
.pingIntervalSecs(n) - SDK’nın sunucuya proto düzeyinde Ping gönderme sıklığı. Sunucunun Pong ile yanıt vermesi beklenir. Varsayılan: 10.
.maxMissedPongs(n) - SDK’nın bağlantıyı ölü sayıp yeniden bağlanmadan önce ardışık kaç ping’in yanıtsız kalabileceği. Varsayılan: 3. Varsayılanlarla ölü bağlantı yaklaşık 30 saniye içinde tespit edilir.
.channelCapacity(n) - Arka plan görevi ile kodunuz arasındaki sınırlı tampon. Olayları tüketmek yavaşsa ve bu dolarsa arka plan görevi sınırsız bellek yemek yerine duraklar. Varsayılan: 4096.
YAML yapılandırması yazma
İstediğiniz filtrelerle bir YAML dosyası oluşturun:YAML filtre referansı
transactions - her giriş adlı bir filtredir. Bir işlem account_include adreslerinden herhangi birini içeriyorsa eşleşir. account_exclude eşleşmeleri çıkarır. account_required listelenen tüm adreslerin bulunmasını gerektirir. vote ve failed işlem tipine göre filtreler.
accounts - adresle belirli hesapları izleyin veya owner ile bir programa ait tüm hesapları izleyin.
slots - slot güncellemelerine abone olun. filter_by_commitment yalnızca taahhüt düzeyinizdeki güncellemeleri gönderir.
commitment - 'processed', 'confirmed' veya 'finalized'. Varsayılan: 'confirmed'.
YAML ${ENV_VAR} genişletmesini destekler:
Olaylara abone olma ve okuma
YAML’dan
Programatik olarak
Çalışma zamanında oluşturulan dinamik filtreler için:Akışı okuma
HemsubscribeYaml hem subscribe bir GeyserStream döndürür. Bu bir async iterable’dır - for await kullanın:
await stream.next() çağırın. Akış kapalıysa undefined döner. Yeniden denemeler tükendiyse bir sonraki iterasyon hata fırlatır.
Pong iletileri dahili tüketilir ve akışınızda asla görünmez.
Kapatma
Birden çok akış
Tek istemci aynı anda birçok akış çalıştırabilir. Her biri kendi arka plan bağlantısını alır:Tam örnek
pump.fun işlemlerini izleyen, imzayı çözen ve her biri için bir özet yazdıran bir akış.grpc.yml ile: