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 on Dockerとの戦い
Search
Sponsored
·
Your Podcast. Everywhere. Effortlessly.
Share. Educate. Inspire. Entertain. You do you. We'll handle the rest.
→
Yasutomo Uemori
PRO
December 09, 2017
Programming
38
0
Share
Rails on Dockerとの戦い
Rails Developer Meetup2017でのLTのスライドになります
Yasutomo Uemori
PRO
December 09, 2017
More Decks by Yasutomo Uemori
See All by Yasutomo Uemori
よくわかる新収益認識基準
wakaba260
PRO
0
990
いまどきのゲームサーバアーキテクチャ
wakaba260
PRO
1
470
オンラインゲームのRails複数db戦略
wakaba260
PRO
0
82
Active job meets kubernetes
wakaba260
PRO
0
38
Ruby/Rails Benchmarking and Profiling with TDD
wakaba260
PRO
0
64
GCP・GKEで作るスケーラブルなゲーム開発環境
wakaba260
PRO
0
76
サービスクラス、その前に
wakaba260
PRO
0
38
Rubocopとの付き合い方
wakaba260
PRO
0
43
Rails api way in aiming
wakaba260
PRO
0
45
Other Decks in Programming
See All in Programming
Cyrius ーLinux非依存にコンテナをネイティブ実行する専用OSー
n4mlz
0
260
The free-lunch guide to idea circularity
hollycummins
0
390
条件判定に名前、つけてますか? #phperkaigi #c
77web
2
900
Codex CLIのSubagentsによる並列API実装 / Parallel API Implementation with Codex CLI Subagents
takatty
2
750
Tamach-sre-3_ANDPAD-shimaison93
mane12yurks38
0
220
どんと来い、データベース信頼性エンジニアリング / Introduction to DBRE
nnaka2992
1
350
実践ハーネスエンジニアリング #MOSHTech
kajitack
7
5.2k
Codexに役割を持たせる 他のAIエージェントと組み合わせる実務Tips
o8n
4
1.5k
Agentic AI: Evolution oder Revolution
mobilelarson
PRO
0
220
野球解説AI Agentを開発してみた - 2026/02/27 LayerX社内LT会資料
shinyorke
PRO
0
380
Codex の「自走力」を高める
yorifuji
0
1.3k
「接続」—パフォーマンスチューニングの最後の一手 〜点と点を結ぶ、その一瞬のために〜
kentaroutakeda
4
2.3k
Featured
See All Featured
Self-Hosted WebAssembly Runtime for Runtime-Neutral Checkpoint/Restore in Edge–Cloud Continuum
chikuwait
0
440
Into the Great Unknown - MozCon
thekraken
40
2.3k
Stop Working from a Prison Cell
hatefulcrawdad
274
21k
SERP Conf. Vienna - Web Accessibility: Optimizing for Inclusivity and SEO
sarafernandez
2
1.4k
Thoughts on Productivity
jonyablonski
75
5.1k
How to optimise 3,500 product descriptions for ecommerce in one day using ChatGPT
katarinadahlin
PRO
1
3.5k
I Don’t Have Time: Getting Over the Fear to Launch Your Podcast
jcasabona
34
2.7k
CoffeeScript is Beautiful & I Never Want to Write Plain JavaScript Again
sstephenson
162
16k
Fashionably flexible responsive web design (full day workshop)
malarkey
408
66k
"I'm Feeling Lucky" - Building Great Search Experiences for Today's Users (#IAC19)
danielanewman
231
22k
How STYLIGHT went responsive
nonsquared
100
6k
Amusing Abliteration
ianozsvald
0
150
Transcript
Rails on Docker との戦い
自己紹介 植森 康友 株式会社Aiming 主な仕事 WebAPI 開発 devops Docker おじさん
普段のrailsdm では大阪側のスタッフをしてます
最初に LT に向けてスライドを調整していたら時間が全然なかったので 技術的な話をする時間はありません スライドの内容を削ってたらrails の話がなくなりました というわけでrails と全然関係ない話をします
Rails on Docker との戦い タイトルに偽りあり
Docker 化のモチベー ション
Docker 化のモチベー ション
Docker 化のモチベー ション 個人的に大きいのは「 アプリケー ション規格の統一化」 セットアップ方法 → d o
c k e r b u i l d 必要なミドルウェア → docker のみ 起動方法 → d o c k e r r u n デプロイフロー → イメー ジのビルド、push、 起動 コンポー ネントの連携 → docker‑compose、kubernetes → その結果として環境の再構築や複数環境の立ち上げが楽に チームに複数のアプリケーションを開発している人がいると恩恵が大きい
とはいえ問題がなくなるわけではない docker ならではのトラブルや悩みが発生する 学習コスト、 チー ムの習熟度・ 理解度 開発環境 コンテナならではのトラブル
学習コスト、 チー ムの習熟度・ 理解度 easy 出典: ふつうのRails アプリケー ション開発
学習コスト、 チー ムの習熟度・ 理解度 docker の開発フロー に乗っかると d o c
k e r - c o m p o s e b u i l d でビルドする d o c k e r - c o m p o s e u p で起動する d o c k e r - c o m p o s e r u n でコマンド実行する → easy
None
学習コスト、 チー ムの習熟度・ 理解度 慣れてない人はdocker 自体がそもそもeasy ではない 出典: ふつうのRails アプリケー
ション開発
学習コスト、 チー ムの習熟度・ 理解度 例えば、 ラップして使いやすくする 今のプロジェクトは歴史的経緯で「easy = シェルスクリプト」 今までとあまり変わらないフローにすることで導入障壁が減った
開発でdocker を使うとき docker for mac volume めっちゃ遅い mac だと動くけどlinux では動かない
linux だと発生するvolume のpermission denied network エディタとかとの親和性が微妙 gem へのタグジャンプとか gem のコー ドを見たい docker(for mac) と相性が悪いアプリケー ションもある 普段の開発では不便な点も多々 ある docker for macまじでつらい
開発でdocker を使うとき Q. 我々 はdocker 化することで何がしたかったか? A.
開発でdocker を使うとき Q. 我々 はdocker 化することで何がしたかったか? A.
開発でdocker を使うとき docker 化することでしんどくなったら本末転倒 docker であることにこだわらない チー ムにとって楽な方に倒す だいじなこと →
「 できる」 こと 本番とほぼおなじイメー ジを起動できる CI とほぼおなじテストを実行できる セットアップ、 再構築がかんたんにできる
その他、 いろんなトラブル 開発環境 docker のイメー ジビルド時間 環境変数(≒ グロー バル変数) の増殖
CI 環境(in jenkins slave) docker network 作成数が上限に達して死ぬ イメー ジやボリュー ムがディスク圧迫して死ぬ docker‑compose のコンテナ名が被って死ぬ デプロイ環境 private registry docker デー モンの意味不明なエラー ロギングどうする? 話し始めるとキリがない話題なので詳しくは懇親会で
docker での困り事:CI 環境
docker での困り事: デプロイ環境 dockerホストを自前で管理するのはつらい
docker 化で得たもの アプリケー ション規格の統一化 docker 化しておけばとりあえずなんとかなるし動かせる レビュー のしやすい環境 ロー カルでも複数の環境をさくっと立てれる
git worktree → docker‑compose build & up ポー タビリティ デプロイ・CI でもできることがロー カルでもできる デプロイ・CI でも複数の環境をかんたんに立ち上げられる
まとめ: Docker との戦い docker ならではの苦労もあるが、docker 化のメリットは大きい だいじなこと チー ムに合った方法を選ぶ easy
本質(docker 化で解決したかったこと) を忘れない dockerでの導入でも、 「ふだんの開発で気をつけること」こそ重要でした
We are hiring! 株式会社Aiming ではエンジニアを募集しています! Rails に興味がある Devops に興味がある 懇親会でもお話しましょう