Meilisearch: 使用 CLI 自動化操作

透過 Stackhero CLI 程式化啟動 Meilisearch、取得其認證資訊並變更其設定

歡迎來到 Stackhero 文件中心!

如果您正在尋找一個強大且易於使用的搜尋引擎,Stackhero 的 Meilisearch cloud 服務會是您的理想選擇。您可以期待以下特色:

  • 可自訂網域名稱,內建 HTTPS 安全機制。
  • 更新無煩惱,只需一鍵即可完成。
  • 透過專屬的 私人 VM,享有高 效能 與強大 安全性

想要快速開始嗎?您只需 5 分鐘即可體驗 Stackhero 的 Meilisearch cloud hosting 解決方案。這項服務專為節省您的時間並讓設定流程變得極為簡單而設計!

本指南將說明如何從命令列全程建立 Meilisearch 服務、讀取其認證資訊並更新其設定,完全不需在控制台點擊操作。這非常適合用於腳本、自動化流程(CI pipeline)及 AI agent。

我們將全程使用 Stackhero CLI。如果您尚未安裝,可以透過以下指令安裝:

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

最簡單的開始方式是透過瀏覽器登入。當您執行登入指令時,CLI 會自動開啟網頁,讓您授權存取權限。您不需要在 CLI 輸入密碼或 2FA 驗證碼。

stackhero login

登入後,您的認證資訊會儲存在本地端,後續 CLI 指令會自動使用。

若是在完全自動化的環境(如腳本或 CI pipeline),建議使用非互動式的 access token。您可以在控制台(帳戶 > 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。

# 列出服務商店可用的實例規格(請使用 NAME 欄位作為 --instance)
stackhero instances-store-list --service-store=meilisearch

# 列出可用區域(如 "europe")
stackhero regions-list

以下是一個範例腳本,會建立一個 stack,將您的 Meilisearch 服務加入其中,等待服務啟動,取得其設定(包含自動產生的認證資訊),然後套用新的設定。

#!/bin/bash
set -e

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

serviceStore="meilisearch"   # Meilisearch 服務商店名稱(見步驟 2)
instance="..."                # 步驟 3 選擇的實例規格
region="europe"               # 步驟 3 選擇的區域名稱

# 建立服務專用的 stack(預設使用您的主要組織;如需指定請加 --organization)
stackId=$(stackhero --format=script stack-create \
  --name="My Meilisearch stack")
echo "Stack created: ${stackId}"

# 將 Meilisearch 加入 stack(名稱會自動解析)
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 驗證方式。