Meilisearch: CLIによる自動化

Stackhero CLIを使ってMeilisearchを起動し、認証情報を取得し、構成をプログラムで変更する方法

Stackhero ドキュメントへようこそ!

強力で使いやすい検索エンジンをお探しの場合は、Stackhero の Meilisearch cloud サービスがおすすめです。主な特長は以下の通りです:

  • カスタマイズ可能なドメイン名と、標準搭載の HTTPS セキュリティ。
  • ワンクリックで簡単にアップデートが可能、手間がかかりません。
  • プライベートかつ専用の VM による高い パフォーマンス と強固な セキュリティ

すぐに始めたい方は、Stackhero の Meilisearch cloud hosting ソリューションを使えば、わずか 5 分でセットアップできます。時間を節約し、できるだけシンプルに導入できるよう設計されています!

このガイドでは、コマンドラインのみでMeilisearchサービスを作成し、その認証情報を取得し、構成を更新する方法を解説します。ダッシュボードでクリック操作を行う必要はありません。スクリプト、CIパイプライン、AIエージェントでの利用に最適です。

すべての操作にはStackhero CLIを使用します。まだインストールしていない場合は、以下のコマンドでインストールできます。

curl -fsSL https://www.stackhero.io/install.sh | sh

最も簡単な開始方法は、ブラウザ経由でログインすることです。ログインコマンドを実行すると、CLIがWebページを開き、そこでアクセスを承認できます。CLI自体にパスワードや2要素認証コードを入力する必要はありません。

stackhero login

ログイン後、認証情報はローカルに保存され、以降のCLIコマンドで自動的に利用されます。

スクリプトやCIパイプラインなど完全自動化された環境では、非対話型のアクセストークンを利用するのが便利です。ダッシュボード(アカウント > Access tokens)からトークンを作成し、環境変数としてエクスポートしてください。CLIや実行するスクリプトは自動的にこのトークンを認識します。

export STACKHERO_TOKEN="usr-xxxxxx:your-token"

次に、アカウントで利用可能なMeilisearchサービスストアを一覧表示します。CLIはストアの名前meilisearch)を直接受け付けるため、IDを調べたりコピーしたりする必要はありません。

# Meilisearchサービスストアを一覧表示(複数組織を管理している場合は--organizationを追加)
stackhero services-store-list --name="meilisearch"

以降のコマンドではストア名meilisearchを参照できます。また、必要に応じてリストから特定のsvs-xxxxxx IDを選択することも可能です。

# サービスストアのインスタンスサイズを一覧表示(--instanceにはNAME列を使用)
stackhero instances-store-list --service-store=meilisearch

# 利用可能なリージョンを一覧表示(例: "europe"など)
stackhero regions-list

以下は、スタックを作成し、Meilisearchサービスを追加し、起動を待ち、構成(生成された認証情報を含む)を取得し、新しい構成を適用するサンプルスクリプトです。

#!/bin/bash
set -e

export STACKHERO_TOKEN="usr-xxxxxx:your-token"

serviceStore="meilisearch"   # Meilisearchサービスストア名(ステップ2参照)
instance="..."                # ステップ3で選択したインスタンスサイズ
region="europe"               # ステップ3で選択したリージョン名

# サービス用のスタックを作成(デフォルト組織を使用。必要に応じて--organizationを追加)
stackId=$(stackhero --format=script stack-create \
  --name="My Meilisearch stack")
echo "Stack created: ${stackId}"

# スタックにMeilisearchを追加(名前は自動解決されます)
serviceId=$(stackhero --format=script service-add \
  --stack="My Meilisearch stack" \
  --service-store="${serviceStore}" \
  --instance="${instance}" \
  --region="${region}")
echo "Service added: meilisearch"

# サービスが完全に起動するまで待機(数分かかる場合があります)
stackhero service-wait-for --service="meilisearch"

# サービスの構成を取得(生成された認証情報を含む)
stackhero service-configuration-get --service="meilisearch" --format=json

service-configuration-getコマンドは、サービスの完全な構成(自動生成されたパスワードや接続情報を含む)を返します。出力はJSON形式なので、スクリプトや自動化で簡単に利用できます。

stackhero service-configuration-get --service=svc-xxxxxx --format=json

構成スキーマの例を確認し、ご自身の設定を適用できます。構成を更新すると、必要に応じてサービスが再起動されます。

# サービスの構成スキーマと例を表示
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認証についても解説しています。