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
My home VM Solution by premade MicroOS
Search
Sponsored
·
Ship Features Fearlessly
Turn features on and off without deploys. Used by thousands of Ruby developers.
→
hashimotosyuta
November 06, 2022
Technology
2.3k
0
Share
My home VM Solution by premade MicroOS
I explain my home VM solution by premade MicroOS.
hashimotosyuta
November 06, 2022
More Decks by hashimotosyuta
See All by hashimotosyuta
[Cross Distro Developers Camp] open source conference 2023 Online/Spring
hashimotosyuta
0
210
Kubic with OpenSDS
hashimotosyuta
0
300
Dockerの使い方
hashimotosyuta
1
420
Kubicで簡単お手軽Kubernetesクラスタ構築
hashimotosyuta
0
2.7k
Kubernetes動かしてみた
hashimotosyuta
0
260
DRBD block device replication solution for HA cluster mainly
hashimotosyuta
0
690
Dockerイメージの脆弱性診断をPortus & Clairで
hashimotosyuta
1
1.3k
PortusでプライベートDockerレジストリを作ってみよう 設定編
hashimotosyuta
0
2.7k
PortusでプライベートDockerレジストリを作ってみよう
hashimotosyuta
1
3.2k
Other Decks in Technology
See All in Technology
JJUG CCC 2026 Spring AI時代の開発こそ標準化を武器に! ― 方式・プロセス・プラットフォームの標準化
s27watanabe
2
670
価格.comをAI駆動で全面刷新する ー 30年分の技術的負債を返し、次の30年の土台をつくる ー
tkyowa
8
5.4k
サプライチェーンセキュリティの空白地帯 - 信頼できる”依存性”の未来を考える
rung
PRO
2
630
Spring Boot における AOT Cache 活用テクニックと 起動時間改善事例
ntt_dsol_java
0
200
AI Engineering Summit Tokyo 2026 AIの前に、やることがある 〜医療データ企業の4フェーズ〜
dtaniwaki
0
600
AI フレンドリーなエラー監視を TypeScript で実現する
shinyaigeek
2
210
Oracle AI Database@Google Cloud:サービス概要のご紹介
oracle4engineer
PRO
6
1.5k
「嘘をつくテスト」の失敗例から学ぶ 良いテストコード #frontend_phpcon_do
asumikam
0
140
Claude Codeを組織で使いこなす— サーバサイドAIエージェント運用の実践知
techtekt
PRO
0
160
AIプラットフォームを運用し続けるための可観測性
tanimuyk
4
980
Gradle×GitHub_ActionsでCI時間を約50%短縮 ジョブ分割の設計と落とし穴 / Cutting CI Time by ~50% with Gradle and GitHub Actions: Job-Splitting Design and Pitfalls
takatty
0
590
オンコールの負荷軽減のためのBits Assistant 活用方法 / How to Use Bits Assistant to Reduce the Workload on On-Call Staff
sms_tech
1
370
Featured
See All Featured
The AI Search Optimization Roadmap by Aleyda Solis
aleyda
1
5.8k
Statistics for Hackers
jakevdp
799
230k
Making Projects Easy
brettharned
120
6.7k
How To Speak Unicorn (iThemes Webinar)
marktimemedia
1
470
How to train your dragon (web standard)
notwaldorf
97
6.7k
Design and Strategy: How to Deal with People Who Don’t "Get" Design
morganepeng
133
19k
The Straight Up "How To Draw Better" Workshop
denniskardys
239
140k
Reflections from 52 weeks, 52 projects
jeffersonlam
356
21k
Practical Orchestrator
shlominoach
191
11k
Being A Developer After 40
akosma
91
590k
Why Your Marketing Sucks and What You Can Do About It - Sophie Logan
marketingsoph
0
160
Distributed Sagas: A Protocol for Coordinating Microservices
caitiem20
333
22k
Transcript
YAML に書いた宣言的な定義から VM を作ってみた 〜一般のご家庭向け ver 〜 power of orchestration
openSUSE-ja hashimotosyuta @syuta_openSUSE
イントロダクション • MicroOS • Combustion • Bash • Ansible •
SaltStack • k3s KVM
宣言的とは 「どうやるか」では無く、 「どんな結果が欲しいか」に 主眼を置く方法論 – ここでは、欲しい VM のスペック を設定ファイル( YAML
)に書く ことで実現する方法を指します。
こんなことがありませんか? • ホストに余計なものを入れたくない – 極力ホストは欲しい物、必要な物だけにしたい • 検証用の使い捨てVMが欲しい – コンテナなどサーバー技術をちょっと使ってみた い
• SaltStackやKubernetesを試したい 何なら使いたい – 複数マシンのコラボレーションを体感したい
検証用 VM あるある • 自宅サービス提供 VM の横で検証 – 自宅サービスが煽りをくって止まる •
実は前のソフトの検証時に、今回必 要なパッケージが一部入っていた – 今回の手順だけだと動かない
SaltStack SaltStack Master の指示により、 Minion が各種設定を行う SaltStack Master SaltStack Minion
Virtual Machine Virtual Machine 各種設定 SaltStack Minion Virtual Machine 各種設定 Virtual Machine SaltStack Minion Virtual Machine 各種設定 Virtual Machine
Kubernetes Master Node の指示により、 Worker Node がコンテナを動 かす ※概略です Master
Node Worker Node コンテナ Worker Node コンテナ Worker Node コンテナ コンテナ
宣言的 KVM SCRIPT YAML
構成要素 YAML サービス Virtual Machine ネットワークなどの基本設定 スクリプト MicroOS Ansible SaltStack
Combustion KVM
ハードウェアとソフトウェア VM VM VM サービス B サービス B VM サービス
A
YAML ハードウェア domainname: k3s_master type: microos hostname: k3s-master enp2s0: ip:
192.168.254.150 subnet: 24 vcpus: 2 ansible: - { role: saltmaster } vm: - "saltstack_master" - "k3s_master" - "k3s_worker1" - "k3s_worker2" playbook: - "saltmaster" - "saltminion" メイン / ソフトウェア
レイヤー間の連携 ハードウェア設定 YAML ansible: - { role: saltmaster } インベントリ
ファイル playbook 書き込む 参照する [saltmaster] 192.168.xxx.yyy hosts:saltmaster
MicroOS & Combustion • MicroOS – イミュータブル – コンテナ最適化 –
軽量 • Combustion – MicroOS 初期設定スクリプト
Combustion による設定 YAML MicroOS ホストネームなどの 基本設定 スクリプト 設定ファイル 雛形 設定ファイル
Combustion 設定ファイル 初期化スクリプト 作成 設定 配置
k3s
解決済課題 • ネットワーク設定 – NetworkManagerにいつの間にか変わっていた • VM 並列作成 – インベントリファイル同時に書き込んじゃう問題
• 初回SSHログイン確認ダイアログ – ssh-keyscanでknown hostsに追記することで回避 • ストレージアタッチメント – 永続ボリュームは必須
ストレージアタッチメント VM ホスト コンテナ LVM ハードウェア設定 YAML playbook
解決したい課題 • フロントエンドからの制御 – YAML編集やスクリプト実行を制御 • VM生成中の中断、クリーンアップ – ホスト起動時に自動実行とかした場合、即シャットダ ウンする可能性がある
• MicroOSプリメイドイメージの自動アップデート – 検証用アップデートと簡単なテスト • pythonで書き直したい – bashは悪くないけれどちょっと辛い
Thank you