Upgrade to Pro
— share decks privately, control downloads, hide ads and more …
Speaker Deck
Features
Speaker Deck
PRO
Sign in
Sign up for free
Search
Search
レガシーシステム・技術的負債とは何か Diverseの向き合い方
Search
SAMUKEI
November 22, 2018
Technology
2
2.1k
レガシーシステム・技術的負債とは何か Diverseの向き合い方
レガシーシステム・技術的負債の分類とDiverseがどう向き合っているか
SAMUKEI
November 22, 2018
Tweet
Share
More Decks by SAMUKEI
See All by SAMUKEI
PWAでここまでできる
samukei
26
17k
老舗マッチングサービスとの付き合い方
samukei
0
1.5k
Other Decks in Technology
See All in Technology
公開初日に個人環境で試した Gemini CLI 体験記など / Gemini CLI実験レポート
you
PRO
3
1.3k
AI コードレビューが面倒すぎるのでテスト駆動開発で解決しようとして読んだら、根本的に俺の勘違いだった
mutsumix
0
130
オブザーバビリティプラットフォーム開発におけるオブザーバビリティとの向き合い / Hatena Engineer Seminar #34 オブザーバビリティの実現と運用編
arthur1
0
220
SAE J1939シミュレーション環境構築
daikiokazaki
1
200
FAST導入1年間のふりかえり〜現実を直視し、さらなる進化を求めて〜 / Review of the first year of FAST implementation
wooootack
1
230
AI時代の知識創造 ─GeminiとSECIモデルで読み解く “暗黙知”と創造の境界線
nyagasan
0
180
会社もクラウドも違うけど 通じたコスト削減テクニック/Cost optimization strategies effective regardless of company or cloud provider
aeonpeople
2
410
人に寄り添うAIエージェントとアーキテクチャ #BetAIDay
layerx
PRO
2
470
経験がないことを言い訳にしない、 AI時代の他領域への染み出し方
parayama0625
0
280
2025-07-25 NOT A HOTEL TECH TALK ━ スマートホーム開発の最前線 ━ SOFTWARE
wakinchan
0
180
反脆弱性(アンチフラジャイル)とデータ基盤構築
cuebic9bic
2
120
クマ×共生 HACKATHON - 熊対策を『特別な行動」から「生活の一部」に -
pharaohkj
0
270
Featured
See All Featured
The Pragmatic Product Professional
lauravandoore
35
6.8k
The Psychology of Web Performance [Beyond Tellerrand 2023]
tammyeverts
48
2.9k
The Power of CSS Pseudo Elements
geoffreycrofte
77
5.9k
Let's Do A Bunch of Simple Stuff to Make Websites Faster
chriscoyier
507
140k
Chrome DevTools: State of the Union 2024 - Debugging React & Beyond
addyosmani
7
770
Being A Developer After 40
akosma
90
590k
Embracing the Ebb and Flow
colly
86
4.8k
Making Projects Easy
brettharned
117
6.3k
"I'm Feeling Lucky" - Building Great Search Experiences for Today's Users (#IAC19)
danielanewman
229
22k
Six Lessons from altMBA
skipperchong
28
3.9k
Intergalactic Javascript Robots from Outer Space
tanoku
272
27k
Build The Right Thing And Hit Your Dates
maggiecrowley
37
2.8k
Transcript
レガシーシステム 技術的負債 とは何か Diverseの関わり方
who? • さむけい(藤田 雄大) • 所属はDiverse Inc. / MAEMO LLC •
youbrideのサーバ・クライアントやってます • DroidKaigi 2019に登壇します!PWAの話します! https://droidkaigi.jp/2019/ • 会社でPodcast配信してます。聴いてください! https://podcast.diverse-inc.com/
オンライン カジュアル シリアス オフライン
レガシーシステム 技術的負債 に悩まされているという方
みなさん悩んでいますね!
では、 レガシーシステム 技術的負債 とはなんでしょうか?
レガシーシステムとは?(wikipedia引用) レガシーシステムとは、主にコンピュータの分野で、代替す べき新しい技術などのために古くなったコンピュータのシス テムや技術などのことである。そのようなデバイスをレガ シーデバイス、そのようなオペレーティングシステムを、レガ シーOSなどともいう。
技術的負債とは?(wikipedia引用) 技術的負債とは、行き当たりばったりなソフトウェアアーキ テクチャと、余裕のないソフトウェア開発が引き起こす結果 のことを指す新しい比喩である。「設計上の負債」とも言う。
ざっくり ・古いシステムなどレガシーシステム ・設計ミス or 設計のないソフトウェアを技術的負債 ということで、悪いっぽいですね。
本当にそうでしょうか?
古いシステムということは枯れている(安定している)というこ とではないの?
当時は設計が適切であっても時代の流れに取り残されたら 技術負債になるよね?
モヤモヤしてきましたか?
モヤモヤしてきましたね?
でも、 レガシーシステム 技術的負債 にはみなさん悩まされていますよね?
では、 レガシーシステム 技術的負債 を”課題”と捉えてみるとどうでしょうか?
みなさん”課題”を”解決”することは 好き(面白い)ですよね?
じゃあ、 レガシーシステム 技術的負債 という”課題”を”解決”することは、 面白いことじゃないですか!?
ということで、 Diverseがどのように レガシーシステム 技術的負債 という”課題”と向き合っているか を話します!
では、 Diverseにおける レガシーシステム 技術的負債 の”課題”を元に分類してみます
インフラ • オンプレミス • 2013年にリプレースしたままの環境(youbrideの例) ◦ ホスト環境のOSが古い ◦ 仮想環境のOSが古い ◦
仮想環境内のソフトウェアのバージョンが古い アプリケーション
インフラ アプリケーション • サーバサイドの言語がPerl • 開発キャパを超えた仕様変更による改修
分類ができましたね それぞれの課題の詳細とアプローチを考えます
• オンプレミス • 2013年にリプレースしたままの環境(youbrideの例) ◦ ホスト環境のOSが古い ◦ 仮想環境のOSが古い ◦ 仮想環境内のソフトウェアのバージョンが古い
インフラ アプリケーション
オンプレミスの課題 オンプレ = 悪ではありませんが、 • 即時のスケールアップが難しい • 開発環境の増設なども保守会社への問い合わせが必要 といった点がプロダクトの成長にネックになっています。
オンプレミスへのアプローチ 開発を円滑に進めるためにAWSなどのクラウドへの移行を進めています。 オンプレミス環境を一気に全部移行することは出来ません。 そのため、機能単位でクラウド環境に移行を計画しています。 現在は、STFからAWS S3に移行をしています。
• オンプレミス • 2013年にリプレースしたままの環境(youbrideの例) ◦ ホスト環境のOSが古い ◦ 仮想環境のOSが古い ◦ 仮想環境内のソフトウェアのバージョンが古い
インフラ アプリケーション
2013年のままの環境の課題 重大なセキュリティパッチのみ当てる運用になっていたため、 • 重大なセキュリティリスクはないがソフトウェアが構成が古い • なので、メジャーバージョンアップには設定ファイルのマイグレーションも必 要になる • 結果、アップデートが難しい という状況になっています。
2013年のままの環境へのアプローチ 社内の文化と体制に問題があると考え、 • 上長に現状の課題を認識してもらう • 認識してもらった上で、社内にSRE部隊を整備することに同意してもらう という、課題を解消するための組織作りを始めています。
• サーバサイドの言語がPerl • 開発キャパを超えた仕様変更による改修 インフラ アプリケーション
サーバサイドの言語がPerlの課題 Perlは年に1回アップデートされており、メンテナンスされています。 そのため、Perl = レガシーではないと個人的には考えています。 ただし、 • 言語のシェアが減っており、Perlでの求人活動はすごく難しい • 社内に第一言語がPerlの人が少なくなった
という課題を抱えています。
サーバサイドの言語がPerlへのアプローチ (youbrideの例) 求人活動の課題はクリティカルになっているため、積極的にPerlから別の言語に 移行する作業を進めています。 youbrideではWeb/API双方が必要なため、マイクロサービス化は考えずにフル スタックなフレームワークを持つRubyへの移行を現在進めています。 (仲間募集中です!)
• サーバサイドの言語がPerl • 開発キャパを超えた仕様変更による改修 インフラ アプリケーション
開発キャパを超えた仕様変更による改修の課題 設計や実装や単体テストへの対応の時間がないことによって 1. 安易に巨大なBaseクラスが作成される 2. 便利だけど黒魔術的なUtilityが大量に作られる 3. Modelが強すぎて後から単体テストが難しい などの課題が生まれていました。
開発キャパを超えた仕様変更による改修へのアプローチ1 (youbrideの例) • カンバンでのタスクコントロールを行う タスクを見える化し、1スプリントで実施できる タスクを明確にすることでキャパシティを超える 開発をしないように調整しています。
開発キャパを超えた仕様変更による改修へのアプローチ2 (youbrideの例) • 設計方針はチームで認識をあわせてから簡易なドキュメントを作成 巨大なBaseを作らないなどの意識を統一しながら進めています。 ただし、どんなに設計をしても時代が変われば合わなくなっていきます。 放置せず適切な形にメンテナンスし続けることが大事です!!!!
全然語り足りていないので 懇親会でぜひ話しましょう〜
おわり