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
脱VM!リモートコンテナによる開発
Search
HIRA
February 09, 2021
Technology
0
720
脱VM!リモートコンテナによる開発
2021.2.9 社内勉強会発表資料
2022.5.21 SlideShareから移行
HIRA
February 09, 2021
Tweet
Share
More Decks by HIRA
See All by HIRA
AWS CloudFormationによる Infrastructure as Codeの実現
hira
0
170
MQ(メッセージキュー)入門
hira
0
630
マイクロサービス化に向けて
hira
0
130
CI(継続的インテグレーション)
hira
0
77
Other Decks in Technology
See All in Technology
ビズリーチが挑む メトリクスを活用した技術的負債の解消 / dev-productivity-con2025
visional_engineering_and_design
2
5k
Lambda Web Adapterについて自分なりに理解してみた
smt7174
5
150
改めてAWS WAFを振り返る~業務で使うためのポイント~
masakiokuda
1
210
Should Our Project Join the CNCF? (Japanese Recap)
whywaita
PRO
0
310
怖くない!はじめてのClaude Code
shinya337
0
330
Flutter向けPDFビューア、pdfrxのpdfium WASM対応について
espresso3389
0
110
5min GuardDuty Extended Threat Detection EKS
takakuni
0
180
CursorによるPMO業務の代替 / Automating PMO Tasks with Cursor
motoyoshi_kakaku
2
870
asken AI勉強会(Android)
tadashi_sato
0
160
KiCadでPad on Viaの基板作ってみた
iotengineer22
0
260
GeminiとNotebookLMによる金融実務の業務革新
abenben
0
250
20250625 Snowflake Summit 2025活用事例 レポート / Nowcast Snowflake Summit 2025 Case Study Report
kkuv
1
390
Featured
See All Featured
The Invisible Side of Design
smashingmag
301
51k
Helping Users Find Their Own Way: Creating Modern Search Experiences
danielanewman
29
2.7k
Rebuilding a faster, lazier Slack
samanthasiow
82
9.1k
Build The Right Thing And Hit Your Dates
maggiecrowley
36
2.8k
Fireside Chat
paigeccino
37
3.5k
CSS Pre-Processors: Stylus, Less & Sass
bermonpainter
357
30k
Building an army of robots
kneath
306
45k
[RailsConf 2023] Rails as a piece of cake
palkan
55
5.6k
Let's Do A Bunch of Simple Stuff to Make Websites Faster
chriscoyier
507
140k
It's Worth the Effort
3n
185
28k
Visualization
eitanlees
146
16k
実際に使うSQLの書き方 徹底解説 / pgcon21j-tutorial
soudai
PRO
181
53k
Transcript
脱VM!! リモートコンテナによる開発 (2021.2.9) KENJI HIRATA
現状課題 • 複数プロジェクトの開発保守のため個別の開発環境(VM)が 必要となる VMの容量が大きくHDD逼迫 VM起動により、CPU・メモリ等のリソース負荷がかかり、PCのス ペックが低いと重くて開発が困難
新規要員対しVMの提供が必要 (VPNではネットワーク的にきついためポータブルHDD等による受け渡し となる⇒出社が必要)
現状課題 • 複数プロジェクトの開発保守のため個別の開発環境(VM)が 必要となる VMの容量が大きくHDD逼迫 VM起動により、CPU・メモリ等のリソース負荷がかかり、PCのス ペックが低いと重くて開発が困難
新規要員対しVMの提供が必要 (VPNではネットワーク的にきついためポータブルHDDによる受け渡しと なる⇒出社が必要) ホスト環境を汚さず、かつVMを利用しないで開発ができないか??
解決策 • 開発環境を仮想コンテナ化 • VSCodeのRemote Containers機能でコンテナに接続して開発
仮想コンテナとは? ホストOS カーネル コンテナ コンテナ VM(仮想マシン) ゲストOS ゲストOS コンテナエンジンというプロセスを通して、ホストOSの「カーネル」を共有することでCPUやメモリなどのリソースを隔 離し、仮想的な空間を作り出す。これをコンテナ型仮想化という。
VMWare等のハイパーバイザ型仮想化に比べ、軽量かつ起動が早いというメリットがある。 カーネル カーネル ハイパーバイザー コンテナエンジン アプリ アプリ アプリ アプリ ミドル ウェア ミドル ウェア ミドル ウェア ミドル ウェア
代表的なコンテナエンジン「docker」 コンテナ型の仮想環境を作成、配布、実行するためのプラットフォーム 今回は、dockerを利用した開発の方法を紹介します。
コンテナ化するメリット • インフラ環境(実行に必要なミドルウェア、ライブラリ、他設定等)をコード化できる • コード化することでインフラをバージョン管理可能 • VMのように仮想マシンの配布ではなく、数キロバイトの定義ファイルのみの配布で済む。 • 簡単に作り直せるため、変更も容易。
WindowsでDockerを利用するためには • Hyper-Vを利用する • WSL2(Windows Subsystem Linux)を利用する どちらかの方法でDockerを起動させることができるが、Hyper-Vを利用する場合、VMWareが利用 できなくなる。 コンテナとVMの両立を実現するには、WSL2を利用する方法となる。
※WSL2の利用については下記ページを参照 Windowsローカル開発環境のコンテナとVMの共存運用に向けて https://qiita.com/kj_hira/items/be2631f26e6afbc5b0df
dockerを利用した開発フローの例 dockerコンテナ jar Javaランタイム dockerコンテナ jar Javaランタイム dockerコンテナ jar Javaランタイム
検証環境 本番環境 開発環境 コンテナリポジトリ ローカルPC コンテナ起動 アプリデプロイ PUSH PULL PULL 開発から本番まで同一の実行環境であることで、環境による動作不備の心配が不要。 ローカルでは動いたけどサーバ(他環境)では動かないといったことが無くなる。
dockerを利用した開発フローの例 dockerコンテナ jar Javaランタイム dockerコンテナ jar Javaランタイム dockerコンテナ jar Javaランタイム
検証環境 本番環境 開発環境 コンテナリポジトリ ローカルPC コンテナ起動 アプリデプロイ PUSH PULL PULL 開発から本番まで同一の実行環境であることで、環境による動作不備の心配が不要。 ローカルでは動いたけどサーバでは動かないといったことが無くなる。 しかし、開発メンバーにコンテナの知識が必要。 全員に習得してもらうのは無理がある・・・
コンテナを使った開発の難しさを解消 VSCodeのRemoteContainers機能を利用することで、コンテナを意識せずにコンテナによる開発が可能 引用:Visual Studio Code (Developing inside a Container)
開発者の操作手順の例 1. VSCodeを立ち上げる 2. Gitリポジトリから最新をPULL(またはclone) ※Dockerfileまたはdocker-composeファイルを取得 3. VSCodeのRemoteContainersを起動 ※ここで自動的にコンテナの生成と起動が行われる 4.
ソースコードを修正し、VSCodeのデバッグを実行 コンテナを意識することなく従来通りの開発が可能