本番デプロイ設定: SSL, Kamal, API環境変数化, テスト修正

This commit is contained in:
2026-02-21 23:45:12 +09:00
parent e90ea88758
commit 9626db3dcf
21 changed files with 226 additions and 78 deletions

37
script/deploy_dip_api.sh Normal file
View File

@@ -0,0 +1,37 @@
#!/bin/bash
# ==================================================
# dip_api (FastAPI) のビルド・起動スクリプト
# VPS上で実行
# ==================================================
set -e
# dip_api のソースコードがある場所VPSにコピー後
DIP_API_DIR="${1:-/home/kontei/dip_api}"
echo "=== dip_api Docker イメージのビルド ==="
cd "$DIP_API_DIR"
docker build -t dip-api:latest .
echo ""
echo "=== 既存コンテナの停止・削除(ある場合) ==="
docker stop dip-api 2>/dev/null || true
docker rm dip-api 2>/dev/null || true
echo ""
echo "=== dip_api コンテナの起動 ==="
docker run -d \
--name dip-api \
--restart always \
-p 8000:8000 \
dip-api:latest
echo ""
echo "=== ヘルスチェック ==="
sleep 3
if curl -s http://localhost:8000/debug/heartbeat > /dev/null 2>&1; then
echo "✅ dip_api は正常に起動しています"
else
echo "⚠️ dip_api の起動を確認中... (数秒待ってから再確認してください)"
echo " docker logs dip-api で確認"
fi

54
script/setup_vps.sh Normal file
View File

@@ -0,0 +1,54 @@
#!/bin/bash
# ==================================================
# さくらVPS 初期セットアップスクリプト
# 対象: Ubuntu 24.04 LTS
# 実行: ssh kontei@153.127.48.108 でログイン後に実行
# ==================================================
set -e
echo "=== 1. Docker のインストール ==="
# Docker の公式リポジトリを追加
sudo apt-get update
sudo apt-get install -y ca-certificates curl
sudo install -m 0755 -d /etc/apt/keyrings
sudo curl -fsSL https://download.docker.com/linux/ubuntu/gpg -o /etc/apt/keyrings/docker.asc
sudo chmod a+r /etc/apt/keyrings/docker.asc
echo \
"deb [arch=$(dpkg --print-architecture) signed-by=/etc/apt/keyrings/docker.asc] https://download.docker.com/linux/ubuntu \
$(. /etc/os-release && echo "${VERSION_CODENAME}") stable" | \
sudo tee /etc/apt/sources.list.d/docker.list > /dev/null
sudo apt-get update
sudo apt-get install -y docker-ce docker-ce-cli containerd.io docker-buildx-plugin docker-compose-plugin
# kontei ユーザーを docker グループに追加sudo なしで docker を使えるようにする)
sudo usermod -aG docker kontei
echo "※ docker グループの反映には再ログインが必要です"
echo ""
echo "=== 2. Docker レジストリの起動 ==="
# Kamal がイメージをプッシュするためのローカルレジストリ
sudo docker run -d \
-p 5555:5000 \
--restart always \
--name registry \
registry:2
echo ""
echo "=== 3. ファイアウォール設定 ==="
# HTTP/HTTPS ポートを開放
sudo ufw allow 80/tcp
sudo ufw allow 443/tcp
# Docker レジストリ(ローカルのみ)
sudo ufw allow from 127.0.0.1 to any port 5555
echo "※ UFW が有効でない場合は 'sudo ufw enable' で有効化してください"
echo ""
echo "=== セットアップ完了 ==="
echo "次のステップ:"
echo " 1. 再ログインして docker グループを反映"
echo " 2. 'docker ps' で registry コンテナが起動していることを確認"
echo " 3. DNS で diplo.kontei.net → 153.127.48.108 の A レコードを設定"
echo " 4. ローカルPCから 'bin/kamal setup' を実行"