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
モダンとレガシー #gotandaem
Search
mizuki_r
July 29, 2019
Technology
0
540
モダンとレガシー #gotandaem
mizuki_r
July 29, 2019
Tweet
Share
More Decks by mizuki_r
See All by mizuki_r
FrontendUp_新規事業で_Remixを採用した理由と対策.pdf
rymizuki
0
130
税理士ドットコムの 技術的挑戦 #tapioca_lt
rymizuki
0
260
PHPを始めて1年、レガシーシステムにどう向き合っているか #phpstudy
rymizuki
1
680
Vuexに型を付けるパターンを調べた #gotandajs
rymizuki
0
120
DockerでNodeの開発は厳しいのか? #gotandajs
rymizuki
3
370
マネージャー!きみは何者だ! #gotandaem
rymizuki
0
1.7k
物語を楽しむための物語論
rymizuki
0
510
失敗と向き合う
rymizuki
0
1.4k
社内勉強会と組織の成長を考える
rymizuki
1
2.6k
Other Decks in Technology
See All in Technology
Terraform にコントリビュートしていたら Azure のコストをやらかした話 / How I Messed Up Azure Costs While Contributing to Terraform
nnstt1
1
470
dbtとリバースETLでデータ連携の複雑さに立ち向かう
morookacube
0
140
AOAI で AI アプリを開発する時にまず考えたいこと
mappie_kochi
1
670
AWSを利用する上で知っておきたい名前解決の話
nagisa53
6
790
時間がないなら、つくればいい 〜数十人規模のチームが自律性を発揮するために試しているいくつかのこと〜
kakehashi
PRO
23
5.3k
テストコードにはテストの意図を込めよう(2025年版) #retechtalk / Put the intent of the test 2025
nihonbuson
PRO
3
730
Vibe Coding Tools
ijin
0
120
Azure & DevSecOps
kkamegawa
2
180
Sleep-time Compute: LLM推論コスト削減のための事前推論
sergicalsix
1
100
Compose におけるパスワード自動入力とパスワード保存
tonionagauzzi
0
210
MCP でモノが動くとおもしろい/It is interesting when things move with MCP
bitkey
2
470
非root化Androidスマホでも動く仮想マシンアプリを試してみた
arkw
0
120
Featured
See All Featured
The World Runs on Bad Software
bkeepers
PRO
68
11k
Dealing with People You Can't Stand - Big Design 2015
cassininazir
367
26k
The Myth of the Modular Monolith - Day 2 Keynote - Rails World 2024
eileencodes
24
2.7k
How to Think Like a Performance Engineer
csswizardry
23
1.6k
Understanding Cognitive Biases in Performance Measurement
bluesmoon
29
1.7k
Fashionably flexible responsive web design (full day workshop)
malarkey
407
66k
Faster Mobile Websites
deanohume
307
31k
Easily Structure & Communicate Ideas using Wireframe
afnizarnur
194
16k
Scaling GitHub
holman
459
140k
JavaScript: Past, Present, and Future - NDC Porto 2020
reverentgeek
48
5.4k
A Tale of Four Properties
chriscoyier
159
23k
Producing Creativity
orderedlist
PRO
344
40k
Transcript
モダンとレガシー 2019/07/29 #Gotanda.EM @mizuki_r
@mizuki_r 弁護士ドットコム株式会社 税理士ドットコム事業部/開発チーム チームマネージャー 2 自己紹介 PHP, Vue, Nuxt, Management,
Recruitment, etc…
今日のテーマ
モダン
レガシー
良く使われるこのワードを 組織にどう反映するか?
背景
税理士ドットコム • 日本最大級の税理士/税務ポータルサイト • 税理士紹介、Q&A、ニュースなど • サービス開始: 2006年 • エンジニア:
社員x1, 業務委託x5
自分のポジション • 開発マネージャー • テックリード • エンジニア(フロント・バック・インフラ)
開発Mgrの責任範囲 • 組織方針策定 • 個人目標・育成 • 採用
採用
よくあるやりとり
「どのような環境で働きたい ですか?」
「モダンな技術を使える」
「モダンな環境」
なるほど
税理士ドットコム • サーバ: PHP 7.2, Yii Frwamework 1.1 • 1年ほど前に7.2にバージョンアップ
• しかしnamespaceがない、autoloaderが 特殊など課題もある • フロント: jQuery, Vue, Sass
モダン…とは…?
モダン
–by Google “《名・ダナ》現代的。当世風”
–by wikipedia “「近代以前」の時代や社会と対照的な、社会 的、経済的、そしてイデオロギー的な特徴の多 くを描いた、 モダニティー 、大まかに定義さ れた概念”
Web開発で使われるモダン • 定義らしい定義はない • 流行りのトレンドとかその程度の温度感 • 「モダンとは?」と聞いて「これ」と返せ る人は多くない • 少なくとも僕は返せない
でもみんな一般的に使うよ ね?
レガシー
– コトバンク “遺産。先人の遺物” “時代遅れのもの。「レガシーシステム」”
Web開発で使われるレガシー • メンテナンス困難なコード郡 • 古いアーキテクチャや技術体系、言語 • 知識が断絶し、どうしてこうなっているか誰も知らない • 「レガシーとは?」と聞くと結構返せる人が多い •
多分新陳代謝が激しい組織においてはすぐレガシーにな る
数年運用してれば 大体レガシーでは?
モダンとレガシー
レガシーとモダン • 感覚的に「これはモダン」「これはレガシー」って 言ってない? • つまり感覚的に判断基準があり、そこに合意がある こともある • そしてエンジニアとして、無視できない課題でもあ る
• 「お前んとこレガシーじゃん」って言われたら悲しい
人がモダンを求めるとき、 本質的に何を求めるか?
モダンを求める意味 • 世の中の潮流に追いつけているか • メンテナンスされ、ニーズがあるものか • 可能性を開き、挑戦しているか
組織戦略としての軸
組織の文化として捉える • 今の技術的あるいは思想的に新しいものを取り 入れる余地があるか? • 何らかの技術的な挑戦を体外的にアウトプット できるか? • 盲目的に新技術を導入しようとしていないか? •
過去のシステムを否定しすぎていないか?
マインドとしてのモダニズム
とはいえ、新しいコトだけが 全てではない
新しいモノを重視しすぎる • 新しい技術の導入にかまけてビジネス的な価値を失う • → 全体を一斉にリファクタしよう • → 終わらない /
利用者にとって益がない • 全体を見通して何がビジネスにおいて必要なのかを見極め、ビジネスとシス テムのインピーダンスミスマッチを解消する • 今利益を生み出している仕組みを正しく理解する • エンジニアだけではなく、関係する部門に協力を仰ぎ、システ ムのあり方を問い直す必要がある
バランスを考慮して体制に反 映する • 新しい技術や思想の導入にはリスクや反発が伴う • しかし今までなかったナレッジを導入することで課題が 解消したり問題自体をなくす可能性もある • 可能性を閉ざさず、開いた状態でメンバーを含め判断で きる体制を敷く
ビジネスとのバランスが大切
まとめ
まとめ • モダンとレガシーにおける意味を考えた • 採用活動を通して生じた考えを体制に落と そうとしている • エンジニアはビジネスとシステムを繋ぐ橋 になるべき存在だと考えているので、それ を実現したい
ご清聴ありがとうございまし た