data:image/s3,"s3://crabby-images/e57f8/e57f80229a8d730e66b72b4ad069ee201ad624a6" alt="博士"
前回からの続きなのじゃ。
data:image/s3,"s3://crabby-images/16809/168097267eab9c641726a0df178546b7b5e0faca" alt="ゆるり"
ゆるりはプログラミングの基礎も勉強したことがなく、全くの素人。
そこで、わからない用語を調べるのに何度もお世話になったサイトが「分かりそう」で「分からない」でも「分かった」気になれるIT用語辞典です。
ゆる~く教えてくれるので、なんとなく理解できる優れものサイトです。
- OS:Windows 10/バージョン 21H2 (OS ビルド 19044.1706)
- プロセッサ:Intel(R) Core(TM) i7-7500U
- メモリ:DDR4 8GB
- マザーボード:L-NSS172-L
Node.jsをWSL2にインストールする
data:image/s3,"s3://crabby-images/e57f8/e57f80229a8d730e66b72b4ad069ee201ad624a6" alt="博士"
Node.jsをWSL2にインストールするのじゃ。
Node.jsはプログラマーさん側でJavascriptを使えるようにする環境であり、
WSL2(Windows Subsystem for Linux 2)とはWindows 10上でLinuxを動作させるための仕組みなのじゃ。
※2022.6.30追記:この方法でNode.js をインストールするとnpm(Node Package Manager)も自動的にインストールされるのじゃ。
↓Windowsキーを右クリックし、Windows PowerShell(管理者)をクリックし起動する
data:image/s3,"s3://crabby-images/3c8a9/3c8a9f742c073da4b9d77de08e12d49f1f53ceb5" alt="Node.jsをWSL2にインストールする"
↓「管理者:Windows PowerShell」に「wsl --install
」と打ち込みEnter
data:image/s3,"s3://crabby-images/7837a/7837ac6b212e03bb853b020a2499d821d0a7187a" alt="Node.jsをWSL2にインストールする"
「Installing: Virtual Machine Platformうんぬんかんぬん」と表示される
パソコンを再起動↓
data:image/s3,"s3://crabby-images/34d5e/34d5e770142c8b722a15ba62836ef701e51effca" alt="Node.jsをWSL2にインストールする"
再起動後、スタートメニュー(Windowsマーク)から「Ubuntu」を立ち上げる↓
data:image/s3,"s3://crabby-images/cb0b9/cb0b96ec7951f3d82b8088165914b0f959441ada" alt="Node.jsをWSL2にインストールする"
ユーザー名とパスワードを設定する↓
data:image/s3,"s3://crabby-images/7538d/7538d88a75c8b2692649422e603077aa1dd6fedb" alt="Node.jsをWSL2にインストールする"
data:image/s3,"s3://crabby-images/16809/168097267eab9c641726a0df178546b7b5e0faca" alt="ゆるり"
ちなみに「New password」と「Retype new password」は入力しても画面には表示されません。
初めてこのようなものを使ったゆるりはここでもつまづきました。
↓ダーッと色んな事が書かれて最終的に下記画像のようになれば、成功だと思われる
data:image/s3,"s3://crabby-images/54136/54136a98724005991289515a78fb82b4ea288242" alt="Node.jsをWSL2にインストールする"
バージョンを確認してみる。PowerShellに「wsl -l -v
」と入力しEnter↓
data:image/s3,"s3://crabby-images/e353d/e353db79ced9c7140ae36b72753cd17c4744ee26" alt="Node.jsをWSL2にインストールする"
参考サイトにUbuntuでバージョンとコードネームを確認するようにと書いてあったので、一応確認する(なぜ確認するのかは不明)。
コマンドを実行↓
lsb_release -dc
data:image/s3,"s3://crabby-images/cf7a3/cf7a3305548ac5547ef87118459d720d798a88c7" alt="Node.jsをWSL2にインストールする"
data:image/s3,"s3://crabby-images/16809/168097267eab9c641726a0df178546b7b5e0faca" alt="ゆるり"
初めてこのようなものを使ったゆるりは、ここでもつまづく…。
貼り付け(Ctrl + V)を押しても入力されない…。
Ubuntuでは「マウスの右クリック」が「Ctrl + V」の代わりのボタンだったのです‼
Ubuntuの更新をする
①コマンドを実行↓
sudo apt update && sudo apt upgrade
②パスワードを実行↓
data:image/s3,"s3://crabby-images/7f423/7f42304ae69d769c238fa05397cd153f219e394c" alt="Node.jsをWSL2にインストールする"
実行(Enter)を押すとこんなことになる↓
data:image/s3,"s3://crabby-images/a0af9/a0af94b63d9a689d225bf4f4053513c8744b36a6" alt="Node.jsをWSL2にインストールする"
「まだ続けたいのか?」というようなことをきかれているようなので、「Y」(Yesのことだろう)と入力する↓
data:image/s3,"s3://crabby-images/7073f/7073fedbf7f94c4f1594b789f7be512eb7afa69b" alt="Node.jsをWSL2にインストールする"
実行(Enter)を押すとこんなことになる↓
data:image/s3,"s3://crabby-images/e7ecb/e7ecb4d6af6a55ca5272077786f026f913d03831" alt="Node.jsをWSL2にインストールする"
終わったようだ↓
data:image/s3,"s3://crabby-images/810c8/810c84b276352a94bf1de3b92498fe17ec264d02" alt="Node.jsをWSL2にインストールする"
続けてcURLをインストールする(コマンドラインでインターネットからコンテンツをダウンロードするために使用するツールだそうだ)。
①コマンドを実行↓
sudo apt-get install curl
②パスワードを実行↓
data:image/s3,"s3://crabby-images/e32b7/e32b76b2388abf7357cc23ff3d513d71b1d2891c" alt="Node.jsをWSL2にインストールする"
↓今回はすぐ終わった
data:image/s3,"s3://crabby-images/d9c47/d9c47602b86efb084bf0f0ecb22de1a9f2509953" alt="Node.jsをWSL2にインストールする"
nvm(Node Version Manager/ノード・バージョン管理ツール) をインストールする。
コマンドを実行↓
curl -o- https://raw.githubusercontent.com/nvm-sh/nvm/v0.39.1/install.sh | bash
data:image/s3,"s3://crabby-images/ac1ea/ac1ea4e9421c50a5bf2f51b7147455acc3d36e08" alt="Node.jsをWSL2にインストールする"
インストールを確認する。
コマンドを実行↓
command -v nvm
「nvm
」 と返されるはずが何も応答がない…↓
data:image/s3,"s3://crabby-images/97397/97397f533ed6d2de483e9731c1e95f4fa5ea186a" alt="Node.jsをWSL2にインストールする"
“コマンドが見つかりません” というメッセージが返される場合、または何も応答がない場合は、Ubuntuを閉じてから再度開き、もう一度やり直してくださいと公式に書いてあるので、その通りにすると無事 「nvm
」 と返ってきた↓
data:image/s3,"s3://crabby-images/33ab2/33ab2c48b578caedcb431c6fb94db880b75a5a5e" alt="Node.jsをWSL2にインストールする"
現在インストールされている Node のバージョンを一覧表示する。(この時点では何もないらしい)
コマンドを実行する↓
nvm ls
data:image/s3,"s3://crabby-images/4705d/4705d25175623219355bdae568704f4f1a534d94" alt="Node.jsをWSL2にインストールする"
Node.js の最新リリースをインストールする。
コマンドを実行↓
nvm install node
data:image/s3,"s3://crabby-images/b3373/b33739d810b79496bfe383c9464a7b268a5573a4" alt="Node.jsをWSL2にインストールする"
Node.js の安定した LTSリリースをインストールする。
コマンドを実行↓
nvm install --lts
data:image/s3,"s3://crabby-images/66762/667622d1a4a45124a14c60703168b785c7f63483" alt="Node.jsをWSL2にインストールする"
インストールされている Node のバージョンを一覧表示する。
コマンドを実行↓
nvm ls
data:image/s3,"s3://crabby-images/1b974/1b974ac9c4bb6226e273e703d95c35f4283b450d" alt="Node.jsをWSL2にインストールする"
Node.js がインストールされていて、安定した LTS リリースバージョンであることを確認する。
コマンドを実行↓
node --version
data:image/s3,"s3://crabby-images/d7c3f/d7c3f683fbaaacbf404c2d0b5d8610276412f43f" alt="Node.jsをWSL2にインストールする"
npmも安定バージョンか確認する。
コマンドを実行↓
npm --version
data:image/s3,"s3://crabby-images/82998/82998b62644b668d9bd56d9b6446e362d5ba1f3a" alt="Node.jsをWSL2にインストールする"
Gethをインストールする
data:image/s3,"s3://crabby-images/e57f8/e57f80229a8d730e66b72b4ad069ee201ad624a6" alt="博士"
スマートコントラクトやdApps(分散型アプリケーション)を作るためには、Ethereumという環境(プラットフォーム)を使ってEthereumのP2Pネットワークに参加する必要があるのじゃ。
P2Pネットワークに参加するためには、Ethereumクライアントをインストールし起動。
そこでEthereumで推奨されている「Geth」というEthereumクライアントをインストールするのじゃ。
「Geth」は他にもETHの採掘(マイニング)・送金、トランザクションの生成・ブロックチェーンの確認などができるのじゃ。
data:image/s3,"s3://crabby-images/16809/168097267eab9c641726a0df178546b7b5e0faca" alt="ゆるり"
「Geth」はgo-ethereumの略で、Goというプログラミング言語で実装されたスマートコントラクトのクライアントなんだって。
P2Pネットワークで自動で契約を執行するプログラムを実行してくれるらしいよ。
①コマンドを実行↓
sudo add-apt-repository -y ppa:ethereum/ethereum
(①の下の行について:パスワードを一度間違え「Sorry, try again」と言われた)
↓②パスワードを実行
data:image/s3,"s3://crabby-images/28239/2823925bb5974a8f5a2ac607c30731e10d0d0da7" alt="Gethをインストールする"
①コマンドを実行↓
sudo apt-get update
↓②パスワードを実行
data:image/s3,"s3://crabby-images/c2a9a/c2a9a943172263cc6de6a76425910fed4567f5f5" alt="Gethをインストールする"
①コマンドを実行↓
sudo apt-get install ethereum
②パスワードを実行
③続けたいかと質問してくるので「Y」を実行↓
data:image/s3,"s3://crabby-images/9db32/9db32793c8caa52856204b2d7fbb368edecfa3ce" alt="Gethをインストールする"
gethがインストールされたかを確認する
↓コマンドを実行
geth --help
data:image/s3,"s3://crabby-images/6fd37/6fd37f8429172dcb3d34f388dc5fffbe0f523819" alt="Gethをインストールする"
Gethのアップデートをする
①コマンドを実行↓
sudo apt-get update
②パスワードを実行↓
data:image/s3,"s3://crabby-images/adf8a/adf8adfbfe8bbdaf3698ce364acffaef40fc925c" alt="Gethをインストールする"
Gethのアップグレードをする
①コマンドを実行↓
sudo apt-get upgrade
②続けたいかと質問してくるので「Y」を実行↓
data:image/s3,"s3://crabby-images/e66d0/e66d0526c770bc8faf06462e3af745a034fa0077" alt="Gethをインストールする"
Gethをプライベート(テスト)ネットワークに接続する
data:image/s3,"s3://crabby-images/e57f8/e57f80229a8d730e66b72b4ad069ee201ad624a6" alt="博士"
Gethをプライベート(テスト)ネットワークに接続するのじゃ。
本番のネットワークにいきなり接続するとバグや不具合があったら大変なことになる場合もあるので、スマートコントラクトがちゃんと機能するのかなどをテストするプライベート(テスト)ネットワークを作成して、そこに接続するのじゃ。
データディレクトリ(eth_private_net)を作成する。
↓コマンドを実行
mkdir /home/ユーザー名/eth_private_net
data:image/s3,"s3://crabby-images/c7d30/c7d30f4b63c7ceee75c976fa30a7c118726cbcf4" alt=""
作ったディレクトリに移動する
↓コマンドを実行
cd /home/ユーザー名/eth_private_net
data:image/s3,"s3://crabby-images/199d2/199d25da42b96cf1a45f015c4bae7fb97bd106fa" alt="Gethをプライベート(テスト)ネットワークに接続する"
data:image/s3,"s3://crabby-images/e57f8/e57f80229a8d730e66b72b4ad069ee201ad624a6" alt="博士"
Windows 用の Visual Studio Code をダウンロードしてインストールするのじゃ。
Visual Studio Codeのサイトにアクセスするのじゃ。
data:image/s3,"s3://crabby-images/16809/168097267eab9c641726a0df178546b7b5e0faca" alt="ゆるり"
プログラマーさんたちはVisual Studio CodeのことをVS Codeと呼んでるみたいです。
Download for Windowsをクリック↓
data:image/s3,"s3://crabby-images/de00c/de00c693ae60a894ae4ade447dc2fa0717835267" alt="Gethをプライベート(テスト)ネットワークに接続する"
exeファイルをクリックする↓
data:image/s3,"s3://crabby-images/35e82/35e82fbad59f837cb42bf438e9354768dcc462aa" alt="Gethをプライベート(テスト)ネットワークに接続する"
「同意する」を選択して「次へ(N) >」↓
data:image/s3,"s3://crabby-images/cface/cface33a1241c4039734e2c9a428c8882b70b472" alt="Gethをプライベート(テスト)ネットワークに接続する"
インストール先を確認して、それでよければ「次へ(N) >」をクリック↓
data:image/s3,"s3://crabby-images/758e1/758e1543fba971a7ddc6a779bf10b1050319dcbd" alt="Gethをプライベート(テスト)ネットワークに接続する"
「次へ(N) >」をクリック↓
data:image/s3,"s3://crabby-images/62651/626517e16d7cf7df6697a28163404da9514f85d8" alt="Gethをプライベート(テスト)ネットワークに接続する"
デフォルトのまま「次へ(N) >」をクリック↓
data:image/s3,"s3://crabby-images/7776a/7776aba95fa0cce0b356d8d9688be9d589211b71" alt="Gethをプライベート(テスト)ネットワークに接続する"
「インストール(I)」をクリック↓
data:image/s3,"s3://crabby-images/322b8/322b8c0c2f450013e9f1db75e17ede4221385514" alt="Gethをプライベート(テスト)ネットワークに接続する"
「完了」をクリック↓
data:image/s3,"s3://crabby-images/479f8/479f8aecdf297e843daea034f38c703748a86130" alt="Gethをプライベート(テスト)ネットワークに接続する"
Remote – WSL 拡張機能を VS Code にインストールする
①拡張機能を選択
②「Remote – WSL」と入力
③「Remote – WSL」をクリック
④「Install」をクリック↓
data:image/s3,"s3://crabby-images/c3179/c3179c9fdd191755a1de81b286dc93ee38639856" alt="Gethをプライベート(テスト)ネットワークに接続する"
data:image/s3,"s3://crabby-images/16809/168097267eab9c641726a0df178546b7b5e0faca" alt="ゆるり"
「Install」の部分が最初から「Uninstall」になっている人は、もうインストールされているということなので、この作業は飛ばして大丈夫です。
WSL2のUbuntu へ接続
①リモートエクスプローラーを選択
②「Ubuntu」を右クリックすると接続メニューが表示されるので、「Connect to WSL」を選択↓
data:image/s3,"s3://crabby-images/1f242/1f24237eefefde09a27bebbf3c81c3c977936849" alt="Gethをプライベート(テスト)ネットワークに接続する"
新規でVisual Studio Codeが起動する。
↓左下に「WSL: Ubuntu」と表示されていれば接続完了。
data:image/s3,"s3://crabby-images/4efda/4efdabf017153119913c3b3784abb274c8ba027c" alt="Gethをプライベート(テスト)ネットワークに接続する"
①エクスプローラーを選択
②「Open Folder」をクリック
③「eth_private_net」を選択↓
data:image/s3,"s3://crabby-images/dfaed/dfaed9a424de512070c93cf6fb5f9c981f9417d8" alt="Gethをプライベート(テスト)ネットワークに接続する"
「OK」をクリック↓
data:image/s3,"s3://crabby-images/b23bb/b23bb657475a95fbade385b3dd1ed8bcf1f5b208" alt="Gethをプライベート(テスト)ネットワークに接続する"
ここで “Do you trust the authors of the files in this folder?”(このフォルダー内のファイルの信頼しますか?という内容の画面が出たら、”Yes,I trust the authors Trust folder and enable all features”(はい、作成者を信頼します フォルダーを信頼してすべての機能を有効にする)という左下の青い四角をクリックする↓
data:image/s3,"s3://crabby-images/178ba/178bab70ea44306958591be4348066c9bc3dd11a" alt="Gethをプライベート(テスト)ネットワークに接続する"
Genesisファイルを作成する
↓「New File」をクリック、「myGenesis.json」と入力しEnter
data:image/s3,"s3://crabby-images/857c7/857c7cc38cf3a84a5e2025203fae3124a515ac45" alt="Gethをプライベート(テスト)ネットワークに接続する"
「myGenesis.json」をクリックすると、右側にコードを書き込めるスペースができる↓
data:image/s3,"s3://crabby-images/11b6f/11b6fd29d0662e8095d7a0d95dc0f8255085f0f2" alt="Gethをプライベート(テスト)ネットワークに接続する"
下記コードを上記画像の右側にコピペ
Rinkebyネットワーク今回はRinkebyネットワークを使うので、"chainId"
は「4」を使用↓
{
"config": {
"chainId": 4,
"homesteadBlock": 0,
"eip150Block": 0,
"eip155Block": 0,
"eip158Block": 0,
"byzantiumBlock": 0,
"constantinopleBlock": 0,
"petersburgBlock": 0,
"istanbulBlock": 0,
"berlinBlock": 0
},
"nonce": "0x0000000000000042",
"timestamp": "0x0",
"parentHash": "0x0000000000000000000000000000000000000000000000000000000000000000",
"extraData": "",
"gasLimit": "0x8000000",
"difficulty": "0x4000",
"mixhash": "0x0000000000000000000000000000000000000000000000000000000000000000",
"coinbase": "0x3333333333333333333333333333333333333333",
"alloc": {}
}
↓
data:image/s3,"s3://crabby-images/6d130/6d1308c0784376e33e75aa70e3c27c5a9a7112dc" alt="Gethをプライベート(テスト)ネットワークに接続する"
2022.11.20 追記:{}の位置は見やすくするために合わせているということがわかりました。
「Ctrl + S」でセーブする↓
data:image/s3,"s3://crabby-images/b6a2f/b6a2fe62dea3938ce0818d1549a2ef0f4d1a5dbd" alt="Gethをプライベート(テスト)ネットワークに接続する"
data:image/s3,"s3://crabby-images/16809/168097267eab9c641726a0df178546b7b5e0faca" alt="ゆるり"
上記画像が出たら、その都度セーブしてください。
※途中でVS Codeの作業を中断(リモート接続を終了)したいとき
①「WSL:Ubuntu」をクリック
②一番下の「Close Remote Connection」をクリック↓
data:image/s3,"s3://crabby-images/d89d1/d89d1d3ffb9c1858859ee3bb6ad752ab82af32b0" alt="Gethをプライベート(テスト)ネットワークに接続する"
Gethを使用するためにgenesisブロックの初期化をする。
Ubuntuでコマンドを実行↓
geth --datadir /home/ユーザー名/eth_private_net init /home/ユーザー名/eth_private_net/myGenesis.json
data:image/s3,"s3://crabby-images/eb31b/eb31b439ea45c2db5ee3f8422d975c2666da5789" alt="Gethをプライベート(テスト)ネットワークに接続する"
↓ここでVisual Studio Codeを見てみると…
data:image/s3,"s3://crabby-images/5292c/5292ccbbbb4bf11daac2ea47ac38fffa4e74a4a4" alt="Gethをプライベート(テスト)ネットワークに接続する"
data:image/s3,"s3://crabby-images/e57f8/e57f80229a8d730e66b72b4ad069ee201ad624a6" alt="博士"
gethとkeystoreのディレクトリがあれば、初期化は成功なのじゃ。
Gethをプライベート(テスト)ネットワークで起動させる
data:image/s3,"s3://crabby-images/e57f8/e57f80229a8d730e66b72b4ad069ee201ad624a6" alt="博士"
続いてGethをプライベート(テスト)ネットワークで起動し、HTTP-RPCを有効にしておくのじゃ。
Gethを起動すると外部からのAPIを受け付けることができる環境になるのじゃ。
スマートコントラクトを実行するために(web3.jsを使えるようにするために)必要な作業なのじゃ。
gethを起動する。
Ubuntuでコマンドを実行networkid
は、Genesisファイルの"chainId"
で指定したRinkebyネットワークと同じ「4」にする↓
geth --networkid "4" --nodiscover --datadir "/home/ユーザー名/eth_private_net" console 2>> /home/ユーザー名/eth_private_net/geth_err.log
data:image/s3,"s3://crabby-images/85f65/85f65e3fe87ac14f08b77269946c4ad1a89e790e" alt="Gethをプライベート(テスト)ネットワークで起動させる"
「Ctrl + D」か「exit」と入力して止める↓
data:image/s3,"s3://crabby-images/415ed/415edc812eed60ed1978efc9e67acdaa20152e99" alt="Gethをプライベート(テスト)ネットワークで起動させる"
data:image/s3,"s3://crabby-images/e57f8/e57f80229a8d730e66b72b4ad069ee201ad624a6" alt="博士"
以上がUbuntuへGethを起動させる方法なのじゃ。
お疲れ様なのじゃ。
そして次は…
data:image/s3,"s3://crabby-images/16809/168097267eab9c641726a0df178546b7b5e0faca" alt="ゆるり"
今日はもう満足したので、続きはまた今度で
|゚Д゚)ノ ジャ、マタ!!
data:image/s3,"s3://crabby-images/e57f8/e57f80229a8d730e66b72b4ad069ee201ad624a6" alt="博士"
君もお疲れ様なのじゃ(´・ω・)っ旦~
また次回なのじゃ。
コメント