Usacloud導入ガイド
インストール
macOS/Linux
curl -fsSL https://github.com/sacloud/usacloud/releases/latest/download/install.sh | bash
Windows(chocolatey
)
choco install usacloud
chocolateyのusacloudパッケージは @223n さんによってメンテナンスされています。
その他の場合
GitHub Releasesページから任意のプラットフォーム向けのファイルをダウンロードして展開し、任意のフォルダー内に配置してください。
(PATHを通しておくと便利です)
https://github.com/sacloud/usacloud/releases/latest/
Dockerを利用する場合
usacloud
実行用イメージとしてghcr.io/sacloud/usacloud
を公開しています。
# Dockerでのusacloud実行例
docker run -it --rm \
-e SAKURACLOUD_ACCESS_TOKEN \
-e SAKURACLOUD_ACCESS_TOKEN_SECRET \
-e SAKURACLOUD_ZONE \
ghcr.io/sacloud/usacloud server ls
Warning
v0との互換性維持のためにDockerHubでsacloud/usacloud
イメージを配布していますが将来的に廃止予定です。
ghcr.io/sacloud/usacloud
の利用を推奨します。
シェル補完(Shell Completion)
bash_completion
などのシェル補完が利用できる場合は、以下のコマンドで有効に出来ます。
Bash
# Linuxの場合
$ usacloud completion bash > /etc/bash_completion.d/usacloud
# MacOSの場合
$ usacloud completion bash > /usr/local/etc/bash_completion.d/usacloud
Zsh
$ usacloud completion zsh > "${fpath[1]}/_usacloud"
Fish:
$ usacloud completion fish > ~/.config/fish/completions/usacloud.fish
詳細はcompletionコマンドを参照してください。
設定
usacloud
の実行にはさくらのクラウドのAPIキーの取得/設定が必要です。
以下のドキュメントに従いAPIキーを作成してください。
さくらのクラウド ドキュメント: APIキーの新規作成・編集
APIキーの設定
APIキーを取得したら、usacloud config
を実行しAPIキーを設定します。
画面の指示に従い、アクセストークン(token)とシークレット(secret)、操作対象のゾーン、デフォルトの出力形式を入力します。
$ usacloud config
Setting SakuraCloud API Token =>
Enter token: [アクセストークンを入力]
Setting SakuraCloud API Secret =>
Enter secret: [アクセスシークレットを入力]
Setting SakuraCloud Zone =>
Enter zone[is1a/is1b/tk1a/tk1b/tk1v]: [ゾーンを入力]
Setting Default Output Type =>
Enter default-output-type[table/json/yaml]: [デフォルトの出力形式を入力]
Written your settings to ~/.usacloud/default/config.json
操作対象のゾーンは以下のいずれかを入力してください。
is1a
: 石狩第1ゾーンis1b
: 石狩第2ゾーンtk1a
: 東京第1ゾーンtk1b
: 東京第2ゾーンtk1v
: サンドボックス
Note
グローバルオプション--zones
やプロファイルでZones
を設定している場合は設定可能なゾーンが上記と異なる場合があります。
詳細はリファレンス / プロファイルを参照してください。
Warning
usacloud config
コマンドで入力した内容は平文でJSONファイルとして保存されます。
デフォルトでは~/.usacloud/<ファイル名>/config.json
にパーミッション0700
で保存されます。
取り扱いは十分に注意してください。
Tip
usacloud config
では基本的な項目の設定のみが行えます。
より詳細な設定をしたい場合は生成されたJSONファイルを直接編集する必要があります。
JSONファイルに記載できる内容の詳細についてはリファレンス / プロファイルを参照してください。
その他のAPIキー設定方法
環境変数での指定
APIキーは環境変数での指定にも対応しています。
$ export SAKURACLOUD_ACCESS_TOKEN=アクセストークン
$ export SAKURACLOUD_ACCESS_TOKEN_SECRET=アクセスシークレット
$ export SAKURACLOUD_ZONE=ゾーン
コマンドラインオプションでの指定
コマンド実行時にコマンドラインオプションで指定することが出来ます。
$ usacloud --token=アクセストークン --secret=アクセスシークレット --zone=ゾーン server ls
Warning
コマンドラインオプション--token
/--secret
を利用した場合、ヒストリーに値が残ってしまう場合があります。
取り扱いは十分に注意してください。
複数箇所で指定した場合の優先順位
複数の箇所で指定されていた場合、以下の順で読み込みます(後から読み込んだものが優先)。
- 環境変数での指定
- プロファイル(
usacloud config
で保存されるもの)での指定 - コマンドラインオプションでの指定
以上で設定終了です。続いて基本的な使い方に進んでください。