முக்கிய உள்ளடக்கத்திற்குச் செல்லவும்

லோக்கல், மல்டி-கிளையன்ட் டெஸ்ட்நெட்டில் dApp-ஐ உருவாக்கி சோதிப்பது எப்படி

கிளையன்ட்கள்
நோடுகள்
ஸ்மார்ட் ஒப்பந்தங்கள்
தொகுக்கக்கூடிய தன்மை
கருத்தொற்றுமை அடுக்கு
செயலாக்க அடுக்கு
சோதனை
இடைநிலையாளர்
டெடி மிதிகு
11 ஏப்ரல், 2023
9 நிமிட வாசிப்பு

அறிமுகம்

உள்ளமைக்கக்கூடிய லோக்கல் Ethereum டெஸ்ட்நெட்டை உருவாக்குவது, அதில் ஒரு ஸ்மார்ட் ஒப்பந்தத்தை டிப்ளாய் செய்வது மற்றும் உங்கள் dApp-ஐ சோதிக்க டெஸ்ட்நெட்டைப் பயன்படுத்துவது ஆகிய செயல்முறைகளை இந்த வழிகாட்டி விளக்குகிறது. லைவ் டெஸ்ட்நெட் அல்லது மெயின்நெட்டில் டிப்ளாய் செய்வதற்கு முன்பு, வெவ்வேறு நெட்வொர்க் உள்ளமைவுகளுக்கு எதிராக தங்கள் dApp-களை லோக்கலாக உருவாக்கி சோதிக்க விரும்பும் dApp டெவலப்பர்களுக்காக இந்த வழிகாட்டி வடிவமைக்கப்பட்டுள்ளது.

இந்த வழிகாட்டியில், நீங்கள்:

  • Kurtosis (opens in a new tab)-ஐப் பயன்படுத்தி eth-network-package (opens in a new tab) உடன் லோக்கல் Ethereum டெஸ்ட்நெட்டை உருவாக்குவீர்கள்,
  • dApp-ஐ கம்பைல் செய்ய, டிப்ளாய் செய்ய மற்றும் சோதிக்க உங்கள் Hardhat dApp மேம்பாட்டுச் சூழலை லோக்கல் டெஸ்ட்நெட் உடன் இணைப்பீர்கள், மற்றும்
  • பல்வேறு நெட்வொர்க் உள்ளமைவுகளுக்கு எதிராக மேம்பாடு மற்றும் சோதனைப் பணிப்பாய்வுகளைச் செயல்படுத்த, நோடுகளின் எண்ணிக்கை மற்றும் குறிப்பிட்ட EL/CL கிளையன்ட் இணைப்புகள் போன்ற அளவுருக்கள் உட்பட லோக்கல் டெஸ்ட்நெட்டை உள்ளமைப்பீர்கள்.

Kurtosis என்றால் என்ன?

Kurtosis (opens in a new tab) என்பது மல்டி-கண்டெய்னர் சோதனைச் சூழல்களை உள்ளமைக்க வடிவமைக்கப்பட்ட ஒரு தொகுக்கக்கூடிய பில்ட் சிஸ்டம் ஆகும். பிளாக்செயின் டெஸ்ட்நெட்கள் போன்ற டைனமிக் அமைவு லாஜிக் தேவைப்படும் மீண்டும் உருவாக்கக்கூடிய சூழல்களை உருவாக்க இது டெவலப்பர்களுக்கு குறிப்பாக உதவுகிறது.

இந்த வழிகாட்டியில், Kurtosis eth-network-package ஆனது geth (opens in a new tab) செயலாக்க அடுக்கு (EL) கிளையன்ட், அத்துடன் teku (opens in a new tab), lighthouse (opens in a new tab), மற்றும் lodestar (opens in a new tab) கருத்தொற்றுமை அடுக்கு (CL) கிளையன்ட்களுக்கான ஆதரவுடன் லோக்கல் Ethereum டெஸ்ட்நெட்டை உருவாக்குகிறது. இந்த பேக்கேஜ் Hardhat Network, Ganache மற்றும் Anvil போன்ற ஃபிரேம்வொர்க்குகளில் உள்ள நெட்வொர்க்குகளுக்கு உள்ளமைக்கக்கூடிய மற்றும் தொகுக்கக்கூடிய மாற்றாக செயல்படுகிறது. Kurtosis டெவலப்பர்கள் பயன்படுத்தும் டெஸ்ட்நெட்கள் மீது அதிக கட்டுப்பாட்டையும் நெகிழ்வுத்தன்மையையும் வழங்குகிறது, இதுவே Ethereum Foundation மெர்ஜை சோதிக்க Kurtosis-ஐப் பயன்படுத்தியதற்கும் (opens in a new tab) நெட்வொர்க் மேம்படுத்தல்களைச் சோதிக்க தொடர்ந்து அதைப் பயன்படுத்துவதற்கும் முக்கிய காரணமாகும்.

Kurtosis-ஐ அமைத்தல்

நீங்கள் தொடர்வதற்கு முன், உங்களிடம் இவை இருப்பதை உறுதிசெய்யவும்:

லோக்கல் Ethereum டெஸ்ட்நெட்டை உருவாக்குதல்

லோக்கல் Ethereum டெஸ்ட்நெட்டை உருவாக்க, இதை இயக்கவும்:

1kurtosis --enclave local-eth-testnet run github.com/kurtosis-tech/eth-network-package

குறிப்பு: இந்தக் கட்டளை --enclave ஃபிளாக்கைப் பயன்படுத்தி உங்கள் நெட்வொர்க்கிற்கு "local-eth-testnet" என்று பெயரிடுகிறது.

Kurtosis வழிமுறைகளை விளக்கவும், சரிபார்க்கவும், பின்னர் செயல்படுத்தவும் செயல்படும்போது, அது பின்னணியில் எடுக்கும் படிகளை அச்சிடும். முடிவில், பின்வருவனவற்றை ஒத்த ஒரு வெளியீட்டை நீங்கள் காண வேண்டும்:

1INFO[2023-04-04T18:09:44-04:00] ======================================================
2INFO[2023-04-04T18:09:44-04:00] || Created enclave: local-eth-testnet ||
3INFO[2023-04-04T18:09:44-04:00] ======================================================
4Name: local-eth-testnet
5UUID: 39372d756ae8
6Status: RUNNING
7Creation Time: Tue, 04 Apr 2023 18:09:03 EDT
8
9========================================= Files Artifacts =========================================
10UUID Name
11d4085a064230 cl-genesis-data
121c62cb792e4c el-genesis-data
13bd60489b73a7 genesis-generation-config-cl
14b2e593fe5228 genesis-generation-config-el
15d552a54acf78 geth-prefunded-keys
165f7e661eb838 prysm-password
17054e7338bb59 validator-keystore-0
18
19========================================== User Services ==========================================
20UUID Name Ports Status
21e20f129ee0c5 cl-client-0-beacon http: 4000/tcp -> <http://127.0.0.1:54261> RUNNING
22 metrics: 5054/tcp -> <http://127.0.0.1:54262>
23 tcp-discovery: 9000/tcp -> 127.0.0.1:54263
24 udp-discovery: 9000/udp -> 127.0.0.1:60470
25a8b6c926cdb4 cl-client-0-validator http: 5042/tcp -> 127.0.0.1:54267 RUNNING
26 metrics: 5064/tcp -> <http://127.0.0.1:54268>
27d7b802f623e8 el-client-0 engine-rpc: 8551/tcp -> 127.0.0.1:54253 RUNNING
28 rpc: 8545/tcp -> 127.0.0.1:54251
29 tcp-discovery: 30303/tcp -> 127.0.0.1:54254
30 udp-discovery: 30303/udp -> 127.0.0.1:53834
31 ws: 8546/tcp -> 127.0.0.1:54252
32514a829c0a84 prelaunch-data-generator-1680646157905431468 <none> STOPPED
3362bd62d0aa7a prelaunch-data-generator-1680646157915424301 <none> STOPPED
3405e9619e0e90 prelaunch-data-generator-1680646157922872635 <none> STOPPED
35
அனைத்தையும் காட்டு

வாழ்த்துகள்! Docker மூலம் CL (lighthouse) மற்றும் EL கிளையன்ட் (geth) உடன் லோக்கல் Ethereum டெஸ்ட்நெட்டை உருவாக்க Kurtosis-ஐப் பயன்படுத்தியுள்ளீர்கள்.

மதிப்பாய்வு

இந்தப் பிரிவில், Kurtosis Enclave (opens in a new tab)-க்குள் லோக்கல் Ethereum டெஸ்ட்நெட்டை உருவாக்க GitHub-இல் ரிமோட்டாக ஹோஸ்ட் செய்யப்பட்ட eth-network-package (opens in a new tab)-ஐப் பயன்படுத்த Kurtosis-க்கு வழிகாட்டும் கட்டளையை நீங்கள் செயல்படுத்தினீர்கள். உங்கள் என்கிளேவுக்குள், "ஃபைல் ஆர்ட்டிஃபாக்ட்கள்" (file artifacts) மற்றும் "பயனர் சேவைகள்" (user services) இரண்டையும் நீங்கள் காண்பீர்கள்.

உங்கள் என்கிளேவில் உள்ள ஃபைல் ஆர்ட்டிஃபாக்ட்கள் (opens in a new tab) EL மற்றும் CL கிளையன்ட்களை பூட்ஸ்ட்ராப் செய்ய உருவாக்கப்பட்ட மற்றும் பயன்படுத்தப்பட்ட அனைத்து தரவையும் உள்ளடக்கியது. இந்த Docker இமேஜிலிருந்து (opens in a new tab) உருவாக்கப்பட்ட prelaunch-data-generator சேவையைப் பயன்படுத்தி தரவு உருவாக்கப்பட்டது.

பயனர் சேவைகள் உங்கள் என்கிளேவில் செயல்படும் அனைத்து கண்டெய்னரைஸ்டு சேவைகளையும் காண்பிக்கின்றன. EL கிளையன்ட் மற்றும் CL கிளையன்ட் இரண்டையும் கொண்ட ஒற்றை நோடு உருவாக்கப்பட்டிருப்பதை நீங்கள் கவனிப்பீர்கள்.

உங்கள் dApp மேம்பாட்டுச் சூழலை லோக்கல் Ethereum டெஸ்ட்நெட் உடன் இணைக்கவும்

dApp மேம்பாட்டுச் சூழலை அமைத்தல்

இப்போது உங்களிடம் இயங்கும் லோக்கல் டெஸ்ட்நெட் இருப்பதால், உங்கள் லோக்கல் டெஸ்ட்நெட்டைப் பயன்படுத்த உங்கள் dApp மேம்பாட்டுச் சூழலை இணைக்கலாம். உங்கள் லோக்கல் டெஸ்ட்நெட்டில் பிளாக்ஜாக் dApp-ஐ டிப்ளாய் செய்ய இந்த வழிகாட்டியில் Hardhat ஃபிரேம்வொர்க் பயன்படுத்தப்படும்.

உங்கள் dApp மேம்பாட்டுச் சூழலை அமைக்க, எங்கள் மாதிரி dApp-ஐக் கொண்ட ரெபாசிட்டரியை குளோன் செய்து அதன் சார்புகளை நிறுவ, இதை இயக்கவும்:

1git clone https://github.com/kurtosis-tech/awesome-kurtosis.git && cd awesome-kurtosis/smart-contract-example && yarn

இங்கு பயன்படுத்தப்படும் smart-contract-example (opens in a new tab) கோப்புறையானது Hardhat (opens in a new tab) ஃபிரேம்வொர்க்கைப் பயன்படுத்தும் dApp டெவலப்பருக்கான வழக்கமான அமைப்பைக் கொண்டுள்ளது:

  • contracts/ (opens in a new tab) பிளாக்ஜாக் dApp-க்கான சில எளிய ஸ்மார்ட் ஒப்பந்தங்களைக் கொண்டுள்ளது
  • scripts/ (opens in a new tab) உங்கள் லோக்கல் Ethereum நெட்வொர்க்கில் டோக்கன் ஒப்பந்தத்தை டிப்ளாய் செய்வதற்கான ஸ்கிரிப்டைக் கொண்டுள்ளது
  • test/ (opens in a new tab) எங்கள் பிளாக்ஜாக் dApp-இல் உள்ள ஒவ்வொரு பிளேயருக்கும் 1000 மின்ட் செய்யப்பட்டுள்ளதை உறுதிப்படுத்த உங்கள் டோக்கன் ஒப்பந்தத்திற்கான எளிய .js சோதனையைக் கொண்டுள்ளது
  • hardhat.config.ts (opens in a new tab) உங்கள் Hardhat அமைப்பை உள்ளமைக்கிறது

லோக்கல் டெஸ்ட்நெட்டைப் பயன்படுத்த Hardhat-ஐ உள்ளமைத்தல்

உங்கள் dApp மேம்பாட்டுச் சூழல் அமைக்கப்பட்டவுடன், Kurtosis-ஐப் பயன்படுத்தி உருவாக்கப்பட்ட லோக்கல் Ethereum டெஸ்ட்நெட்டைப் பயன்படுத்த இப்போது Hardhat-ஐ இணைப்பீர்கள். இதைச் செய்ய, உங்கள் hardhat.config.ts உள்ளமைவு கோப்பில் உள்ள localnet ஸ்ட்ரக்ட்டில் உள்ள <$YOUR_PORT>-ஐ ஏதேனும் el-client-<num> சேவையிலிருந்து rpc uri வெளியீட்டின் போர்ட்டுடன் மாற்றவும். இந்த மாதிரி வழக்கில், போர்ட் 64248 ஆக இருக்கும். உங்கள் போர்ட் வித்தியாசமாக இருக்கும்.

hardhat.config.ts-இல் உதாரணம்:

1localnet: {
2url: 'http://127.0.0.1:<$YOUR_PORT>', // TODO: $YOUR_PORT என்பதை ETH NETWORK KURTOSIS PACKAGE மூலம் உருவாக்கப்பட்ட NODE URI-இன் PORT-ஐக் கொண்டு மாற்றவும்
3
4// இவை eth-network-package மூலம் உருவாக்கப்பட்ட, முன்பே நிதியளிக்கப்பட்ட சோதனை கணக்குகளுடன் தொடர்புடைய தனிப்பட்ட திறவுகோல்கள் (private keys) ஆகும்
5// <https://github.com/kurtosis-tech/eth-network-package/blob/main/src/prelaunch_data_generator/genesis_constants/genesis_constants.star>
6accounts: [
7 "ef5177cd0b6b21c87db5a0bf35d4084a8a57a9d6a064f86d51ac85f2b873a4e2",
8 "48fcc39ae27a0e8bf0274021ae6ebd8fe4a0e12623d61464c498900b28feb567",
9 "7988b3a148716ff800414935b305436493e1f25237a2a03e5eebc343735e2f31",
10 "b3c409b6b0b3aa5e65ab2dc1930534608239a478106acf6f3d9178e9f9b00b35",
11 "df9bb6de5d3dc59595bcaa676397d837ff49441d211878c024eabda2cd067c9f",
12 "7da08f856b5956d40a72968f93396f6acff17193f013e8053f6fbb6c08c194d6",
13 ],
14},
அனைத்தையும் காட்டு

உங்கள் கோப்பைச் சேமித்தவுடன், உங்கள் Hardhat dApp மேம்பாட்டுச் சூழல் இப்போது உங்கள் லோக்கல் Ethereum டெஸ்ட்நெட் உடன் இணைக்கப்பட்டுள்ளது! இதை இயக்குவதன் மூலம் உங்கள் டெஸ்ட்நெட் செயல்படுகிறதா என்பதை நீங்கள் சரிபார்க்கலாம்:

1npx hardhat balances --network localnet

வெளியீடு இதுபோன்று இருக்க வேண்டும்:

10x878705ba3f8Bc32FCf7F4CAa1A35E72AF65CF766 has balance 10000000000000000000000000
20x4E9A3d9D1cd2A2b2371b8b3F489aE72259886f1A has balance 10000000000000000000000000
30xdF8466f277964Bb7a0FFD819403302C34DCD530A has balance 10000000000000000000000000
40x5c613e39Fc0Ad91AfDA24587e6f52192d75FBA50 has balance 10000000000000000000000000
50x375ae6107f8cC4cF34842B71C6F746a362Ad8EAc has balance 10000000000000000000000000
60x1F6298457C5d76270325B724Da5d1953923a6B88 has balance 10000000000000000000000000

Hardhat உங்கள் லோக்கல் டெஸ்ட்நெட்டைப் பயன்படுத்துகிறது என்பதையும், eth-network-package மூலம் உருவாக்கப்பட்ட முன்-நிதியளிக்கப்பட்ட கணக்குகளைக் கண்டறிகிறது என்பதையும் இது உறுதிப்படுத்துகிறது.

உங்கள் dApp-ஐ லோக்கலாக டிப்ளாய் செய்து சோதிக்கவும்

dApp மேம்பாட்டுச் சூழல் லோக்கல் Ethereum டெஸ்ட்நெட் உடன் முழுமையாக இணைக்கப்பட்டுள்ளதால், லோக்கல் டெஸ்ட்நெட்டைப் பயன்படுத்தி உங்கள் dApp-க்கு எதிராக மேம்பாடு மற்றும் சோதனைப் பணிப்பாய்வுகளை இப்போது இயக்கலாம்.

லோக்கல் புரோட்டோடைப்பிங் மற்றும் மேம்பாட்டிற்காக ChipToken.sol ஸ்மார்ட் ஒப்பந்தத்தை கம்பைல் செய்து டிப்ளாய் செய்ய, இதை இயக்கவும்:

1npx hardhat compile
2npx hardhat run scripts/deploy.ts --network localnet

வெளியீடு இதுபோன்று இருக்க வேண்டும்:

1ChipToken deployed to: 0xAb2A01BC351770D09611Ac80f1DE076D56E0487d

இப்போது எங்கள் பிளாக்ஜாக் dApp-இல் உள்ள ஒவ்வொரு பிளேயருக்கும் 1000 மின்ட் செய்யப்பட்டுள்ளதை உறுதிப்படுத்த உங்கள் லோக்கல் dApp-க்கு எதிராக simple.js சோதனையை இயக்க முயற்சிக்கவும்:

வெளியீடு இதுபோன்று இருக்க வேண்டும்:

1npx hardhat test --network localnet

வெளியீடு இதுபோன்று இருக்க வேண்டும்:

1ChipToken
2 mint
3 ✔ should mint 1000 chips for PLAYER ONE
4
5 1 passing (654ms)

மதிப்பாய்வு

இந்த கட்டத்தில், நீங்கள் இப்போது ஒரு dApp மேம்பாட்டுச் சூழலை அமைத்துள்ளீர்கள், Kurtosis உருவாக்கிய லோக்கல் Ethereum நெட்வொர்க்குடன் அதை இணைத்துள்ளீர்கள், மேலும் உங்கள் dApp-க்கு எதிராக ஒரு எளிய சோதனையை கம்பைல் செய்து, டிப்ளாய் செய்து, இயக்கியுள்ளீர்கள்.

இப்போது பல்வேறு நெட்வொர்க் உள்ளமைவுகளின் கீழ் எங்கள் dApp-களைச் சோதிக்க அடிப்படை நெட்வொர்க்கை எவ்வாறு உள்ளமைக்கலாம் என்பதை ஆராய்வோம்.

லோக்கல் Ethereum டெஸ்ட்நெட்டை உள்ளமைத்தல்

கிளையன்ட் உள்ளமைவுகள் மற்றும் நோடுகளின் எண்ணிக்கையை மாற்றுதல்

நீங்கள் உருவாக்க அல்லது சோதிக்க விரும்பும் காட்சி மற்றும் குறிப்பிட்ட நெட்வொர்க் உள்ளமைவைப் பொறுத்து, வெவ்வேறு EL மற்றும் CL கிளையன்ட் இணைகள் மற்றும் மாறுபட்ட நோடுகளின் எண்ணிக்கையைப் பயன்படுத்த உங்கள் லோக்கல் Ethereum டெஸ்ட்நெட்டை உள்ளமைக்கலாம். இதன் பொருள், அமைக்கப்பட்டவுடன், நீங்கள் தனிப்பயனாக்கப்பட்ட லோக்கல் டெஸ்ட்நெட்டை உருவாக்கலாம் மற்றும் எல்லாம் எதிர்பார்த்தபடி செயல்படுவதை உறுதிசெய்ய பல்வேறு நெட்வொர்க் உள்ளமைவுகளின் கீழ் அதே பணிப்பாய்வுகளை (டிப்ளாய்மென்ட், சோதனைகள் போன்றவை) இயக்க அதைப் பயன்படுத்தலாம். நீங்கள் மாற்றக்கூடிய பிற அளவுருக்கள் பற்றி மேலும் அறிய, இந்த இணைப்பைப் பார்வையிடவும்.

இதை முயற்சிக்கவும்! JSON கோப்பு வழியாக eth-network-package-க்கு பல்வேறு உள்ளமைவு விருப்பங்களை நீங்கள் அனுப்பலாம். இந்த நெட்வொர்க் அளவுருக்கள் JSON கோப்பு லோக்கல் Ethereum நெட்வொர்க்கை அமைக்க Kurtosis பயன்படுத்தும் குறிப்பிட்ட உள்ளமைவுகளை வழங்குகிறது.

இயல்புநிலை உள்ளமைவு கோப்பை எடுத்து, வெவ்வேறு EL/CL இணைகளுடன் இரண்டு நோடுகளை உருவாக்க அதைத் திருத்தவும்:

  • geth/lighthouse உடன் நோடு 1
  • geth/lodestar உடன் நோடு 2
  • geth/teku உடன் நோடு 3

இந்த உள்ளமைவு உங்கள் dApp-ஐச் சோதிப்பதற்காக Ethereum நோடு செயலாக்கங்களின் பன்முக நெட்வொர்க்கை உருவாக்குகிறது. உங்கள் உள்ளமைவு கோப்பு இப்போது இதுபோன்று இருக்க வேண்டும்:

1{
2 "participants":
3 [
4 {
5 "el_client_type": "geth",
6 "el_client_image": "",
7 "el_client_log_level": "",
8 "cl_client_type": "lighthouse",
9 "cl_client_image": "",
10 "cl_client_log_level": "",
11 "beacon_extra_params": [],
12 "el_extra_params": [],
13 "validator_extra_params": [],
14 "builder_network_params": null,
15 },
16 {
17 "el_client_type": "geth",
18 "el_client_image": "",
19 "el_client_log_level": "",
20 "cl_client_type": "lodestar",
21 "cl_client_image": "",
22 "cl_client_log_level": "",
23 "beacon_extra_params": [],
24 "el_extra_params": [],
25 "validator_extra_params": [],
26 "builder_network_params": null,
27 },
28 {
29 "el_client_type": "geth",
30 "el_client_image": "",
31 "el_client_log_level": "",
32 "cl_client_type": "teku",
33 "cl_client_image": "",
34 "cl_client_log_level": "",
35 "beacon_extra_params": [],
36 "el_extra_params": [],
37 "validator_extra_params": [],
38 "builder_network_params": null,
39 },
40 ],
41 "network_params":
42 {
43 "preregistered_validator_keys_mnemonic": "giant issue aisle success illegal bike spike question tent bar rely arctic volcano long crawl hungry vocal artwork sniff fantasy very lucky have athlete",
44 "num_validator_keys_per_node": 64,
45 "network_id": "3151908",
46 "deposit_contract_address": "0x4242424242424242424242424242424242424242",
47 "seconds_per_slot": 12,
48 "genesis_delay": 120,
49 "capella_fork_epoch": 5,
50 },
51}
அனைத்தையும் காட்டு

ஒவ்வொரு participants ஸ்ட்ரக்ட்டும் நெட்வொர்க்கில் உள்ள ஒரு நோடுடன் மேப் செய்யப்படுகிறது, எனவே 3 participants ஸ்ட்ரக்ட்கள் உங்கள் நெட்வொர்க்கில் 3 நோடுகளை உருவாக்க Kurtosis-க்குச் சொல்லும். ஒவ்வொரு participants ஸ்ட்ரக்ட்டும் அந்த குறிப்பிட்ட நோடிற்குப் பயன்படுத்தப்படும் EL மற்றும் CL இணையை குறிப்பிட உங்களை அனுமதிக்கும்.

network_params ஸ்ட்ரக்ட் ஒவ்வொரு நோடிற்கும் ஜெனிசிஸ் கோப்புகளை உருவாக்கப் பயன்படுத்தப்படும் நெட்வொர்க் அமைப்புகளையும், நெட்வொர்க்கின் ஒரு ஸ்லாட்டிற்கான வினாடிகள் போன்ற பிற அமைப்புகளையும் உள்ளமைக்கிறது.

நீங்கள் திருத்திய அளவுருக்கள் கோப்பை நீங்கள் விரும்பும் எந்த கோப்பகத்திலும் சேமிக்கவும் (கீழே உள்ள எடுத்துக்காட்டில், இது டெஸ்க்டாப்பில் சேமிக்கப்பட்டுள்ளது) பின்னர் இதை இயக்குவதன் மூலம் உங்கள் Kurtosis பேக்கேஜை இயக்க அதைப் பயன்படுத்தவும்:

1kurtosis clean -a && kurtosis run --enclave local-eth-testnet github.com/kurtosis-tech/eth-network-package "$(cat ~/eth-network-params.json)"

குறிப்பு: புதியதைத் தொடங்குவதற்கு முன் பழைய டெஸ்ட்நெட் மற்றும் அதன் உள்ளடக்கங்களை அழிக்க Kurtosis-க்கு அறிவுறுத்த kurtosis clean -a கட்டளை இங்கு பயன்படுத்தப்படுகிறது.

மீண்டும், Kurtosis சிறிது நேரம் செயல்படும் மற்றும் நடைபெறும் தனிப்பட்ட படிகளை அச்சிடும். இறுதியில், வெளியீடு இதுபோன்று இருக்க வேண்டும்:

1Starlark code successfully run. No output was returned.
2INFO[2023-04-07T11:43:16-04:00] ==========================================================
3INFO[2023-04-07T11:43:16-04:00] || Created enclave: local-eth-testnet ||
4INFO[2023-04-07T11:43:16-04:00] ==========================================================
5Name: local-eth-testnet
6UUID: bef8c192008e
7Status: RUNNING
8Creation Time: Fri, 07 Apr 2023 11:41:58 EDT
9
10========================================= Files Artifacts =========================================
11UUID Name
12cc495a8e364a cl-genesis-data
137033fcdb5471 el-genesis-data
14a3aef43fc738 genesis-generation-config-cl
158e968005fc9d genesis-generation-config-el
163182cca9d3cd geth-prefunded-keys
178421166e234f prysm-password
18d9e6e8d44d99 validator-keystore-0
1923f5ba517394 validator-keystore-1
204d28dea40b5c validator-keystore-2
21
22========================================== User Services ==========================================
23UUID Name Ports Status
24485e6fde55ae cl-client-0-beacon http: 4000/tcp -> http://127.0.0.1:65010 RUNNING
25 metrics: 5054/tcp -> http://127.0.0.1:65011
26 tcp-discovery: 9000/tcp -> 127.0.0.1:65012
27 udp-discovery: 9000/udp -> 127.0.0.1:54455
2873739bd158b2 cl-client-0-validator http: 5042/tcp -> 127.0.0.1:65016 RUNNING
29 metrics: 5064/tcp -> http://127.0.0.1:65017
301b0a233cd011 cl-client-1-beacon http: 4000/tcp -> 127.0.0.1:65021 RUNNING
31 metrics: 8008/tcp -> 127.0.0.1:65023
32 tcp-discovery: 9000/tcp -> 127.0.0.1:65024
33 udp-discovery: 9000/udp -> 127.0.0.1:56031
34 validator-metrics: 5064/tcp -> 127.0.0.1:65022
35949b8220cd53 cl-client-1-validator http: 4000/tcp -> 127.0.0.1:65028 RUNNING
36 metrics: 8008/tcp -> 127.0.0.1:65030
37 tcp-discovery: 9000/tcp -> 127.0.0.1:65031
38 udp-discovery: 9000/udp -> 127.0.0.1:60784
39 validator-metrics: 5064/tcp -> 127.0.0.1:65029
40c34417bea5fa cl-client-2 http: 4000/tcp -> 127.0.0.1:65037 RUNNING
41 metrics: 8008/tcp -> 127.0.0.1:65035
42 tcp-discovery: 9000/tcp -> 127.0.0.1:65036
43 udp-discovery: 9000/udp -> 127.0.0.1:63581
44e19738e6329d el-client-0 engine-rpc: 8551/tcp -> 127.0.0.1:64986 RUNNING
45 rpc: 8545/tcp -> 127.0.0.1:64988
46 tcp-discovery: 30303/tcp -> 127.0.0.1:64987
47 udp-discovery: 30303/udp -> 127.0.0.1:55706
48 ws: 8546/tcp -> 127.0.0.1:64989
49e904687449d9 el-client-1 engine-rpc: 8551/tcp -> 127.0.0.1:64993 RUNNING
50 rpc: 8545/tcp -> 127.0.0.1:64995
51 tcp-discovery: 30303/tcp -> 127.0.0.1:64994
52 udp-discovery: 30303/udp -> 127.0.0.1:58096
53 ws: 8546/tcp -> 127.0.0.1:64996
54ad6f401126fa el-client-2 engine-rpc: 8551/tcp -> 127.0.0.1:65003 RUNNING
55 rpc: 8545/tcp -> 127.0.0.1:65001
56 tcp-discovery: 30303/tcp -> 127.0.0.1:65000
57 udp-discovery: 30303/udp -> 127.0.0.1:57269
58 ws: 8546/tcp -> 127.0.0.1:65002
5912d04a9dbb69 prelaunch-data-generator-1680882122181135513 <none> STOPPED
605b45f9c0504b prelaunch-data-generator-1680882122192182847 <none> STOPPED
613d4aaa75e218 prelaunch-data-generator-1680882122201668972 <none> STOPPED
அனைத்தையும் காட்டு

வாழ்த்துகள்! உங்கள் லோக்கல் டெஸ்ட்நெட்டை 1-க்கு பதிலாக 3 நோடுகளைக் கொண்டிருக்குமாறு வெற்றிகரமாக உள்ளமைத்துள்ளீர்கள். உங்கள் dApp-க்கு எதிராக நீங்கள் முன்பு செய்த அதே பணிப்பாய்வுகளை (டிப்ளாய் மற்றும் சோதனை) இயக்க, உங்கள் புதிய, 3-நோடு லோக்கல் டெஸ்ட்நெட்டில் உள்ள ஏதேனும் el-client-<num> சேவையிலிருந்து rpc uri வெளியீட்டின் போர்ட்டுடன் உங்கள் hardhat.config.ts உள்ளமைவு கோப்பில் உள்ள localnet ஸ்ட்ரக்ட்டில் உள்ள <$YOUR_PORT>-ஐ மாற்றுவதன் மூலம் நாங்கள் முன்பு செய்த அதே செயல்பாடுகளைச் செய்யவும்.

முடிவுரை

அவ்வளவுதான்! இந்த குறுகிய வழிகாட்டியை சுருக்கமாகக் கூற, நீங்கள்:

  • Kurtosis-ஐப் பயன்படுத்தி Docker மூலம் லோக்கல் Ethereum டெஸ்ட்நெட்டை உருவாக்கினீர்கள்
  • உங்கள் லோக்கல் dApp மேம்பாட்டுச் சூழலை லோக்கல் Ethereum நெட்வொர்க்குடன் இணைத்தீர்கள்
  • லோக்கல் Ethereum நெட்வொர்க்கில் dApp-ஐ டிப்ளாய் செய்து அதற்கு எதிராக ஒரு எளிய சோதனையை இயக்கினீர்கள்
  • அடிப்படை Ethereum நெட்வொர்க்கை 3 நோடுகளைக் கொண்டிருக்குமாறு உள்ளமைத்தீர்கள்

உங்களுக்கு எது நன்றாக வேலை செய்தது, எதை மேம்படுத்தலாம் என்பது குறித்து உங்களிடமிருந்து கேட்க அல்லது உங்கள் கேள்விகளுக்கு பதிலளிக்க நாங்கள் விரும்புகிறோம். GitHub (opens in a new tab) வழியாகத் தொடர்புகொள்ள அல்லது எங்களுக்கு மின்னஞ்சல் அனுப்ப (opens email client) தயங்க வேண்டாம்!

பிற எடுத்துக்காட்டுகள் மற்றும் வழிகாட்டிகள்

எங்கள் விரைவுத் தொடக்கத்தை (opens in a new tab) (அங்கு நீங்கள் ஒரு Postgres தரவுத்தளத்தையும் அதன் மேல் API-ஐயும் உருவாக்குவீர்கள்) மற்றும் எங்கள் awesome-kurtosis ரெபாசிட்டரியில் (opens in a new tab) உள்ள பிற எடுத்துக்காட்டுகளைப் பார்க்க உங்களை ஊக்குவிக்கிறோம், அங்கு நீங்கள் சில சிறந்த எடுத்துக்காட்டுகளைக் காண்பீர்கள், அவற்றுக்கான பேக்கேஜ்கள் உட்பட:

பக்கம் கடைசியாகப் புதுப்பிக்கப்பட்டது: 23 செப்டம்பர், 2025

இந்த வழிகாட்டி பயனுள்ளதாக இருந்ததா?