コンテンツにスキップ
公式サイト →

keelson.yaml

TODO(内部向け・リリース前に対応して削除)

Section titled “TODO(内部向け・リリース前に対応して削除)”

keelson.yaml は、プロジェクトルートに配置するデプロイ設定ファイルです。アプリのランタイム、起動コマンド、環境変数、データベース、定期実行ジョブなどを定義します。

デプロイ時に Keelson はこのファイルを読み取り、その内容に基づいてビルドと実行環境を決定します。

slug: my-app
runtime: python-slim
command: "python app.py"
env:
PORT: "8080"

フィールド必須デフォルト説明
slugstringはいアプリの識別子(URLの一部になります)
typestringnullアプリ種別。"web" のみ指定可。指定時は cronsworkers 不可
runtimestringはい実行環境。対応ランタイムを参照
commandstring | list条件付き起動時に実行するコマンド。crons がない場合は必須
envmap{}環境変数
databaseslist[]SQLite データベースの設定
cronslist条件付き[]定期実行ジョブ。command がない場合は必須
workerslist[]バックグラウンドワーカー
storageobject{}永続ストレージの設定
assetsobjectnull静的アセット配信の設定

アプリの識別子です。公開URLの一部として使われます(例: my-app.keelson.run)。

slug: my-app

ルール:

  • 使用できる文字: 小文字英数字とハイフン(a-z, 0-9, -
  • 長さ: 1〜63文字
  • --(連続ハイフン)は使用不可
  • 予約語: api, console, www, admin(これが現時点での完全な一覧です)

アプリ種別を指定します。省略可能です。

type: web

指定できる値は "web" のみです。type: web を指定すると、静的アセット配信(assets)が有効になり、command なしでのデプロイが可能になります。

制約:

  • type: web を指定した場合、crons および workers は使用できません

アプリの実行環境を指定します。静的サイトのみのデプロイでも必須です。

ランタイム言語用途
python-slimPython軽量。テキスト処理、API など
python-mediaPythonメディア処理向け(画像・動画ライブラリ含む)
node-slimNode.js軽量
node-mediaNode.jsメディア処理向け
go-slimGo軽量
go-mediaGoメディア処理向け

迷った場合は -slim から始めてください。メディア処理系のライブラリが必要になった場合に -media へ切り替えます。


起動時に実行するコマンドです。依存パッケージのインストールなどの準備処理を含めることもできます。文字列またはリスト形式で指定できます。

# 文字列形式(シェル経由で実行)
command: "python -m pip install -r requirements.txt && python app.py"
# リスト形式(exec 形式で実行)
command:
- python
- app.py

ルール:

  • commandcrons のどちらかは必須です(両方指定も可)
  • type: webassets のみのデプロイでは省略可

環境変数をキーと値のペアで定義します。値はすべて文字列として扱われます。

YAML の自動型変換を避けるため、値はすべて引用符で囲むことを推奨します。

env:
PORT: "8080"
NODE_ENV: "production"
DEBUG: "false"
DB_PATH: "/data/main.db"

SQLite データベースの設定です。databases で宣言したファイルは、storage で定義された永続ストレージ上に配置されます。storage を省略した場合、データは永続化されず Pod の再起動時に失われます。データを保持したい場合は storage も合わせて設定してください。

databases:
- name: main
type: sqlite
path: /data/main.db
フィールド必須デフォルト説明
namestringdb-{index}データベースの識別名
typestringはいsqlite のみ対応
pathstringはいファイルのマウントパス

ルール:

  • path/data/ で始まる必要があります
  • namepath はそれぞれ重複不可

定期実行ジョブを定義します。Keelson 内部では Kubernetes CronJob として実行されます。

crons:
- name: cleanup
schedule: "0 3 * * *"
command: "python cleanup.py"
timeout: 60
フィールド必須デフォルト説明
namestringはいジョブ名。小文字英数字とハイフン、1〜63文字
schedulestringはいcron 式(5フィールド形式)
commandstring | listはい実行コマンド
timeoutint300タイムアウト(秒)。1〜3600

ルール:

  • 最大 10 個まで定義可能
  • name の重複不可
  • type: web との併用不可
意味
* * * * *毎分
0 * * * *毎時 0 分
0 3 * * *毎日 3:00
0 0 * * 1毎週月曜 0:00

バックグラウンドワーカープロセスを定義します。Web アプリとは別のプロセスとして実行されます。

workers:
- name: processor
command: "python worker.py"
replicas: 1
フィールド必須デフォルト説明
namestringはいワーカー名。小文字英数字とハイフン、1〜63文字
commandstring | listはい実行コマンド
replicasint1レプリカ数。0 または 1
resourcesobjectnullリソース制約(下記参照)

replicas0 にすると、ワーカーの定義は保持されますが起動しません。一時的にワーカーを無効化したい場合に使用します。

ルール:

  • 現在のバージョンでは最大 1 つまで定義可能
  • トップレベルの command が設定されている場合のみ使用可
  • type: web との併用不可

ワーカーの CPU・メモリの制約を指定できます。

workers:
- name: processor
command: "python worker.py"
resources:
requests:
cpu: "200m"
memory: "256Mi"
limits:
cpu: "1"
memory: "512Mi"

requestslimits のいずれかに、cpu または memory を1つ以上指定してください。


永続ストレージの設定です。コンテナ内の /data にマウントされます。databases で定義する SQLite ファイルもこの領域を使用します。

storage を省略した場合、/data は一時領域となり、Pod の再起動時にデータが失われます。データを永続化するには storage を設定してください。

storage:
disk_id: my-disk
フィールド必須デフォルト説明
disk_idstringnullストレージ識別子。小文字英数字とハイフン、1〜32文字

静的アセット配信の設定です。静的サイトや SPA のデプロイ、バックエンド API とのハイブリッド構成に使用します。

assets:
dir: dist
fallback: index.html
api: /api
フィールド必須デフォルト説明
dirstringはいアセットディレクトリ(プロジェクトルートからの相対パス)
fallbackstringnullSPA 用フォールバックファイル(例: index.html
apistringnullバックエンド API のパスプレフィックス(例: /api

api を指定すると、そのパス配下のリクエストはバックエンドアプリへ転送され、それ以外は静的アセットとして配信されます。

ルール:

  • dir.. を含むパスは使用不可
  • api/ で始まる必要があります
  • api/__keelson 配下のパスは使用不可
  • api はトップレベルの command が設定されている場合のみ使用可
  • ハイブリッド構成(assets + command)では fallback が必須

commandassets の組み合わせにより、デプロイモードが自動的に決まります。

モードcommandassetsfallback説明
コンテナありなし通常のアプリデプロイ
静的サイトなしありなし静的ファイルのみ
SPAなしありありSPA(フォールバック付き)
ハイブリッドありあり必須静的ファイル + バックエンド API

設定の組み合わせには以下の制約があります。

ルール説明
command または crons が必須少なくとも一方を指定してください(type: web の静的サイトデプロイを除く)
type: web の排他制約crons および workers とは併用できません
workers には command が必要トップレベルの command がない場合、workers は使用できません
assets.api には command が必要API プレフィックスはバックエンドがある場合のみ指定できます
ハイブリッドには fallback が必要assetscommand を両方指定する場合、fallback は必須です

Web アプリ + SQLite(最も一般的)

Section titled “Web アプリ + SQLite(最も一般的)”
slug: flask-crud
runtime: python-slim
command: "python -m pip install --user -r requirements.txt && python app.py"
env:
PORT: "8080"
PYTHONUNBUFFERED: "1"
PYTHONUSERBASE: "/deps/.local"
DB_PATH: "/data/customers.db"
storage:
disk_id: flask-crud-data
databases:
- name: customers
type: sqlite
path: /data/customers.db
slug: marketing-site
type: web
runtime: node-slim
assets:
dir: dist
fallback: index.html

定期実行ジョブのみ(Web なし)

Section titled “定期実行ジョブのみ(Web なし)”
slug: cron-logger
runtime: python-slim
env:
PYTHONUNBUFFERED: "1"
crons:
- name: heartbeat
schedule: "* * * * *"
command: "python heartbeat.py"
timeout: 30

Web + バックグラウンドワーカー

Section titled “Web + バックグラウンドワーカー”
slug: task-worker
runtime: python-slim
command: "python -m pip install --user -r requirements.txt && python app.py"
env:
PORT: "8080"
PYTHONUNBUFFERED: "1"
PYTHONUSERBASE: "/deps/.local"
DB_PATH: "/data/tasks.db"
storage:
disk_id: task-worker-data
databases:
- name: tasks
type: sqlite
path: /data/tasks.db
workers:
- name: default
command: "python -m pip install --user -r requirements.txt && python worker.py"
replicas: 1

ハイブリッド(静的ファイル + バックエンド API)

Section titled “ハイブリッド(静的ファイル + バックエンド API)”
slug: photo-galleries
runtime: python-slim
command: "python -m pip install --user -r requirements.txt && python app.py"
env:
PORT: "8080"
PYTHONUNBUFFERED: "1"
PYTHONUSERBASE: "/deps/.local"
assets:
dir: static
fallback: index.html
api: /api
storage:
disk_id: photo-data
databases:
- name: main
type: sqlite
path: /data/main.db
slug: my-go-app
runtime: go-slim
# Keelson が deploy 時に Linux 向け binary を `./app` としてビルドします。
command: "./app"
env:
PORT: "8080"
slug: node-crud
runtime: node-slim
command: "npm install && npm start"
env:
PORT: "8080"
NODE_ENV: "production"
DB_PATH: "/data/notes.db"
storage:
disk_id: node-crud-data
databases:
- name: notes
type: sqlite
path: /data/notes.db

エラー原因説明
path/data/ で始まっていないdatabases.path/data/ 配下である必要があります
api/ で始まっていないassets.api/ で始まる必要があります
commandcrons もない少なくとも一方を指定してください(type: web の静的デプロイを除く)
workers があるのに command がないworkers はトップレベルの command が必要です
env の値が引用符で囲まれていないtrue/false/数値は YAML に型変換されます。すべて引用符で囲んでください
storage なしで databases を使っているデータは永続化されず Pod 再起動時に失われます