Ruby: CLIによる自動化
Stackhero CLIを使ってRubyを起動し、認証情報を取得し、構成をプログラムで変更する方法
👋 Stackheroのドキュメントへようこそ!
Stackheroは、数多くの利点を提供する、すぐに使えるRubyクラウドソリューションを提供しています。
- シンプルな
git pushでアプリケーションを数秒でデプロイ。- 独自のドメイン名を使用し、HTTPS証明書の自動設定による強化されたセキュリティを享受。
- 自動バックアップ、ワンクリック更新、そしてシンプルで透明性があり、予測可能な価格設定で安心を提供。
- プライベートで専用のVMによる最適なパフォーマンスと強固なセキュリティを実現。
時間を節約し、生活を簡素化:StackheroのRubyクラウドホスティングソリューションを試すのに5分しかかかりません!
このガイドでは、コマンドラインのみでRubyサービスを作成し、その認証情報を取得し、構成を更新する方法を解説します。ダッシュボードでクリック操作を行う必要はありません。スクリプト、CIパイプライン、AIエージェントでの利用に最適です。
すべての操作にはStackhero CLIを使用します。まだインストールしていない場合は、以下のコマンドでインストールできます。
curl -fsSL https://www.stackhero.io/install.sh | sh
1. 認証
最も簡単な開始方法は、ブラウザ経由でログインすることです。ログインコマンドを実行すると、CLIがWebページを開き、そこでアクセスを承認できます。CLI自体にパスワードや2要素認証コードを入力する必要はありません。
stackhero login
ログイン後、認証情報はローカルに保存され、以降のCLIコマンドで自動的に利用されます。
スクリプトやCIパイプラインなど完全自動化された環境では、非対話型のアクセストークンを利用するのが便利です。ダッシュボード(アカウント > Access tokens)からトークンを作成し、環境変数としてエクスポートしてください。CLIや実行するスクリプトは自動的にこのトークンを認識します。
export STACKHERO_TOKEN="usr-xxxxxx:your-token"
2. Rubyサービスストアの検索
次に、アカウントで利用可能なRubyサービスストアを一覧表示します。CLIはストアの名前(ruby)を直接受け付けるため、IDを調べたりコピーしたりする必要はありません。
# Rubyサービスストアを一覧表示(複数組織を管理している場合は--organizationを追加)
stackhero services-store-list --name="ruby"
以降のコマンドではストア名rubyを参照できます。また、必要に応じてリストから特定のsvs-xxxxxx IDを選択することも可能です。
3. インスタンスサイズとリージョンの選択
# サービスストアのインスタンスサイズを一覧表示(--instanceにはNAME列を使用)
stackhero instances-store-list --service-store=ruby
# 利用可能なリージョンを一覧表示(例: "europe"など)
stackhero regions-list
4. サービスの作成
以下は、スタックを作成し、Rubyサービスを追加し、起動を待ち、構成(生成された認証情報を含む)を取得し、新しい構成を適用するサンプルスクリプトです。
#!/bin/bash
set -e
export STACKHERO_TOKEN="usr-xxxxxx:your-token"
serviceStore="ruby" # Rubyサービスストア名(ステップ2参照)
instance="..." # ステップ3で選択したインスタンスサイズ
region="europe" # ステップ3で選択したリージョン名
# サービス用のスタックを作成(デフォルト組織を使用。必要に応じて--organizationを追加)
stackId=$(stackhero --format=script stack-create \
--name="My Ruby stack")
echo "Stack created: ${stackId}"
# スタックにRubyを追加(名前は自動解決されます)
serviceId=$(stackhero --format=script service-add \
--stack="My Ruby stack" \
--service-store="${serviceStore}" \
--instance="${instance}" \
--region="${region}")
echo "Service added: ruby"
# サービスが完全に起動するまで待機(数分かかる場合があります)
stackhero service-wait-for --service="ruby"
# サービスの構成を取得(生成された認証情報を含む)
stackhero service-configuration-get --service="ruby" --format=json
5. 認証情報の取得
service-configuration-getコマンドは、サービスの完全な構成(自動生成されたパスワードや接続情報を含む)を返します。出力はJSON形式なので、スクリプトや自動化で簡単に利用できます。
stackhero service-configuration-get --service=svc-xxxxxx --format=json
6. 構成の変更
構成スキーマの例を確認し、ご自身の設定を適用できます。構成を更新すると、必要に応じてサービスが再起動されます。
# サービスの構成スキーマと例を表示
stackhero service-configuration-example --service=svc-xxxxxx
# カスタム構成を適用(必要に応じてサービスが再起動)
stackhero service-configuration-set \
--service=svc-xxxxxx \
--configuration='{ "...": "..." }'
# 新しい構成が適用されるまで待機
stackhero service-wait-for --service=svc-xxxxxx
以上です。これで、サービスの起動、認証情報の取得、再構成まで、すべてスクリプトや自動化で完結できる一連の流れをご確認いただけました。さらに詳しく知りたい場合は、CLIの詳細ドキュメントもご参照ください。ここで紹介した非対話型STACKHERO_TOKEN認証についても解説しています。