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

事業譲渡されたブランドにGo言語を取り入れた話

Sponsored · Your Podcast. Everywhere. Effortlessly. Share. Educate. Inspire. Entertain. You do you. We'll handle the rest.

 事業譲渡されたブランドにGo言語を取り入れた話

Avatar for Ryuya Ishibashi

Ryuya Ishibashi

December 25, 2023
Tweet

More Decks by Ryuya Ishibashi

Other Decks in Technology

Transcript

  1. Copyright © ENECHANGE Ltd. All Rights Reserved. | 2 自己紹介

    Ryuya Ishibashi SES企業にて大小様々なプロジェクトに参画 • Ruby on Rails / Vue.js / PHP / C# / .NET / Drupal / AWS / Azureなどの技術に触れてきました ↓ ENECHANGE株式会社 • 2022/04 - 2023/03 ◦ Railsエンジニアとして、電気料金シミュレーションのAPI開 発を中心にお仕事していました • 2023/04 - ←いまここ ◦ Go・インフラエンジニアとして、EV充電器のスポット情報 API開発やAWS環境構築を中心にお仕事しています (@RubyKaigi2022) X / GitHub
  2. Copyright © ENECHANGE Ltd. All Rights Reserved. | 4 EVsmartブランドについて

    • EVsmartとは? ◦ いくつかのサービスの総称 (統一的なブランド名称)です ▪ EVの充電器検索、充電スタンド・スポット口コミサイト ▪ 上記のアプリ版 (iOS/Android) • 自動車メーカー様にOEM提供 ▪ 上記のAPI版 • マップサービス・カーナビ等に提供 • 事業譲渡について ◦ 2022/09、EVsmartブランドはアユダンテ社から ENECHANGE社に事業譲渡されました
  3. Copyright © ENECHANGE Ltd. All Rights Reserved. | 5 EVsmartブランドについて

    • エネルギークラウド事業部 EV Unitの守備範囲 ◦ 赤字の箇所を主に担当しています ▪ EVの充電器検索、充電スタンド・スポット口コミサイト ▪ 上記のアプリ版 (iOS/Android) • 自動車メーカー様にOEM提供 ▪ 上記のAPI版 • マップサービス・カーナビ等に提供
  4. Copyright © ENECHANGE Ltd. All Rights Reserved. | 8 従来のEVsmartの課題

    • とにかくコードが読みづらく、保守が困難 ◦ 典型的なスパゲッティコード • 杜撰なブランチ管理 ◦ master, testing, developブランチに謎の大量の差分がある • …And So On!
  5. Copyright © ENECHANGE Ltd. All Rights Reserved. | 10 解決方法(アユダンテ社)

    • コード自体を一から書き直す ◦ 従来のコードを改善するのも同じくらいコストがかかる • 言語自体もPHPではなく、Goを選択する ◦ それなら、モダンで高速な静的型付け言語であるGoを採用しよう • インフラも一から作り直そう ◦ VMでなく、コンテナオーケストレーションサービスを利用しよう • クラウドサービス自体もAzureではなく、GCPを選択する ◦ それなら、今時のGKEを採用しよう
  6. Copyright © ENECHANGE Ltd. All Rights Reserved. | 11 解決方法(ENECHANGE社)

    • 基本的にはアユダンテ社の対応を踏襲するが、赤字の箇所だけ変更した • コード自体を一から書き直す ◦ 従来のコードを改善するのも同じくらいコストがかかる • 言語自体もPHPではなく、Goを選択する ◦ それなら、モダンで高速な静的型付け言語であるGoを採用しよう • インフラも一から作り直そう ◦ VMでなく、コンテナオーケストレーションサービスを利用しよう • クラウドサービスは自社で強みのあるAWSを利用しよう ◦ 既に開発運用実績のあるECS on Fargateを採用しよう
  7. Copyright © ENECHANGE Ltd. All Rights Reserved. | 12 新しいEVsmartのアーキテクチャ

    mobile app backend Management Console Azure DB Gin Web Framework fargate frontend Gin Web Framework fargate AWS fargate backend
  8. Copyright © ENECHANGE Ltd. All Rights Reserved. | 14 Go言語の優れた要素

    • 高速性 ◦ 静的型付け言語で、事前コンパイルされているため、実行時の処理が速い ◦ 参考) 実際のエンドポイントを用いた実験結果
  9. Copyright © ENECHANGE Ltd. All Rights Reserved. | 15 Go言語の優れた要素

    • 表現のシンプル性 ◦ 例) ループ処理はfor文しかない ▪ Rubyのループ処理 • for, times, while, each, upto, downto, step, loop… ◦ 誰が書いても似たようなコードになり、 ▪ 保守性に優れている ▪ PRレビューも容易になりうる
  10. Copyright © ENECHANGE Ltd. All Rights Reserved. | 16 Go言語の優れた要素

    • Goroutineによる非常に軽量なスレッドの実現 ◦ 特徴 ▪ 少ないメモリ消費 ▪ 低い生成・破壊コスト ▪ M:Nモデルによる、低いコンテキストスイッチ ◦ 業務活用例 ▪ 1分毎の充電器の満空情報の更新処理に利用 ▪ 10 routinesによる同時実行により、 確実に処理が数秒で終わるようになった
  11. Copyright © ENECHANGE Ltd. All Rights Reserved. | 17 Go言語の優れた要素

    • Interfaceを利用した柔軟なDependency Injectionの実現 ◦ Interfaceを活用することで非常に簡単にDIを実装できます ◦ 業務活用例 ▪ 外部APIにリクエストするユースケースで、状況に応じて モックレスポンス ←→ 実リクエストを切り替えるようにしました type Client interface { Request(url URL, token string) ([]byte, error) } type RealClient struct{} type MockClient struct{} func NewClient() Client { cnf := config.GetConfig() if cnf.OcpiMockServer { return MockClient{} } else { return RealClient{} } } func (rc RealClient) Request(url URL, token string) ([]byte, error){ // 実際のエンドポイントに対する通常のリクエスト } func (mc MockClient) Request(url URL, token string) ([]byte, error) { switch url { case "http://mock.com/api/versions": return mc.mockVersionsResponse() case "http://mock.com/api/2.2": return mc.mockVersionDetailResponse() default: return nil, errors.New("invalid API endpoint") } }
  12. Copyright © ENECHANGE Ltd. All Rights Reserved. | 19 Gin

    / GORMを利用するメリット • 前提 ◦ Ginとは? ▪ Go言語によるWebアプリケーションフレームワーク ◦ GORMとは? ▪ Go言語によるORMライブラリ • Gin / GORMを利用するメリット ◦ 非常に簡単にMVCベースのWebアプリを構築できる ▪ MVCフレームワークに馴染みのある開発者にとって理解が容易 ▪ Rails, Laravel等を採用している企業のファーストチョイスとしては 良さそう ◦ 両者とも最もメジャーなパッケージの1つであるため、ドキュメントやコミュニ ティが充実している