Upgrade to Pro — share decks privately, control downloads, hide ads and more …

How Uber "Go"es Recap

micnncim
August 20, 2019

How Uber "Go"es Recap

micnncim

August 20, 2019
Tweet

More Decks by micnncim

Other Decks in Technology

Transcript

  1. Table of Contents Topics to be talked About me Uber's

    Go Problems Dependency Injection Standardizing Code Structure Switching to Monorepo My Gophercon Recap
  2. About me @micnncim Twitter: @micnncim / GitHub: @micnncim University Student

    / B4 / Computer Science Software Engineer Intern @Merpay Expert Team
  3. FX

  4. FX

  5. FX

  6. uber-go/fx APPLICATION FRAMEWORK DI 機能を中⼼とする 薄い " アプリケーションフレームワーク" DEPENDENCY INJECTION

    Provider からよしなに依存関係を解決 RICH FEATURE Hook, Timeout, Run func などの設定 開発者の依存モジュールへの認知負荷を軽減
  7. Before Consistent Code Structure NOT GOOD ARCHITECTURE "Transport" 層と "Business"

    層の混合 INCONSITENCY ⼀貫性が無いため複数サービスの開発の認知負荷が⾼い
  8. CONSITENT CODE STRUCTURE WITH GLUE CONSITENT ARCHITECTURE 複数サービス開発の認知負荷が ⼩さくなる LIKE

    CLEAN ARCHITECTURE ビジネスロジックの分離 モジュール間の適切な依存
  9. Polyrepo Before Monorepo UPDATE PACKAGES マイクロサービス全体の 1 package のアップデートに 合計数百

    commit が必要 DUPLICATE CODE 複数のマイクロサービスが 同じコードを保有する
  10. MONOREPO EASY UPDATE OF PACKAGES 1 commit で全てのマイクロサービスの package をアップデート

    バージョン管理もシンプルに SIMPLE CODE 少ない重複コード 共有・再利⽤・変更がしやすい BUILD WITH BAZEL Bazel を利⽤し⾼速・⾼再現性のビルド
  11. Why Bazel? Just my thought FAST AND CORRECT 並列ビルドとキャッシュで⾼速 Go

    や protoc のバージョン固定 sandbox 環境 LESS DOCKERFILES Bazel で Docker Image を ビルドするので Dockerfile の管理が 少なくなる GOOD WITH GO gazelle: Go ⽤ Bazel ファイル ⾃動⽣成ツール シングルバイナリ
  12. RECAP OF RECAP DEPENDENCY INJECTION uber-go/fx - DI based application

    framework CONSITENT CODE STRUCTURE glue - inspired by Clean Architecture MONOREPO Update a module by 1 commit Bazel