スマートコントラクト作成から利用まで 動作フロー (Solidityなどで)スマートコントラクトを書く スマートコントラクトをEVMバイトコードにコンパイルする EVMバイトコードでネットワークにコントラクト作成トランザクションを送る 動作結果 デプロイされ…
イーサリアム イーサリアムはプログラム可能なブロックチェーンであり、ユーザーが任意の独自性のある複雑な処理を作成することができる。 EVM EVMはスマートコントラクトのランタイム環境として既往するイーサリアムの実行エンジンである。 全ノードがEV…
Googleにおけるユニットテストの定義 Googleがテストを分類する際に使用する2つの軸 テスト規模:テストにより消費されるリソース、テストが実行されている内容に焦点を当てる テスト範囲:テストが検証を意図する実装コードの量 また、Googleにおけるユニッ…
グーグルのテスト文化醸成のための取り組み 1. オリエンテーション 当初、Googleの新入社員向けのオリエンテーションにはテストについての講義は存在しなかった。が、2005年ころからオリエンテーションの講義に自動テストについての講義が組まれるようになっ…
コードカバレッジ テストにおいて、 コードカバレッジ:ある機能のコードのどの行がどのテストにより実行されるか計測する指標。 この指標はあくまでもテストによって実装コードがどの程度実行されているかを確認しているにすぎず、「コードの有用性」を表す…
なぜ自動テストをするのか バグは補足されるのが開発サイクルの後ろになるほど修正のコストが高くつく。開発サイクルの早い段階で高速に自動化テストを回し、バグを捕捉したい。 また、「バグをほそくすること」はテストの同期の一部に過ぎない。ソフトウェ…
イーサリアム上で実行されるトランザクションには複数種類あるが、今回はコントラクト作成トランザクションについて解説する。 初期化 まずは、すべての種類のアカウントが持つ4つの領域を初期化する * 「ナンス」は最初は0 * 「(アカウント)残高」は送信…
概要 ただの暗号資産であるビットコインとは異なり、イーサリアムはスマートコントラクトを活用することで多彩な処理が実行可能。 スマートコントラクトの特徴は大まかに以下の通り。 スマートコントラクトはブロックチェーンの中に置かれる スマートコント…
はじめに イーサリアムブロックチェーン上でトランザクションを実行するためには、トランザクションに伴うコストを実行者が負担しなければならない。 この「コスト」の概念が何を意味するか、またコストの算出・支払いの仕組みについて以下の本文で説明する…
課題 DBが分散した状態でシステム全体としてデータ整合性どのようにして担保するのか(複数サービスにまたがったトランザクション制御どうやる)? 対策 1. 「2層コミット」を使って担保する 分散データベースに対してデータベース間の整合性を担保する方法。 …
マイクロサービスにおける課題 クライアントからみたアクセス先のエンドポイントが複数になる。 サービスの数が増えるとアクセス先の管理、ルーティングが複雑になる 各サービスが共通で行う処理をすべてのサービスに実装すると冗長になる (店舗検索、予約…
課題 マイクロサービスにおけるサービス内の個々のインスタンスは負荷の状況において動的に生成・破棄される。 動的に生成されるインスタンスへのルーティングはどのように行われるか? 対応 マイクロサービス群の内部にサービスディスカバリーが存在し、そ…
課題 サービス間通信における課題として、マイクロサービス内の通信経路上の特定のAPI(サービス)が停止してしまった場合 * サービス間通信のリクエストがタイムアウトまで待たされる * 結果として、ユーザビリティが著しく低下する 対策 サーキットブレー…
マイクロサービスにおける課題 複数サービスが直列に連携されている場合、 直列に接続しているサービスのどれか1つがダウンすると、サービスとしての機能が正常に動作しなくなる 稼働率が下がる なので、直列に連携されているサービスがそれぞれ同期的何連…
Upgrade Chrome from Command Line on Ubuntu · GitHub