Python Blockchain - Membuat Penambang

Untuk memungkinkan penambangan, kita perlu mengembangkan fungsi penambangan. Fungsionalitas penambangan perlu menghasilkan intisari pada string pesan tertentu dan memberikan bukti kerja. Mari kita bahas ini di bab ini.

Fungsi Intisari Pesan

Kami akan menulis fungsi utilitas yang disebut sha256 untuk membuat intisari pada pesan tertentu -

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

Itu sha256 fungsi membutuhkan message sebagai parameter, mengkodekannya ke ASCII, menghasilkan intisari heksadesimal dan mengembalikan nilai ke pemanggil.

Fungsi Penambangan

Kami sekarang mengembangkan minefungsi yang menerapkan strategi penambangan kami sendiri. Strategi kami dalam kasus ini adalah menghasilkan hash pada pesan tertentu yang diawali dengan angka 1 tertentu. Jumlah 1 yang ditentukan ditetapkan sebagai parameter kemine fungsi yang ditentukan sebagai tingkat kesulitan.

Misalnya, jika Anda menentukan tingkat kesulitan 2, hash yang dihasilkan pada pesan tertentu harus dimulai dengan dua angka 1 - seperti 11xxxxxxxx. Jika tingkat kesulitannya 3, hash yang dihasilkan harus dimulai dengan tiga angka 1 - seperti 111xxxxxxxx. Dengan persyaratan ini, kami sekarang akan mengembangkan fungsi penambangan seperti yang ditunjukkan pada langkah-langkah yang diberikan di bawah ini.

Langkah 1

Fungsi penambangan mengambil dua parameter - pesan dan tingkat kesulitan.

def mine(message, difficulty=1):

Langkah 2

Tingkat kesulitan harus lebih besar atau sama dengan 1, kami memastikan ini dengan pernyataan assert berikut -

assert difficulty >= 1

LANGKAH 3

Kami membuat prefix variabel menggunakan tingkat kesulitan yang ditetapkan.

prefix = '1' * difficulty

Perhatikan jika tingkat kesulitannya adalah 2, awalannya adalah "11" dan jika tingkat kesulitannya adalah 3, awalannya adalah "111", dan seterusnya. Kami akan memeriksa apakah prefiks ini ada di intisari pesan yang dihasilkan. Untuk mencerna pesan itu sendiri, kami menggunakan dua baris kode berikut -

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

Kami terus menambahkan nomor baru ike hash pesan di setiap iterasi dan menghasilkan intisari baru pada pesan gabungan. Sebagai masukan untuksha256 fungsi berubah di setiap iterasi, file digestnilai juga akan berubah. Kami memeriksa apakah inidigest nilai telah ditetapkan di atas prefix.

if digest.startswith(prefix):

Jika kondisi terpenuhi, kami akan menghentikan for ulangi dan kembalikan digest nilai bagi pemanggil.

Seluruhnya mine kode ditampilkan di sini -

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

Untuk pengertian Anda, kami telah menambahkan print pernyataan yang mencetak nilai intisari dan jumlah iterasi yang diperlukan untuk memenuhi kondisi sebelum kembali dari fungsi.

Menguji Fungsi Penambangan

Untuk menguji fungsi penambangan kami, cukup jalankan pernyataan berikut -

mine ("test message", 2)

Ketika Anda menjalankan kode di atas, Anda akan melihat output yang mirip dengan yang di bawah ini -

after 138 iterations found nonce:
11008a740eb2fa6bf8d55baecda42a41993ca65ce66b2d3889477e6bfad1484c

Perhatikan bahwa intisari yang dihasilkan dimulai dengan "11". Jika Anda mengubah tingkat kesulitan menjadi 3, intisari yang dihasilkan akan dimulai dengan "111", dan tentu saja, ini mungkin akan membutuhkan lebih banyak jumlah iterasi. Seperti yang Anda lihat, penambang dengan lebih banyak kekuatan pemrosesan akan dapat menambang pesan yang diberikan sebelumnya. Begitulah cara para penambang bersaing satu sama lain untuk mendapatkan pendapatan mereka.

Sekarang, kami siap menambahkan lebih banyak blok ke blockchain kami. Mari kita pelajari ini di bab selanjutnya.