Upgrade to Pro
— share decks privately, control downloads, hide ads and more …
Speaker Deck
Speaker Deck
PRO
Sign in
Sign up for free
DockerでNodeの開発は厳しいのか? #gotandajs
mizuki_r
May 10, 2019
Technology
3
310
DockerでNodeの開発は厳しいのか? #gotandajs
mizuki_r
May 10, 2019
Tweet
Share
More Decks by mizuki_r
See All by mizuki_r
税理士ドットコムの 技術的挑戦 #tapioca_lt
rymizuki
0
200
PHPを始めて1年、レガシーシステムにどう向き合っているか #phpstudy
rymizuki
1
410
モダンとレガシー #gotandaem
rymizuki
0
370
Vuexに型を付けるパターンを調べた #gotandajs
rymizuki
0
87
マネージャー!きみは何者だ! #gotandaem
rymizuki
0
1.4k
物語を楽しむための物語論
rymizuki
0
410
失敗と向き合う
rymizuki
0
990
社内勉強会と組織の成長を考える
rymizuki
1
2.1k
Webpackのビルド時間を1/3にした話 #gotandajs
rymizuki
9
3.7k
Other Decks in Technology
See All in Technology
Multi-Cloud Gatewayでデータを統治せよ!/ Data Federation with MCG
tutsunom
1
280
日経電子版だけじゃない! 日経の新規Webメディアの開発 - NIKKEI Tech Talk #3
sztm
0
320
データ分析基盤の要件分析の話(202201_JEDAI)
yabooun
0
260
SPA・SSGでSSRのようなOGP対応!
simo123
2
150
【NGK2023S】 ノードエディタ形式の画像処理ツール「Image-Processing-Node-Editor」
kazuhitotakahashi
0
290
スクラム導入して変わったチーム、組織のありかた
yumechi
0
190
地方自治体業務あるある ーアナログ最適化編-
y150saya
1
270
OPENLOGI Company Profile
hr01
0
12k
OpenShiftでスポットVMを使おう.pdf
jpishikawa
1
340
書籍を書きました。 そう、VS Codeで。
takumanakagame
4
4.4k
cdk deployに必要な権限ってなんだ?
kinyok
0
180
立ち止まっても、寄り道しても / even if I stop, even if I take a detour
katoaz
0
580
Featured
See All Featured
ピンチをチャンスに:未来をつくるプロダクトロードマップ #pmconf2020
aki_iinuma
31
20k
Happy Clients
brianwarren
90
5.8k
A Modern Web Designer's Workflow
chriscoyier
689
180k
Three Pipe Problems
jasonvnalue
89
8.9k
Done Done
chrislema
178
14k
Reflections from 52 weeks, 52 projects
jeffersonlam
338
18k
Designing on Purpose - Digital PM Summit 2013
jponch
108
5.9k
Large-scale JavaScript Application Architecture
addyosmani
499
110k
Facilitating Awesome Meetings
lara
33
4.6k
Teambox: Starting and Learning
jrom
124
7.9k
Designing the Hi-DPI Web
ddemaree
273
32k
Building Applications with DynamoDB
mza
85
5k
Transcript
DockerでNodeの開発は厳しいのか? 2019/05/10 Gotanda.js #11 @mizuki_r
@mizuki_r 弁護士ドットコム株式会社 税理士ドットコム事業部/開発チーム チームマネージャー 2 自己紹介 JavaScript, Vue, Nuxt, Perl,
PHP, Docker, AWS, etc…
免責事項 • VS Code使いの意見です • intelijも試したかったけど時間が… • 所属する組織・団体の主張ではなく、個人 の意見です •
鵜呑みにせず、参考にとどめましょう
Node環境もDockerにしたい
Node on Dockerしたい • 複数プロジェクトを並列で開発している • グローバルインストールしたくない • ndenv, nvm,
etc, メンテしたくない • docker-composeに集約したい
Docker for Macは mounted volumeの IOが非常に遅い
IOが非常に遅い • mounted volumeの更新系が遅い • Nodeを用いた開発はファイルのW/Rが非常 に多くなる • npm install,
build処理など • これが遅いのは致命的
rm -rf node_modules/* && npm install 環境 実行時間 ホストマシン 14.93s
Docker with mounted volumes 86.83s
Dockerにmountしたvolume への更新は遅い
mountしなければいいのでは?
mounted volumeでの 大幅なIO更新をやめる
mounted volumeをやめる node_modulesを上書きして、ホストにマウントしなくする
rm -rf node_modules/* && npm install 環境 実行時間 ホストマシン 14.93s
Docker with mounted volumes 86.83s Docker without mounted volumes 20.22s
だいぶマシになった。
mounted volumeしないと 困るか?
VS Code使いあるある • eslint, typescriptのVS Code Serverがホ ストに必要 • node_modulesを直接参照(見る・書換る)
したい
コンテナの中で VS Code Serverを動かせればぁ…
VS Code Insiders
VS Code Insiders • vscodeの新機能を確認したり、テストした りするためのInsiders Programの後継 • 通常版のvscodeと同居でき、設定も別のエ ディタとして利用する
https://code.visualstudio.com/insiders/
Developing inside a Container • Remote Developmentの拡張を追加するこ とでSSH, Containers, WSLとの通信が可能
• リモートでVS Code Serverを実行し、リ モートの環境で行われたあれこれをホスト 側のVS Codeに反映してくれる https://code.visualstudio.com/docs/remote/containers
None
まとめ
まとめ • NodeJS on DockerはIOのマウントを外せ ば軽減する • VS CodeのInsiders buildを使うことでホ
ストにマウントせず開発ができる
実行環境
実行環境 • MBP 2018 Core i7 16GB • Docker version
18.09.2, build 6247962 • docker-compose version 1.23.2, build 1110ad01 • node v11.15.0
実験コード https://github.com/rymizuki/example-node-on-docker