コンテンツにスキップ

Daytona

class Daytona()

Daytona API と対話するためのメインクラス。

このクラスは、Daytona サンドボックスの作成・管理・操作のためのメソッドを提供します。 明示的な設定または環境変数を用いて初期化できます。

属性:

  • volume VolumeService - ボリュームを管理するサービス。
  • snapshot SnapshotService - スナップショットを管理するサービス。

:

環境変数を使用する場合:

daytona = Daytona() # Uses DAYTONA_API_KEY, DAYTONA_API_URL
sandbox = daytona.create()

明示的な設定を使用する場合:

config = DaytonaConfig(
api_key="your-api-key",
api_url="https://your-api.com",
target="us"
)
daytona = Daytona(config)
sandbox = daytona.create()

Daytona.__init__

def __init__(config: Optional[DaytonaConfig] = None)

任意の設定で Daytona インスタンスを初期化します。

設定が提供されない場合、環境変数から読み込みます:

  • DAYTONA_API_KEY: 認証に必要な API キー
  • DAYTONA_API_URL: 必須の API URL
  • DAYTONA_TARGET: 任意のターゲット環境(既定は ‘us’)

引数:

  • config Optional[DaytonaConfig] - api_key、api_url、target を含むオブジェクト。

送出:

  • DaytonaError - 設定または環境変数のいずれからも API キーが提供されていない場合

:

from daytona import Daytona, DaytonaConfig
# Using environment variables
daytona1 = Daytona()
# Using explicit configuration
config = DaytonaConfig(
api_key="your-api-key",
api_url="https://your-api.com",
target="us"
)
daytona2 = Daytona(config)

Daytona.create

@overload
def create(params: Optional[CreateSandboxFromSnapshotParams] = None,
*,
timeout: Optional[float] = 60) -> Sandbox

指定された、または既定のスナップショットからサンドボックスを作成します。言語、イメージ、環境変数、ボリュームなど、さまざまなパラメータを指定できます。

引数:

  • params Optional[CreateSandboxFromSnapshotParams] - サンドボックス作成のためのパラメータ。未指定の場合は、 既定の Daytona スナップショットと Python 言語が使用されます。
  • timeout Optional[float] - サンドボックス作成のタイムアウト(秒)。0 はタイムアウトなしを意味します。 既定は 60 秒。

返り値:

  • Sandbox - 作成されたサンドボックスインスタンス。

送出:

  • DaytonaError - timeout、auto_stop_interval、または auto_archive_interval が負の場合、 あるいはサンドボックスの起動に失敗した、またはタイムアウトした場合

:

既定の Python サンドボックスを作成:

sandbox = daytona.create()

カスタムサンドボックスを作成:

params = CreateSandboxFromSnapshotParams(
language="python",
snapshot="my-snapshot-id",
env_vars={"DEBUG": "true"},
auto_stop_interval=0,
auto_archive_interval=60,
auto_delete_interval=120
)
sandbox = daytona.create(params, timeout=40)

Daytona.create

@overload
def create(params: Optional[CreateSandboxFromImageParams] = None,
*,
timeout: Optional[float] = 60,
on_snapshot_create_logs: Callable[[str], None] = None) -> Sandbox

レジストリで利用可能な指定イメージ、または宣言的な Daytona イメージからサンドボックスを作成します。 リソース、言語、イメージ、環境変数、ボリュームなど、さまざまなパラメータを指定できます。Daytona は提供されたイメージからスナップショットを作成し、それを用いてサンドボックスを作成します。

引数:

  • params Optional[CreateSandboxFromImageParams] - イメージからサンドボックスを作成するためのパラメータ。
  • timeout Optional[float] - サンドボックス作成のタイムアウト(秒)。0 はタイムアウトなしを意味します。 既定は 60 秒。
  • on_snapshot_create_logs Callable[[str], None] - スナップショット作成ログを処理するコールバック関数。

返り値:

  • Sandbox - 作成されたサンドボックスインスタンス。

送出:

  • DaytonaError - timeout、auto_stop_interval、または auto_archive_interval が負の場合、 あるいはサンドボックスの起動に失敗した、またはタイムアウトした場合

:

イメージから既定の Python サンドボックスを作成:

sandbox = daytona.create(CreateSandboxFromImageParams(image="debian:12.9"))

宣言的なイメージ定義からカスタムサンドボックスを作成:

declarative_image = (
Image.base("alpine:3.18")
.pipInstall(["numpy", "pandas"])
.env({"MY_ENV_VAR": "My Environment Variable"})
)
params = CreateSandboxFromImageParams(
language="python",
image=declarative_image,
env_vars={"DEBUG": "true"},
resources=Resources(cpu=2, memory=4),
auto_stop_interval=0,
auto_archive_interval=60,
auto_delete_interval=120
)
sandbox = daytona.create(
params,
timeout=40,
on_snapshot_create_logs=lambda chunk: print(chunk, end=""),
)

Daytona.delete

def delete(sandbox: Sandbox, timeout: Optional[float] = 60) -> None

サンドボックスを削除します。

引数:

  • sandbox Sandbox - 削除するサンドボックスインスタンス。
  • timeout Optional[float] - サンドボックス削除のタイムアウト(秒)。0 はタイムアウトなしを意味します。 既定は 60 秒です。

送出:

  • DaytonaError - サンドボックスの削除に失敗した場合、またはタイムアウトした場合

:

sandbox = daytona.create()
# ... サンドボックスを利用 ...
daytona.delete(sandbox) # 終了時にクリーンアップ

Daytona.get

@intercept_errors(message_prefix="Failed to get sandbox: ")
def get(sandbox_id: str) -> Sandbox

ID でサンドボックスを取得します。

引数:

  • sandbox_id str - 取得するサンドボックスの ID。

戻り値:

  • Sandbox - サンドボックスインスタンス。

送出:

  • DaytonaError - sandbox_id が指定されていない場合。

:

sandbox = daytona.get("my-sandbox-id")
print(sandbox.status)

Daytona.find_one

@intercept_errors(message_prefix="Failed to find sandbox: ")
def find_one(sandbox_id: Optional[str] = None,
labels: Optional[Dict[str, str]] = None) -> Sandbox

ID またはラベルでサンドボックスを検索します。

引数:

  • sandbox_id Optional[str] - 取得するサンドボックスの ID。
  • labels Optional[Dict[str, str]] - サンドボックスをフィルタリングするためのラベル。

戻り値:

  • Sandbox - ID またはラベルに一致する最初のサンドボックス。

送出:

  • DaytonaError - サンドボックスが見つからない場合。

:

sandbox = daytona.find_one(labels={"my-label": "my-value"})
print(f"Sandbox ID: {sandbox.id} State: {sandbox.state}")

Daytona.list

@intercept_errors(message_prefix="Failed to list sandboxes: ")
def list(labels: Optional[Dict[str, str]] = None) -> List[Sandbox]

ラベルでフィルタリングされたサンドボックスを一覧表示します。

引数:

  • labels Optional[Dict[str, str]] - サンドボックスをフィルタリングするためのラベル。

戻り値:

  • List[Sandbox] - ラベルに一致するサンドボックスインスタンスのリスト。

:

sandboxes = daytona.list(labels={"my-label": "my-value"})
for sandbox in sandboxes:
print(f"{sandbox.id}: {sandbox.status}")

Daytona.start

def start(sandbox: Sandbox, timeout: Optional[float] = 60) -> None

サンドボックスを起動し、準備完了まで待機します。

引数:

  • sandbox Sandbox - 起動するサンドボックス。
  • timeout Optional[float] - サンドボックスの起動完了を待つ任意のタイムアウト(秒)。 0 はタイムアウトなしを意味します。既定は 60 秒です。

送出:

  • DaytonaError - タイムアウトが負の場合、またはサンドボックスの起動に失敗/タイムアウトした場合

Daytona.stop

def stop(sandbox: Sandbox, timeout: Optional[float] = 60) -> None

サンドボックスを停止し、停止完了まで待機します。

引数:

  • sandbox Sandbox - 停止するサンドボックス。
  • timeout Optional[float] - サンドボックス停止の任意のタイムアウト(秒)。 0 はタイムアウトなしを意味します。既定は 60 秒です。

送出:

  • DaytonaError - タイムアウトが負の場合、またはサンドボックスの停止に失敗/タイムアウトした場合

CodeLanguage

@dataclass
class CodeLanguage(Enum)

Daytona がサポートするプログラミング言語

列挙型メンバー:

  • PYTHON (“python”)
  • TYPESCRIPT (“typescript”)
  • JAVASCRIPT (“javascript”)

DaytonaConfig

class DaytonaConfig(BaseModel)

Daytona クライアントを初期化するための設定オプション。

属性:

  • api_key Optional[str] - Daytona API で認証するための APIキー。未設定の場合は、環境変数 DAYTONA_API_KEY で指定するか、代わりに JWT トークンを指定する必要があります。
  • jwt_token Optional[str] - Daytona API で認証するための JWT トークン。未設定の場合は、環境変数 DAYTONA_JWT_TOKEN で指定するか、代わりに APIキーを指定する必要があります。
  • organization_id Optional[str] - JWT ベース認証で使用される 組織 ID。JWT トークンが指定された場合に必須で、ここで指定するか、環境変数 DAYTONA_ORGANIZATION_ID に設定する必要があります。
  • api_url Optional[str] - Daytona API の URL。未設定の場合は 'https://app.daytona.io/api' がデフォルトとなり、ここまたは環境変数 DAYTONA_API_URL で設定できます。
  • server_url Optional[str] - 非推奨です。代わりに api_url を使用してください。このプロパティは将来のバージョンで削除されます。
  • target Optional[str] - サンドボックスのターゲット(リージョン)/ランナーの場所。未設定の場合のデフォルトは 'us' で、ここまたは環境変数 DAYTONA_TARGET で設定できます。

:

config = DaytonaConfig(api_key="your-api-key")
config = DaytonaConfig(jwt_token="your-jwt-token", organization_id="your-organization-id")

CreateSandboxBaseParams

class CreateSandboxBaseParams(BaseModel)

新しいサンドボックスを作成するための基本パラメーター。

属性:

  • language Optional[CodeLanguage] - サンドボックスのプログラミング言語。デフォルトは「python」。
  • os_user Optional[str] - サンドボックスのOSユーザー。
  • env_vars Optional[Dict[str, str]] - サンドボックスに設定する環境変数。
  • labels Optional[Dict[str, str]] - サンドボックスのカスタムラベル。
  • public Optional[bool] - サンドボックスを公開にするかどうか。
  • timeout Optional[float] - サンドボックスの作成および起動のタイムアウト(秒)。
  • auto_stop_interval Optional[int] - 指定した時間内にサンドボックスイベントが発生しなかった場合に自動停止するまでの間隔(分)。デフォルトは15分。 0は自動停止なしを意味します。
  • auto_archive_interval Optional[int] - 連続して停止しているサンドボックスが自動的にアーカイブされるまでの間隔(分)。デフォルトは7日。 0は最大の間隔が使用されることを意味します。
  • auto_delete_interval Optional[int] - 連続して停止しているサンドボックスが自動的に削除されるまでの間隔(分)。デフォルトでは自動削除は無効です。 負の値は無効、0は停止直後に即時削除を意味します。
  • volumes Optional[List[VolumeMount]] - サンドボックスにアタッチするボリュームのマウント一覧。
  • network_block_all Optional[bool] - サンドボックスのすべてのネットワークアクセスをブロックするかどうか。
  • network_allow_list Optional[str] - サンドボックスで許可するCIDRネットワークアドレスのカンマ区切りリスト。

CreateSandboxFromImageParams

class CreateSandboxFromImageParams(CreateSandboxBaseParams)

イメージから新しいサンドボックスを作成するためのパラメータ。

属性:

  • image Union[str, Image] - サンドボックスに使用するカスタム Docker イメージ。Image オブジェクトが指定された場合は、 イメージが動的にビルドされます。
  • resources Optional[Resources] - サンドボックスのリソース構成。指定しない場合は、サンドボックスに 既定のリソースが割り当てられます。

CreateSandboxFromSnapshotParams

class CreateSandboxFromSnapshotParams(CreateSandboxBaseParams)

スナップショットから新しいサンドボックスを作成するためのパラメータ。

属性:

  • snapshot Optional[str] - サンドボックスに使用するスナップショット名。