Python Blockchain - Madenciler Yaratmak

Madenciliği mümkün kılmak için bir madencilik işlevi geliştirmemiz gerekiyor. Madencilik işlevselliğinin, belirli bir mesaj dizisi üzerinde bir özet oluşturması ve bir çalışma kanıtı sağlaması gerekir. Bunu bu bölümde tartışalım.

Mesaj Özeti İşlevi

Adlı bir yardımcı program işlevi yazacağız sha256 belirli bir mesajla ilgili bir özet oluşturmak için -

def sha256(message):
return hashlib.sha256(message.encode('ascii')).hexdigest()

sha256 fonksiyon alır message parametre olarak, bunu ASCII'ye kodlar, onaltılık bir özet oluşturur ve değeri arayana geri döndürür.

Madencilik İşlevi

Şimdi geliştiriyoruz minekendi madencilik stratejimizi uygulayan işlev. Bu durumda stratejimiz, verilen mesajda belirli sayıda 1'in önüne eklenmiş bir karma oluşturmak olacaktır. Verilen 1 sayısı bir parametre olarak belirtilirmine zorluk seviyesi olarak belirtilen fonksiyon.

Örneğin, 2'lik bir zorluk seviyesi belirlerseniz, belirli bir mesajda oluşturulan hash, 11xxxxxxxx gibi iki 1'le başlamalıdır. Zorluk seviyesi 3 ise, üretilen hash 111xxxxxxxx gibi üç adet 1 ile başlamalıdır. Bu gereksinimler göz önüne alındığında, şimdi aşağıda verilen adımlarda gösterildiği gibi madencilik işlevini geliştireceğiz.

Aşama 1

Madencilik işlevi iki parametre alır - mesaj ve zorluk seviyesi.

def mine(message, difficulty=1):

Adım 2

Zorluk seviyesinin 1'e eşit veya daha büyük olması gerekir, bunu aşağıdaki assert ifadesiyle sağlıyoruz -

assert difficulty >= 1

Aşama 3

Bir prefix ayarlanan zorluk seviyesini kullanarak değişken.

prefix = '1' * difficulty

Zorluk seviyesi 2 ise önek "11", zorluk seviyesi 3 ise önek "111" olacaktır, vb. Mesajın oluşturulan özetinde bu önekin var olup olmadığını kontrol edeceğiz. Mesajın kendisini sindirmek için aşağıdaki iki kod satırını kullanıyoruz -

for i in range(1000):
   digest = sha256(str(hash(message)) + str(i))

Yeni bir numara eklemeye devam ediyoruz iher yinelemede mesaj karmasına ekleyin ve birleştirilmiş mesajda yeni bir özet oluşturun. Girdi olaraksha256 her yinelemede işlev değişir, digestdeğer de değişirdi. Bunu kontrol ediyoruzdigest değer yukarıda ayarlanmış prefix.

if digest.startswith(prefix):

Koşul yerine getirilirse, sonlandıracağız for döngü ve döndür digest arayan için değer.

Tüm mine kod burada gösterilmektedir -

def mine(message, difficulty=1):
   assert difficulty >= 1
   prefix = '1' * difficulty
   for i in range(1000):
      digest = sha256(str(hash(message)) + str(i))
      if digest.startswith(prefix):
         print ("after " + str(i) + " iterations found nonce: "+ digest)
      return digest

Anlayışınız için ekledik print Özet değerini ve işlevden dönmeden önce koşulu karşılamak için gereken yineleme sayısını yazdıran deyim.

Madencilik Fonksiyonunun Test Edilmesi

Madencilik fonksiyonumuzu test etmek için aşağıdaki ifadeyi uygulamanız yeterlidir -

mine ("test message", 2)

Yukarıdaki kodu çalıştırdığınızda, çıktının aşağıdakine benzer olduğunu göreceksiniz -

after 138 iterations found nonce:
11008a740eb2fa6bf8d55baecda42a41993ca65ce66b2d3889477e6bfad1484c

Oluşturulan özetin "11" ile başladığına dikkat edin. Zorluk seviyesini 3 olarak değiştirirseniz, oluşturulan özet "111" ile başlayacak ve elbette muhtemelen daha fazla sayıda yineleme gerektirecektir. Gördüğünüz gibi, daha fazla işlem gücüne sahip bir madenci, verilen bir mesajı daha önce çıkarabilir. Madenciler gelir elde etmek için birbirleriyle bu şekilde rekabet ediyor.

Artık blok zincirimize daha fazla blok eklemeye hazırız. Bunu bir sonraki bölümümüzde öğrenelim.