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
970
脱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
210
MQ(メッセージキュー)入門
hira
0
800
マイクロサービス化に向けて
hira
0
170
CI(継続的インテグレーション)
hira
0
98
Other Decks in Technology
See All in Technology
昔話で振り返るAWSの歩み ~S3誕生から20年、クラウドはどう進化したのか~
nrinetcom
PRO
0
120
AI時代のオンプレ-クラウドキャリアチェンジ考
yuu0w0yuu
0
610
15年メンテしてきたdotfilesから開発トレンドを振り返る 2011 - 2026
giginet
PRO
1
200
開発チームとQAエンジニアの新しい協業モデル -年末調整開発チームで実践する【QAリード施策】-
kaomi_wombat
0
260
OPENLOGI Company Profile for engineer
hr01
1
61k
GitHub Actions侵害 — 相次ぐ事例を振り返り、次なる脅威に備える
flatt_security
8
6.3k
MCPで決済に楽にする
mu7889yoon
0
160
OCI技術資料 : ロード・バランサ 概要 - FLB・NLB共通
ocise
4
27k
ADK + Gemini Enterprise で 外部 API 連携エージェント作るなら OAuth の仕組みを理解しておこう
kaz1437
0
230
SaaSの操作主体は人間からAIへ - 経理AIエージェントが目指す深い自動化
nishihira
0
120
互換性のある(らしい)DBへの移行など考えるにあたってたいへんざっくり
sejima
PRO
0
310
JEDAI認定プログラム JEDAI Order 2026 受賞者一覧 / JEDAI Order 2026 Winners
databricksjapan
0
400
Featured
See All Featured
Future Trends and Review - Lecture 12 - Web Technologies (1019888BNR)
signer
PRO
0
3.3k
Why Mistakes Are the Best Teachers: Turning Failure into a Pathway for Growth
auna
0
100
Effective software design: The role of men in debugging patriarchy in IT @ Voxxed Days AMS
baasie
0
270
Building Experiences: Design Systems, User Experience, and Full Site Editing
marktimemedia
0
460
The Myth of the Modular Monolith - Day 2 Keynote - Rails World 2024
eileencodes
26
3.4k
Leadership Guide Workshop - DevTernity 2021
reverentgeek
1
250
Leo the Paperboy
mayatellez
5
1.6k
SEOcharity - Dark patterns in SEO and UX: How to avoid them and build a more ethical web
sarafernandez
0
150
Done Done
chrislema
186
16k
Design of three-dimensional binary manipulators for pick-and-place task avoiding obstacles (IECON2024)
konakalab
0
390
Thoughts on Productivity
jonyablonski
75
5.1k
Hiding What from Whom? A Critical Review of the History of Programming languages for Music
tomoyanonymous
2
600
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のデバッグを実行 コンテナを意識することなく従来通りの開発が可能