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
事業に向き合い続けたい私は、それでもRailsを使い続ける
Search
Sponsored
·
SiteGround - Reliable hosting with speed, security, and support you can count on.
→
Hideaki ishii
October 23, 2021
Programming
6.5k
8
Share
事業に向き合い続けたい私は、それでもRailsを使い続ける
こちらの発表内容です。
https://kaigionrails.org/2021/talks/danimal141/
Hideaki ishii
October 23, 2021
More Decks by Hideaki ishii
See All by Hideaki ishii
良いコードレビューとは
danimal141
14
12k
I know everything about mocks, stubs, and spies in RSpec
danimal141
0
270
Other Decks in Programming
See All in Programming
「速くなった気がする」をデータで疑う
senleaf24
0
110
[PHPerKaigi 2026]PHPerKaigi2025の企画CodeGolfが最高すぎて社内で内製して半年運営して得た内製と運営の知見
ikezoemakoto
0
310
夢の無限スパゲッティ製造機 -実装篇- #phpstudy
o0h
PRO
0
180
「効かない!」依存性注入(DI)を活用したAPI Platformのエラーハンドリング奮闘記
mkmk884
0
280
Migration to Signals, Signal Forms, Resource API, and NgRx Signal Store @Angular Days 03/2026 Munich
manfredsteyer
PRO
0
200
存在論的プログラミング: 時間と存在を記述する
koriym
5
690
Ruby and LLM Ecosystem 2nd
koic
1
1.4k
Codex CLI でつくる、Issue から merge までの開発フロー
amata1219
0
260
Fundamentals of Software Engineering In the Age of AI
therealdanvega
2
310
ネイティブアプリとWebフロントエンドのAPI通信ラッパーにおける共通化の勘所
suguruooki
0
230
AWS×クラウドネイティブソフトウェア設計 / AWS x Cloud-Native Software Design
nrslib
16
3.5k
20260313 - Grafana & Friends Taipei #1 - Kubernetes v1.36 的開發雜記:那些困在 Alpha 加護病房太久的 Metrics
tico88612
0
240
Featured
See All Featured
Creating an realtime collaboration tool: Agile Flush - .NET Oxford
marcduiker
35
2.4k
HU Berlin: Industrial-Strength Natural Language Processing with spaCy and Prodigy
inesmontani
PRO
0
300
Lightning Talk: Beautiful Slides for Beginners
inesmontani
PRO
1
500
Getting science done with accelerated Python computing platforms
jacobtomlinson
2
160
Beyond borders and beyond the search box: How to win the global "messy middle" with AI-driven SEO
davidcarrasco
3
97
The AI Revolution Will Not Be Monopolized: How open-source beats economies of scale, even for LLMs
inesmontani
PRO
3
3.2k
A Soul's Torment
seathinner
5
2.6k
Winning Ecommerce Organic Search in an AI Era - #searchnstuff2025
aleyda
1
1.9k
From π to Pie charts
rasagy
0
160
[RailsConf 2023] Rails as a piece of cake
palkan
59
6.4k
KATA
mclloyd
PRO
35
15k
Navigating Weather and Climate Data
rabernat
0
150
Transcript
事業に向き合い続けたい私は、 それでもRails を使い続ける @danimal141 Kaigi on Rails 2021
今回、私はこういう話をするために来ました
エンジニアの責任とは「ただ技術をマスターすることではな く、技術を使って事業上の課題を解決すること」ではないか
それを達成するための武器として、Rails って最高では?
Rails ですべての課題を解決できるわけではない モダンな技術の力も借りてコトに向き合っていきたいすね
自己紹介 @danimal141 フロントエンドエンジニアとしてキャリアスタート ベンチャー -> ソシャゲの会社 -> (7 年ぐらい) 創業メンバーとしてスタートアップへ
-> ( 今ここ) Speee 0 →1 開発が多め、エンジニア採用関連の仕事もやりがち ( 得意) 自分が一生懸命書いたコードを何のためらいもなく削除することッ! エンジニア歴10 年ぐらい Rails 歴は8 年ぐらい 今日のスライドはこちらから見れます! https://bit.ly/3EboMEG
アジェンダ スタートアップでスキルコレクターになった話 技術を使って事業上の課題を解決することに向き合っていきたいという話 事業を成長させるための武器としてRails 最高では?でも辛みもあるのでは?という話 Rails とモダンな技術を良いとこ取りを試みた、直近のプロジェクトの話 まとめ
スタートアップでスキルコレクターになった話
突然なんですけど
エンジニアの方なら一度はこんなこと考えたことない ですか? 最近はGo やRust が流行ってるらしいから使ってみたいなぁ サーバサイドKotlin とかめっちゃイケてませんか? このままでいいのか、モダンな技術を習得して変化しないといけないんじゃないか…
わかる
めちゃめちゃわかる
過去の技術選定 ( 特にスタートアップ時代) 振り返り 受託開発なのを良いことに 1 ミリも使ったことないのに急にGo でAPI 実装しちゃう 受託開発なのを良いことに
発表されたばかりのSwift でiOS 開発しちゃう 社内のデータ分析基盤を作るためのデータ収集コマンドが急にKotlin で実装されちゃった もちろんそれぞれ、それなりの理由はあったのですが、「モダンだからひとまず使ってみたい、知らない技術 をキャッチアップしたい」というモチベーション駆動技術選定だったことは否めないと思っています。 I’m a skill collector!
もやっとポイント やはりエンジニアならモダンな技術を使いたい!マスターしたい!! 「達人プログラマーなら毎年少なくとも一つの言語を学習します」 -> 本当に? 自分が一番得意な技術がオワコンって言われていてツライ!! あれ、そもそもなんでそんなに新しい技術マスターしたいんだっけ?マスターして何するんだっけ? 使ったとして自分以外、誰か嬉しいんだっけ? 🧑💻 それって事業に貢献できるの?ユーザの役に立つの?
🧑💻 チームのエンジニア全員、その技術覚えないといけないけど、大丈夫そ? 🧑💻 今後、チーム拡大する時、採用大丈夫そ? 技術選定 is 難しい…
何を軸に考えればええんや… 技術との向き合い方に迷走する
技術を使って事業上の課題を解決することに向き合っ ていきたいという話
そもそも技術選定って何のためにするんだっけ? 世の中やユーザのニーズは日々変化するし、早くリリースして、早くユーザのフィードバックを得て改善し ていく必要がある Done is better than perfect… 特にスタートアップの場合、「ユーザに価値を届ける or
DIE 」 これを達成し続けられる状態にできるかどうか スタートアップや0 →1 開発をメインでやってきた私の場合
エンジニアの責任とは「ただ技術をマスターすることではな く、技術を使って事業上の課題を解決すること」ではないか
事業を成長させるための武器としてRails 最高では?で も辛みもあるのでは?という話
ここで気づいてしまいましたッ!
Rails って良くないですか?
過去の技術選定 ( 特にスタートアップ時代) 振り返りv2 確かに受託開発でモダンな技術を試しまくったりした 楽しかったなぁ🕺 社内のデータ分析基盤を作るためのデータ収集コマンドをKotlin で実装したこともあった 楽しかったなぁ🕺 でも、「なにかしらユーザに価値を届けたい」、「ユーザのためにプロダクトをとにかく高速に育てていき
たい」、そういった場面では常にRails を採用してきた それが事業上の目的を達成するための最速、最良の選択だと思っていたから
Rails の好きな所 事業として本来やるべきコアな機能開発に集中することができる レールが用意されているので、「どういう構成で作ろう」、「どうやって作ろう」みたいな部分でそこ まで悩まない ActiveRecord is 最高 エコシステム(Gem) の充実
0 →1 開発に向いている まず動くものを作り、ユーザのフィードバックを受けながらプロダクトを高速に改善して育てていくス タイル
一方で
Rails でこういう時ちょっと辛くないですか? フロントエンドどうする問題 ユーザの目が肥えてリッチなアプリケーションが標準みたいになってきている 細かいサイクルで変化するフロントエンドのView をjQuery やBackbone.js で実現するのは厳しい ( 個人の
意見です) もちろんHotwire のようなソリューションもあるが、React やVue と比較すると情報量やユーザ数は少な く、何かハマった時ツラそう…
こういったRails のメリット、デメリットを踏まえて
Rails とモダンな技術を良いとこ取りを試みた、直近の プロジェクトの話
直近のプロジェクトの話 不動産領域で新規プロダクトを開発しています! ユーザと不動産会社の担当者がやり取りするチャットUI リアルタイム更新 toB 向け、toC 向けにそれぞれプロダクトを提供する 複雑な条件入力フォーム
技術選定軸 なるべく事業に必要なコアな機能開発に集中したい コアじゃないことであまり悩みたくない、なるべく楽したい リッチなフロントエンド開発に耐えられるような構成にしたい
Backend Rails (API) Rails Way に乗ることで本来やるべきコアな機能開発に集中したい メンバーが使い慣れている GraphQL 不動産領域を扱っており「物件とそれに紐づく様々な情報」という関係性のデータ構造が多く、かつ肝 になる
型定義によるバリデーションがあり、フロントエンドでTypeScript を使う想定だったので相性が良い チャットでリアルタイム更新があり、Subscription が使えそう (GraphQL Pro を使っています) Auth0 認証、認可などアプリケーション上、必要だがプロダクトにとってコアではないものはできるだけショ ートカットしたい
Frontend (toB 、toC がある) React.js チャットUI のような複雑なView の開発が求められたのでReact かVue を使いたい
メンバーが使い慣れている、TypeScript との親和性を考慮してReact TypeScript クリックやスクロールのように、ユーザ起点でのイベントが大量に発生するフロントエンドを中長期的 に生産性高く開発する上で必須と考えた
Infra あまり詳細触れないですが、開発生産性を高めるような技術を積極的に採用しています! AWS Kubernetes Terraform
まとめ 自分の成すべきこと、目的からブレずに意思決定をするのが大切 エンジニアの役割とは「ただ技術をマスターすることではなく、技術を使って事業上の課題を解決するこ と」 皆様も自分なりのエンジニアの役割について考えてみてほしいです! 事業の課題を解決していく上でRails ってやっぱり良いっすね、でも辛い時もあるっすね Rails の良さを活かしつつ、モダンな技術も採用して、コトに向き合って行きましょう💪😎 プロジェクトの具体的な話などはあまり詳しくお話できていないので、もし興味持ってくださった方はQA
ブ ースでお待ちしております! ただの雑談や家の売却や購入を検討されている方も大歓迎です🙋♂️