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
さくらのクラウドとDocker Swarm Modeで誰でもわかる簡単デプロイ @ さくら...
Search
chibiegg
December 23, 2019
Technology
4.5k
0
Share
さくらのクラウドと Docker Swarm Modeで 誰でもわかる簡単デプロイ @ さくらの聖夜2019 / Simple Deployment with SAKURA Cloud and Docker Swarm
chibiegg
December 23, 2019
More Decks by chibiegg
See All by chibiegg
ブラックボックス観測に基づくAI支援のプロトコルのリバースエンジニアリングと再現~AIを用いたリバースエンジニアリング~ @ SECCON 14 電脳会議 / Reverse Engineering and Reproduction of an AI-Assisted Protocol Based on Black-Box Observation @ SECCON 14 DENNO-KAIGI
chibiegg
0
190
ゼロトラストを前提に、もっと便利に、もっと安全に @ 2026-03-03 ITmedia Security Week 2026 冬 / Designing for Zero Trust: Enabling Both Usability and Security
chibiegg
0
88
JANOG57 Meeting in Osaka のご紹介 @さくらの聖夜 2025 / Introduction to JANOG57 Meeting in Osaka
chibiegg
0
56
コンフィデンシャルコンピューティングは本当に機密なのか?@ 2025-08-23 LOCAL Developer Day ’25 Security with 在札幌米国総領事館 / Confidential Computing Truly Confidential? @ 2025-08-23 LOCAL Developer Day ’25 Security with the U.S. Consulate General in Sapporo
chibiegg
0
44
パブリッククラウドにおける機密コンピューティング@さくらのTech Day 2024-11-12 / Confidential Computing in Public Cloud
chibiegg
0
440
tiupによるTiDBの構築 @ TiUG Meetup #3 Osaka / Building TiDB with TiUP
chibiegg
1
290
Stable Diffusionの使い方と追加学習によるLoRAの作成~GPUコンテナサービス “高火力 DOK” の活用~ @ 2024-06-29 OSC2024 Hokkaido / Stable Diffusion and Creating LoRA with Additional Training ~ with 'Koukaryoku DOK' ~
chibiegg
1
2.6k
長期間TiDBを使ってきた話 @ 私たちはなぜNewSQLを使うのかTiDB選定5社が語る選定理由と活用LT / Experiences with TiDB Over Time
chibiegg
3
1.9k
3年近くTiDBを使ってきた話 @ TiUG Kick Off #0 / My Journey with TiDB: Nearly Three Years On @ TiDB User Group Kick Off #0
chibiegg
4
1.4k
Other Decks in Technology
See All in Technology
40代からのアウトプット ― 経験は価値ある学びに変わる / 20260404 Naoki Takahashi
shift_evolve
PRO
5
890
ADOTで始めるサーバレスアーキテクチャのオブザーバビリティ
alchemy1115
2
240
遊びで始めたNew Relic MCP、気づいたらChatOpsなオブザーバビリティボットができてました/From New Relic MCP to a ChatOps Observability Bot
aeonpeople
1
190
Oracle Cloud Infrastructure:2026年3月度サービス・アップデート
oracle4engineer
PRO
0
410
会社紹介資料 / Sansan Company Profile
sansan33
PRO
16
410k
すごいぞManaged Kubernetes
harukasakihara
1
350
AWSで2番目にリリースされたサービスについてお話しします(諸説あります)
yama3133
0
130
自己組織化を試される緑茶ハイを求めて、今日も全力であそんで学ぼう / Self-Organization and Shochu Green Tea
naitosatoshi
0
220
組織的なAI活用を阻む 最大のハードルは コンテキストデザインだった
ixbox
1
1k
OpenClaw初心者向けセミナー / OpenClaw Beginner Seminar
cmhiranofumio
0
350
Oracle AI Databaseデータベース・サービス: BaseDB/ExaDB-Dの可用性
oracle4engineer
PRO
1
140
マルチモーダル非構造データとの闘い
shibuiwilliam
1
190
Featured
See All Featured
Mind Mapping
helmedeiros
PRO
1
140
ピンチをチャンスに:未来をつくるプロダクトロードマップ #pmconf2020
aki_iinuma
128
55k
How to Get Subject Matter Experts Bought In and Actively Contributing to SEO & PR Initiatives.
livdayseo
0
95
Believing is Seeing
oripsolob
1
110
Agile that works and the tools we love
rasmusluckow
331
21k
A brief & incomplete history of UX Design for the World Wide Web: 1989–2019
jct
1
340
Paper Plane (Part 1)
katiecoart
PRO
0
6.4k
Future Trends and Review - Lecture 12 - Web Technologies (1019888BNR)
signer
PRO
0
3.4k
The Web Performance Landscape in 2024 [PerfNow 2024]
tammyeverts
12
1.1k
How to audit for AI Accessibility on your Front & Back End
davetheseo
0
240
The Spectacular Lies of Maps
axbom
PRO
1
680
Design and Strategy: How to Deal with People Who Don’t "Get" Design
morganepeng
133
19k
Transcript
さくらのクラウドと Docker Swarm Modeで 誰でもわかる簡単デプロイ 2019-12-23 @さくらの聖夜2019 ©SAKURA internet Inc.
さくらインターネット株式会社 執行役員 技術推進統括担当 兼 CISO 江草 陽太
⾃⼰紹介 2 【所属等】 さくらインターネット株式会社 新卒入社 執行役員 技術推進統括担当 兼 CISO 【開発】
• さくらのVPS API/DB/制御システム担当 • sakura.io ハードウエア仕様、ファームウエア開発 システム設計、開発、インフラ設計、構築 • 社内システム/データセンター自動化 • さくらのエンジニアリングラボ 【その他】 • CSAJ U22プログラミングコンテスト審査員 • Home NOC Operators’ Group (AS59105) @chibiegg
⾃⼰紹介 3 【経歴】 • ロボカップジュニア (中学・高校) / NHK大学ロボコン • 大阪大学工学部電子情報工学科情報通信工学専攻
• 個人事業主 • 大阪大学大学院工学研究科中退 • SECCON CTF 2014 国内4位 • ISUCON5/ISUSON7/ISUCON8本戦、ISUCON9問題作成 • ICTSC7 大人チーム 【専門】 • ソフトウエアエンジニア • NW/SC/DBスペシャリスト • 回路設計/組み込みソフトウエア 【趣味】 旅行/温泉/写真/電子工作/プログラミング/かわいい服 @chibiegg
よくあるアプリケーション 4 Nginx django Redis PostgreSQL
よく使うミドルウエア 5 • Nginx • リバースプロキシと静的ファイル配信 • Django • Webアプリケーション本体
• Redis/Memcached • グラフデータ等のキャッシュ • PostgreSQL/MariaDB • データベース
古典的な⽅法でのデプロイ 6 • パッケージのインストール • posrgresql-10, python3-pip, redis, nginx •
ソースコードを持って来る • Pythonパッケージをインストールする • 各種設定ファイルを書く • データベースをセットアップする • サービス登録する
2019/12/23 ©SAKURA internet Inc. 7 開発にDocker Composeを使う
開発にDocker Composeを使う 8 • 開発環境は⼿元のmacOSなど • いろんな開発を並⾏して⾏うため、環境構築が⼤変 • データベース、Redis、Pythonのバージョン、etc… •
Docker Composeを使うことで簡単に • コンテナを使うため独⽴した環境が⽤意できる • 他の環境に影響しない、壊さない • 初めて実⾏する⼈もコマンド2つ • `docker-compose build` `docker-compose up` のみ • docker-compose.ymlに全て書いてある • 削除も⼀⾏ `docker-compose rm`
開発にDocker Composeを使う 9 • git clone
[email protected]
:isucon/isucon9- portal.git • cd
isucon9-portal • docker-compose build • docker-compose up • http://localhost:8000/ を開く
2019/12/23 ©SAKURA internet Inc. 10 Docker Composeでのデプロイ 〜1台だけで動かす〜
Docker Composeでのデプロイ 11 Docker ComposeとSystemdを使う • パッケージのインストール • docker, docker-compose
• ソースコードを持って来る • docker-compose.yml が含まれている • Systemdにサービス登録する
1台によるDocker Composeでの課題 12 • ソースコード更新の時に、ダウンタイムが発⽣する • イメージビルドや起動にかかる時間による ↓ ローリングアップデート あるいは
ブルー・グリーンデプロイが欲しい
2019/12/23 ©SAKURA internet Inc. 13 Docker Swarm Modeでのデプロイ 〜複数台で動かす〜
Docker Swarm Mode 14 サーバ OS Docker Engine App App
一台でのDocker Compose サーバ サーバ サーバ OS OS OS Docker Engine Docker Engine Docker Engine App App App App App App Docker Cluster 管理レイヤ Docker Swarm Mode オーケストレーション サービス検出・クラスタ管理 Dockerのコンテナ管理
Docker Swarm Modeでのデプロイ 15 • Docker Swarmのインストール • ⼿作業でも簡単 •
Ansibleで⾃動化も簡単 • ソースコードを持って来る • docker stack deploy コマンドで設定を反映 • イメージのバージョンを変えると ローリングアップデートされる!
注意点 16 • 永続化データがあるアプリケーションはコンテナ で実⾏しない • データベースはDocker外で起動する • NFSなどを利⽤する⽅法もある
Docker Swarm ⾃体の使い⽅は… 17 https://www.slideshare.net/zembutsu/introduction-to-docker-swarm
さくらのクラウドで実環境でも使える構成を紹介 18 エンハンスドLB Nginx Swarm Worker Swarm Manager DBアプライアンス スイッチ
192.168.0.0/24 https://www.example.com/ ポート番号毎にアプリケーションをデプロイし、Nginxでリバースプロキシするといい感じ SSLはLet’s Encryptで自動更新! HTTP/2にも対応!
さくらのクラウドで実環境でも使える構成を紹介 19 エンハンスドLB Swarm Worker Swarm Manager DBアプライアンス スイッチ 192.168.0.0/24
https://www.example.com/ ポート番号毎にアプリケーションをデプロイし、ELBのルール機能でリバースプロキシ ルールベースロードバランスに対応!
2019/12/23 ©SAKURA internet Inc. 20 One more thing ...
2019/12/23 ©SAKURA internet Inc. 21 たしかに!
2019/12/23 ©SAKURA internet Inc. 22 さくらのエンジニアリングラボ
2019/12/23 ©SAKURA internet Inc. 23 どんどん新しいサービスをプロトタイピングし 早期のタイミングでお客様にも直接使っていただく
2019/12/23 ©SAKURA internet Inc. 24 わたしも作るか…
2019/12/23 ©SAKURA internet Inc. 25 金曜日
2019/12/23 ©SAKURA internet Inc. 27 土曜日
2019/12/23 ©SAKURA internet Inc. 28 日曜日
2019/12/23 ©SAKURA internet Inc. 29 火曜日
2019/12/23 ©SAKURA internet Inc. 30 先週
2019/12/23 ©SAKURA internet Inc. 31 先週水曜日
2019/12/23 ©SAKURA internet Inc. 32 今日
2019/12/23 ©SAKURA internet Inc. 33 ということは
2019/12/23 ©SAKURA internet Inc. 34 今⽇からさくらのクラウドでご利⽤いただけます
2019/12/23 ©SAKURA internet Inc. 35 今⽇からさくらのクラウドでご利⽤いただけます
2019/12/23 ©SAKURA internet Inc. 36 今⽇のAdvent Calendarで仕組みを紹介しています Private Docker Container
Registryサービスを作った話 https://qiita.com/chibiegg/private/746e0825c602f947ab1c