Konsul - Architektura

Schemat architektury konsula pracującego w jednym centrum danych można najlepiej opisać, jak pokazano poniżej -

Jak widać, istnieją trzy różne serwery, którymi zarządza Consul. Działająca architektura działa w oparciu o algorytm raft, który pomaga nam w wyborze lidera spośród trzech różnych serwerów. Te serwery są następnie oznaczane zgodnie z tagami, takimi jakFollower i Leader. Jak sama nazwa wskazuje, podążający jest odpowiedzialny za podążanie za decyzjami lidera. Wszystkie te trzy serwery są dalej połączone ze sobą w celu zapewnienia komunikacji.

Każdy serwer współdziała ze swoim własnym klientem przy użyciu koncepcji RPC. Komunikacja pomiędzy Klientami jest możliwa dziękiGossip Protocoljak wspomniano niżej. Komunikacja z internetem może być udostępniana za pomocą protokołu TCP lub komunikacji plotkarskiej. Ta komunikacja jest w bezpośrednim kontakcie z dowolnym z trzech serwerów.

Algorytm tratwy

Raft to algorytm konsensusu służący do zarządzania replikowanym dziennikiem. Opiera się na zasadzieCAP Theorem, która stwierdza, że ​​w przypadku partycji sieciowej należy wybierać między spójnością a dostępnością. Nie wszystkie trzy podstawy twierdzenia CAP można osiągnąć w dowolnym momencie. W najlepszym przypadku trzeba poświęcić dowolne dwa z nich.

ZA Raft Clusterzawiera kilka serwerów, zwykle w liczbie nieparzystej. Na przykład, jeśli mamy pięć serwerów, pozwoli to systemowi tolerować dwie awarie. W dowolnym momencie każdy serwer znajduje się w jednym z trzech stanów:Leader, Followerlub Candidate. Podczas normalnej operacji jest dokładnie jeden lider, a wszystkie pozostałe serwery są obserwatorami. Zwolennicy ci są w stanie pasywnym, tzn. Sami nie wysuwają próśb, ale po prostu odpowiadają na prośby liderów i kandydata.

Poniższa ilustracja przedstawia model przepływu pracy, w którym działa algorytm tratwy -

Kluczowe dane wartości

Od wersji 0.7.1 Konsula wprowadzono osobne dane dotyczące kluczowych wartości. Polecenie KV służy do interakcji z magazynem wartości kluczy Konsula za pośrednictwem wiersza poleceń. Udostępnia polecenia najwyższego poziomu dlaInserting, Updating, Reading i Deletingze sklepu. Aby uzyskać składnicę obiektów Klucz / Wartość, wywołujemy metodę KV dostępną dla klienta konsula -

kv := consul.KV()

Plik KVPair Structuresłuży do reprezentowania pojedynczego wpisu klucz / wartość. Strukturę Consul KV Pair możemy obejrzeć w poniższym programie.

type KVPair struct {
   Key string
   CreateIndex uint64
   ModifyIndex uint64
   LockIndex uint64
   Flags uint64
   Value []byte
   Session string
}

Tutaj różne struktury wymienione w powyższym kodzie można zdefiniować w następujący sposób -

  • Key- Jest to nazwa adresu URL z ukośnikiem. Na przykład - sites / 1 / domain.

  • CreateIndex - Numer indeksu przypisany podczas pierwszego tworzenia klucza.

  • ModifyIndex - Numer indeksu przypisany podczas ostatniej aktualizacji klucza.

  • LockIndex - Numer indeksu utworzony po uzyskaniu nowej blokady na wejściu klucza / wartości

  • Flags - Może być używany przez aplikację do ustawiania wartości niestandardowej.

  • Value - Jest to tablica bajtów o maksymalnej wielkości 512 kB.

  • Session - Można ustawić po utworzeniu obiektu sesji.

Rodzaje protokołów

W Consul są dwa typy protokołów, które nazywane są -

  • Protokół konsensusu i
  • Protokół plotek

Zrozummy je teraz szczegółowo.

Protokół konsensusu

Protokół konsensusu jest używany przez firmę Consul w celu zapewnienia spójności zgodnie z opisem w twierdzeniu CAP. Ten protokół jest oparty na algorytmie Raft. Podczas implementacji protokołu Consensus, algorytm tratwy jest używany, gdy węzły tratwy są zawsze w jednym z trzech stanów: Follower, Candidate lub Leader.

Protokół plotek

Protokół plotek może służyć do zarządzania członkostwem oraz wysyłania i odbierania wiadomości w klastrze. W konsulu użycie protokołu plotkarskiego występuje na dwa sposoby:WAN (Sieć bezprzewodowa) i LAN(Sieć lokalna). Istnieją trzy znane biblioteki, które mogą implementować algorytm Gossip do wykrywania węzłów w sieci peer-to-peer -

  • teknek-gossip - Działa z UDP i jest napisany w Javie.

  • gossip-python - Wykorzystuje stos TCP i możliwe jest również współdzielenie danych poprzez zbudowaną sieć.

  • Smudge - Jest napisany w Go i wykorzystuje UDP do wymiany informacji o statusie.

Protokoły plotek zostały również wykorzystane do osiągnięcia i utrzymania spójności rozproszonej bazy danych lub z innymi typami danych w spójnych stanach, zliczania węzłów w sieci o nieznanej wielkości, niezawodnego rozpowszechniania wiadomości, organizowania węzłów itp.

Zdalne wywołania procedur

RPC można określić jako krótką formę dla zdalnych wywołań procedur. Jest to protokół, którego jeden program używa do żądania usługi od innego programu. Protokół ten może znajdować się na innym komputerze w sieci bez konieczności potwierdzania szczegółów sieci.

Prawdziwe piękno korzystania z RPC w Consul polega na tym, że pomaga nam uniknąć problemów z opóźnieniami, które większość narzędzi usługi wykrywania miała jakiś czas temu. Przed RPC konsul miał tylkoTCP i UDPoparte na połączeniach, które były dobre w większości systemów, ale nie w przypadku systemów rozproszonych. RPC rozwiązuje takie problemy, skracając czas przesyłania informacji pakietowych z jednego miejsca do drugiego. W tym obszarze GRPC od Google jest doskonałym narzędziem, na które warto spojrzeć w przypadku, gdyby ktoś chciał obserwować testy porównawcze i porównywać wydajność.