オープンロジを支える技術 2023
OPENLOGI Advent Calendar 2023 最後の投稿です。
株式会社オープンロジは2013年12月25日が創業日なのでちょうど本日で創業10年目という節目を迎えることになりました。
今があるのもひとえに、ここまで関わってくれた多くの方々(お客様、パートナーの皆様、株主の皆様、過去および現在の全てのメンバー)のおかげです。
そんな感謝の気持ちを携えながら今年も締めくくりとして一年の技術的なアップデートをまとめたいと思います。
過去のエントリー
- オープンロジを支える技術(2022年版)
- オープンロジを支える技術(2021年版)
- オープンロジを支える技術(2020年版)
- オープンロジを支える技術(2019年版)
- オープンロジを支える技術(2018年版)
- オープンロジを支える技術(2017年版)
今年の主なアップデート
今年実施された技術的なアップデートでインパクトが大きかったものを3つピックアップしました。
- フロントエンドビルド環境の分割とライブラリのアップデート
- CI環境周りを中心とした開発基盤の大幅な改善
- Datastream for BigQuery の導入
1. フロントエンドビルド環境の分割とライブラリのアップデート
これまでサーバーサイドのバージョンアップには対応していましたが、フロントエンド関連ライブラリの更新は著しく遅滞していました。
そうなってしまった要因として、一つのビルド環境でシステム全体のフロントエンドを構築していた点が挙げられます。
初期的にはこれで良かったものの、システム規模の拡大に伴い、影響範囲が広がり、アップデートやメンテナンスが困難な状態に追い込まれていました。
この事態を解消するため、まずモジュールごとにビルド環境を分割し、影響範囲を最小にし、メンテナンスが容易な環境の構築に取り組みました。
その成果として、各種ライブラリは最新のものに更新され、これまで活用したいと思いつつも利用できなかった React Hooks も取り入れることができるようになりました。
この一年は、社内でReact勉強会が開催されるなど、フロントエンド周りの盛り上がりが目立つ一年となりました。
この取り組みで導入された主な技術
- フロントエンド開発環境改善
- ドメインモジュール毎にビルド単位分割
- React バージョンアップ v15 → v18
- TypeScript の導入
- 各種ライブラリの導入
- フォームライブラリ
-
React Hook Form
- Redux Form からの刷新
- Redux は最小限の利用にとどめる方針に
-
React Hook Form
- バリデーションライブラリ
- yup
- 独自実装からの脱却
- フォームライブラリ
2. CI環境周りを中心とした開発基盤の大幅な改善
これまで最低限のCI/CD環境は確保されていましたが、その改良が進まずに形骸化していた状態が続いていました。
そんな状況の中、新しく入ったメンバーからの課題提起と提案により、次々と改善が進み開発基盤の大幅強化が実現しました。
取り組みの内容については今年の開催された PHP Conference Japan 2023 で発表 されたのですが、登壇者(@takeokun)による解説記事がありますので詳しくはそちらを参照ください。
この取り組みで導入された主な技術
- Linter/Fomatter 周りの強化
- php-cs-fixer / ESLint / Prettier のアップデートと適用範囲の拡充
- actionlint / secretlint の 導入
- 静的解析関連ツール
3. Datastream for BigQuery の導入
2019 年頃から BigQuery は主にダッシュボードの作成やデータ分析に用いられてきました。
Embulk を使用して RDS のデータを BigQuery にロードする実装が運用の基礎となっていました。
しかし、このシステムはリアルタイム性やデータ信頼性の観点から見ていくつかの問題点を抱えており、積極的な導入に踏み切れずにいました。しかし、Datastream for BigQuery の発表により、探していた理想的な解決策が出現したと感じていたところ、SREチームやDataチームの協力により、その導入を実現することができました。
導入経緯などについては、データエンジニア(@akabe)による以下の記事が詳しいのでそちらを参照ください。
BigQuery を本番データベースとほぼ同等の感覚で使用できるようになった結果、データ利用の可能性が大幅に拡がりました。特に、ニアリアルタイム性とデータの信頼性の向上により、倉庫オペレーションといったクリティカルな用途でも活用可能になりました。
この取り組みで導入された主な技術
- データロード
- データ変換・クエリー実装
- IaC
-
Terraform
- Terraform 職人が増え Data チーム による GCP データ基盤構築でも活用が進んだ
-
Terraform
主な技術スタック
アプリケーション関連
今年は初期から停滞していたフロントエンドのバージョンアップを無事実現。
サーバサイドのバージョンアップの準備も粛々と進めており、来年には実施予定。
インフラ環境
Amazon Web Services (AWS)
レガシーな仮想サーバー環境と新アーキテクチャーによるコンテナ環境の並行運用しています。
レガシー環境における RDS の Aurora化プロジェクト粛々と進めており、来年には移行実現できそうです。
Google Cloud Platform (GCP)
BigQuery を中心としたデータ基盤を運用。
レガシーな Embulk 環境から Datastream for BigQuery を中心とした新たなデータ基盤構築に取り組んでいます。
運用監視
以前よりも Datadog の活用が進み、何かあったら Datadog を見る習慣が根付いてきた気がします
開発環境
Copilot 活用している人と Terraform 職人が増えてきた
情報ツール系
ここらへんは特に変化なし。プロジェクト管理ツールはリプレイス検討したい。
まとめ
今年は新たに仲間入りしたメンバーによる活躍が目立った一年でしたが、その背景には経験豊富なメンバーたちの堅実なサポートがあったからこそであり、その相乗効果によりここまで大きな改善を進めることができたと感じています。
10年も経つとさすがにシステムのところどころで歪みが目立つようにもなってきました。
この問題に関してもCTO室において技術負債解消のための特別チームも組成され、解決に向けて動き始めています。
次の10年はよりビジネスを加速させるシステムを追求していきたいと思います。
オープンロジでは、これからのチャレンジを一緒に楽しめる仲間を募集しています。興味ある方はぜひお気軽にご連絡ください!