Klasik Konsensüs Protokolleri, 1970’li yıllardan itibaren üzerine araştırma yapılan ve geliştirilen bir konsensüs ailesidir.
Bu protokollerin ortak ve ayırıcı özelliği, “point to point” iletişim yapılmasıdır. Bu iletişim türünde tüm nodelar birbirleriyle iletişim kurarlar.
(2/9)
Çok fazla nodeun bulunduğu bir ağda, point to point iletişim sonucu çok fazla mesaj trafiği olacağından dolayı ağ yavaşlamaya başlar. Bu sebeple klasik konsensüs protokolü kullanan ağlar, genel olarak az sayıda node bulundururlar.⛓
(3/9)
Klasik Konsensüs Protokolleri ailesinin en önemli üyesi “pBFT (Practical Byzantine Fault Tolerance) konsensüs protokolü”dür.💎
Algoritmik olarak “f” adet Bizanslı nodeun bulunduğu ağda “2f+1” adet dürüst node bulunduğu takdirde sorunsuz çalışır.🖇
(4/9)
Yani ağın sorunsuz çalışabilmesi için konsensüse katılan nodeların %33’ünden fazlası kötü niyetli olmamalıdır.
pBFT ile çalışan blokzinciri ağlarında her node aynı durumu taşır. pBFT, asenkron ağlarda çalışmak üzere tasarlanmıştır.⚜️
(5/9)
Klasik Konsensüs Protokolleri ailesinin bir diğer üyesi ise 2014 yılında duyurulan “Tendermint Core”dur.
Tendermint Core da BFT bir konsensüstür. Ağın sorunsuz çalışması için kötü niyetli node oranı %33’ün altında kalmalıdır.
(6/9)
Tendermint Core algoritmasında nodelar, validator (onaylayıcı) olmak için belirli miktarda para kilitlemek zorundadırlar.💵
Dürüst davranmayan onaylayıcılar cezalandırılır.
(7/9)
pBFT algoritmasında yeni blok “Lider” seçilen node tarafından ağa önerilirken Tendermint algoritmasında onaylayıcılar ağa blok önerirler.
Tendermint’te hangi onaylayıcının blok önereceği, onaylayıcının oylama gücüne (stake miktarına) bağlıdır. 🗳
(8/9)
Klasik Konsensüs Protokollerinde “deterministic finality” görülür. Ağdaki işlemlerin sonlanması için tüm düğümlerin onayı gereklidir.☑️
Serimiz Paxos Konsensüs Protokolü ile devam edecek.🔎💜
(9/9)
• • •
Missing some Tweet in this thread? You can try to
force a refresh
#Konsensüs Protokolleri
Herhangi bir otoritenin bulunmadığı, merkeziyetsiz sistemlerde ağa katılan ve karar mekanizmasında yer alan nodelar, ağın durumunun doğruluğu için bir anlaşmaya varmalıdır.🙌🏻
🤔 Konsensüs, #blokzinciri ağındaki dağıtık nodeların, yeni bloğa hangi işlemlerin kaydedileceği ve zincire hangi bloğun ekleneceği konusunda anlaşmaya varmalarıdır.
Konsensüs protokolleri ise, nodeların konsensüse nasıl varacaklarını belirleyen standartlardır.〰
(2/6)
Bir blokzinciri ağının konsensüse ulaşabilmesi için 3 temel özellik barındırması gerekir;
1️⃣ Sonlandırma, tüm doğru işlemler bir çıktı oluşturmalı,
2️⃣ Anlaşma, her node aynı kararı vermeli,
3️⃣ Geçerlilik, her karar bir girdi tarafından tetiklenmiş olmalı.