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
810
脱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
180
MQ(メッセージキュー)入門
hira
0
700
マイクロサービス化に向けて
hira
0
150
CI(継続的インテグレーション)
hira
0
81
Other Decks in Technology
See All in Technology
人工衛星のファームウェアをRustで書く理由
koba789
14
7.6k
スマートファクトリーの第一歩 〜AWSマネージドサービスで 実現する予知保全と生成AI活用まで
ganota
2
210
これでもう迷わない!Jetpack Composeの書き方実践ガイド
zozotech
PRO
0
320
2025年夏 コーディングエージェントを統べる者
nwiizo
0
140
職種の壁を溶かして開発サイクルを高速に回す~情報透明性と職種越境から考えるAIフレンドリーな職種間連携~
daitasu
0
150
KotlinConf 2025_イベントレポート
sony
1
120
react-callを使ってダイヤログをいろんなとこで再利用しよう!
shinaps
1
230
Snowflake Intelligenceにはこうやって立ち向かう!クラシルが考えるAI Readyなデータ基盤と活用のためのDataOps
gappy50
0
150
複数サービスを支えるマルチテナント型Batch MLプラットフォーム
lycorptech_jp
PRO
0
320
なぜスクラムはこうなったのか?歴史が教えてくれたこと/Shall we explore the roots of Scrum
sanogemaru
5
1.6k
機械学習を扱うプラットフォーム開発と運用事例
lycorptech_jp
PRO
0
230
初めてAWSを使うときのセキュリティ覚書〜初心者支部編〜
cmusudakeisuke
1
240
Featured
See All Featured
Product Roadmaps are Hard
iamctodd
PRO
54
11k
10 Git Anti Patterns You Should be Aware of
lemiorhan
PRO
656
61k
Fashionably flexible responsive web design (full day workshop)
malarkey
407
66k
What's in a price? How to price your products and services
michaelherold
246
12k
VelocityConf: Rendering Performance Case Studies
addyosmani
332
24k
Bootstrapping a Software Product
garrettdimon
PRO
307
110k
Designing Dashboards & Data Visualisations in Web Apps
destraynor
231
53k
A designer walks into a library…
pauljervisheath
207
24k
How to Think Like a Performance Engineer
csswizardry
26
1.9k
Large-scale JavaScript Application Architecture
addyosmani
512
110k
Typedesign – Prime Four
hannesfritz
42
2.8k
ReactJS: Keep Simple. Everything can be a component!
pedronauck
667
120k
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のデバッグを実行 コンテナを意識することなく従来通りの開発が可能