開発日報

窓際エンジニアの開発備忘。日報は嘘です。

【忘備】グーグルのソフトウェアエンジニアリング ~ テスト概観 ② -テスト品質- ~

コードカバレッジ テストにおいて、 コードカバレッジ:ある機能のコードのどの行がどのテストにより実行されるか計測する指標。 この指標はあくまでもテストによって実装コードがどの程度実行されているかを確認しているにすぎず、「コードの有用性」を表す…

【忘備】グーグルのソフトウェアエンジニアリング ~テスト概観① -概観解説-~

なぜ自動テストをするのか バグは補足されるのが開発サイクルの後ろになるほど修正のコストが高くつく。開発サイクルの早い段階で高速に自動化テストを回し、バグを捕捉したい。 また、「バグをほそくすること」はテストの同期の一部に過ぎない。ソフトウェ…

【忘備】イーサリアム基礎 ~コントラクト作成トランザクション~

イーサリアム上で実行されるトランザクションには複数種類あるが、今回はコントラクト作成トランザクションについて解説する。 初期化 まずは、すべての種類のアカウントが持つ4つの領域を初期化する * 「ナンス」は最初は0 * 「(アカウント)残高」は送信…

【忘備】イーサリアム基礎 ~イーサリアムのスマートコントラクト~

概要 ただの暗号資産であるビットコインとは異なり、イーサリアムはスマートコントラクトを活用することで多彩な処理が実行可能。 スマートコントラクトの特徴は大まかに以下の通り。 スマートコントラクトはブロックチェーンの中に置かれる スマートコント…

【忘備】イーサリアム基礎 ~ガスとトランザクションコスト~

はじめに イーサリアムブロックチェーン上でトランザクションを実行するためには、トランザクションに伴うコストを実行者が負担しなければならない。 この「コスト」の概念が何を意味するか、またコストの算出・支払いの仕組みについて以下の本文で説明する…

【マイクロサービス】サーガ概説

課題 DBが分散した状態でシステム全体としてデータ整合性どのようにして担保するのか(複数サービスにまたがったトランザクション制御どうやる)? 対策 1. 「2層コミット」を使って担保する 分散データベースに対してデータベース間の整合性を担保する方法。 …

【マイクロサービス】APIゲートウェイ概説

マイクロサービスにおける課題 クライアントからみたアクセス先のエンドポイントが複数になる。 サービスの数が増えるとアクセス先の管理、ルーティングが複雑になる 各サービスが共通で行う処理をすべてのサービスに実装すると冗長になる (店舗検索、予約…

【マイクロサービス】サービスディスカバリー概説

課題 マイクロサービスにおけるサービス内の個々のインスタンスは負荷の状況において動的に生成・破棄される。 動的に生成されるインスタンスへのルーティングはどのように行われるか? 対応 マイクロサービス群の内部にサービスディスカバリーが存在し、そ…

【マイクロサービス】サーキットブレーカー概説

課題 サービス間通信における課題として、マイクロサービス内の通信経路上の特定のAPI(サービス)が停止してしまった場合 * サービス間通信のリクエストがタイムアウトまで待たされる * 結果として、ユーザビリティが著しく低下する 対策 サーキットブレー…

【マイクロサービス】メッセージブローカー概説

マイクロサービスにおける課題 複数サービスが直列に連携されている場合、 直列に接続しているサービスのどれか1つがダウンすると、サービスとしての機能が正常に動作しなくなる 稼働率が下がる なので、直列に連携されているサービスがそれぞれ同期的何連…

Update Chrome for Ubuntu

Upgrade Chrome from Command Line on Ubuntu · GitHub

データマネジメントメモ

1. データストレージとオペレーション データベースの保守管理。 データウェアハウス製品 DWHのせんていにあたって。 サーバの保守運用にリソースを費やしても、ビジネス面での課題解決には直接寄与せず、増え続けるデータやユースケースに対応するために、 …

NodeJsでイーサリアム触ってみる

概要 こちらの公式サイトが参考になります。 ドキュメントやチュートリアルも豊富です。 ある程度ブロックチェーンの仕組みがわかっているとよいです。 今回のサンプル完成品はこちら。 準備 infuraサービス登録 今回Infuraというサービスを利用します。 開…

Kotlinで簡易的なブロックチェーンサービス(ビットコイン的)を作ってみた

以下、ReadMeのそのまま貼り付けで。。 こちらがリポジトリ 参考 : 現役シリコンバレーエンジニアが教えるPythonで始めるスクラッチからのブロックチェーン開発入門 解説 TODO 起動 # 起動 $ docker-compose up # 停止 $ docker-compose down http://localho…

【備忘】3大クラウドによるインフラ構成を考える際に使えるリンク

ちゃんと読んでないし、小生はAWSくらいしかまともに使えないが、、 勝手に3大クラウドとかいってるけど、AWS GCP AZUREで良いんだよね? AWS アーキテクチャセンター (AWS) 形で考えるサーバーレス設計 Google Cloud ソリューション デザインパターン Azure…