huawei-cloud-sac-yolo
/install huawei-cloud-sac-yolo
Huawei Cloud YOLO Training Platform
Overview
Deploy the "Quickly Build YOLO Visual Model Training Platform" solution end-to-end on Huawei Cloud. The platform provides GPU-accelerated ECS for YOLO model training, with full infrastructure provisioning via Terraform.
Architecture: ECS (GPU, P2s/Pi2) and VPC and Subnet and Security Group (ICMP/SSH/HTTP) and EIP (300 Mbit/s) and EVS (100 GB system + 500 GB data) and CBR (backup vault + policy). Cloud-init installs Docker and launches the YOLO container on GPU.
Tool chain: Playwright CLI (solution info extraction) + Python 3.8+ (helper scripts) + Terraform 1.15.4+ (declarative deployment). No KooCLI — all resource operations through Terraform.
Prerequisites
- Python 3.8+, Playwright CLI, Terraform 1.15.4+ — see CLI Installation Guide
- Huawei Cloud AK/SK via environment variables (
HW_ACCESS_KEY,HW_SECRET_KEY); if not set, prompt user to manually editterraform.auto.tfvars.jsonto fill in AK/SK - IAM user with sufficient permissions or
rf_admin_trustagency — see IAM Policies
Security
- 🚫 Never expose AK/SK in conversation or output
- 🚫 Never ask user to type AK/SK in chat
- ✅ Prefer IAM users over primary account
- ✅ Modification ops (
apply,destroy) require explicit user confirmation
Core Commands
Placeholder values (see Parameters for per-OS resolution):
| Placeholder | Linux / macOS | Windows |
|---|---|---|
\x3Cpython> |
python3 |
python |
\x3Cscript_dir> |
./scripts |
./scripts |
\x3Ctemp_dir> |
/tmp |
$env:TEMP |
# 1. Extract solution info
\x3Cpython> \x3Cscript_dir>/extract_sac_deploy_info.py \
--url "https://www.huaweicloud.com/solution/implementations/quickly-build-a-yolo-training-platform.html" \
--out \x3Ctemp_dir>/sac_selected.json
# 2. Download and normalize template
\x3Cpython> \x3Cscript_dir>/download_tf_template_file.py \
--url "https://documentation-samples.obs.cn-north-4.myhuaweicloud.com/solution-as-code-publicbucket/solution-as-code-moudle/quickly-build-a-yolo-training-platform/quickly-build-a-yolo-training-platform.tf" \
--out-dir \x3Ctemp_dir>/yolo-workdir
\x3Cpython> \x3Cscript_dir>/normalize_tf_providers.py \x3Ctemp_dir>/yolo-workdir \
--region "cn-north-4"
# 3. List variables for review
\x3Cpython> \x3Cscript_dir>/list_tf_variables.py \x3Ctemp_dir>/yolo-workdir
# 4. Deploy
terraform init
terraform plan
# ⛔ STOP — Review the plan output above. Do NOT auto-apply.
# Confirm with the user (AskUserQuestion or equivalent) before proceeding.
# Only after explicit user confirmation:
terraform apply
# 5. Add YOLO UI security group rule
# Prompt user to manually add an ingress rule for TCP port 8001
# via Huawei Cloud console (VPC > Security Groups > Add Rule).
# Use restricted CIDR — do NOT open to all addresses.
# Wait for user confirmation before continuing.
# 6. Verify
terraform state list
terraform output -json
# 7. Cleanup
terraform destroy
Workflow
1. Extract solution info
\x3Cpython> \x3Cscript_dir>/extract_sac_deploy_info.py \
--url "\x3Csolution_detail_page_url>" \
--out \x3Ctemp_dir>/sac_selected.json
After extraction, display the results to the user:
- Solution name:
titlefield from output JSON - Estimated price:
estimated_price_textfield - Deploy links: list each
textandurlfromdeploy_linksarray - If
titleorestimated_price_textis empty, warn the user and suggest manual verification on the solution page
2. Download and normalize template
\x3Cpython> \x3Cscript_dir>/download_tf_template_file.py \
--url "\x3Ctf_template_url>" \
--out-dir \x3Ctemp_dir>/yolo-workdir
\x3Cpython> \x3Cscript_dir>/normalize_tf_providers.py \x3Ctemp_dir>/yolo-workdir \
--region "cn-north-4"
normalize_tf_providers.py writes terraform.auto.tfvars.json (including region and other parameters).
If environment variables HW_ACCESS_KEY/HW_SECRET_KEY are not set, AK/SK fields are left empty.
Prompt the user to manually edit the file to fill in AK/SK, then continue to the next step.
3. Confirm variables
\x3Cpython> \x3Cscript_dir>/list_tf_variables.py \x3Ctemp_dir>/yolo-workdir
Review with user. Block apply if sensitive variables are empty/weak.
4. Deploy
⛔ STOP — Before running terraform apply, review the terraform plan
output and confirm with the user (AskUserQuestion or equivalent).
Do NOT auto-apply. Only proceed after explicit user confirmation.
5. Add YOLO UI security group rule
The Terraform template does not include an ingress rule for TCP port 8001, which is required for the YOLO training platform web UI. After deployment, prompt the user to manually add an ingress rule for TCP port 8001 via Huawei Cloud console (VPC > Security Groups > Add Rule). Use your own IP or a restricted CIDR — do NOT open to all addresses.
6. Verify
See Verification Method and Acceptance Criteria.
7. Cleanup
Parameters
| Parameter | Required | Default | Constraint |
|---|---|---|---|
region |
Yes | cn-north-4 |
Only supported region |
| AK/SK | Yes | — | Env vars HW_ACCESS_KEY/HW_SECRET_KEY; if absent, prompt user to edit tfvars.json |
ecs_password |
Yes | — | 8-26 chars, mixed case + digit + special |
ecs_flavor |
No | p2s.2xlarge.8 |
— |
system_disk_size |
No | 100 | 40-1024 GB |
data_disk_size |
No | 500 | 40-1024 GB |
bandwidth_size |
No | 300 | 1-300 Mbit/s |
charging_unit |
No | month |
month or year |
charging_period |
No | 1 | — |
Post-Deploy Output
terraform output -json— includesaccess_instructionswith YOLO platform URL- YOLO UI:
http://\x3CEIP>:8001(allow ~10 min for cloud-init) - Verify:
ssh root@\x3CEIP> "docker ps"andssh root@\x3CEIP> "nvidia-smi"
Output Format
terraform output -json returns JSON with the following key fields:
{
"access_instructions": { "value": "http://\x3CEIP>:8001" },
"ecs_eip": { "value": "\x3CElastic IP>" },
"ecs_id": { "value": "\x3CECS Instance ID>" },
"vpc_id": { "value": "\x3CVPC ID>" }
}
All script outputs are in JSON format: extract_sac_deploy_info.py outputs
solution info JSON, list_tf_variables.py outputs variable list JSON.
Verification
Verify deployment results step by step:
- Template extraction — Check
\x3Ctemp_dir>/sac_selected.jsoncontainssolution_name,pricefields - Template download — Confirm
.tffiles exist under\x3Ctemp_dir>/yolo-workdirandterraform validatepasses - Variable confirmation — Sensitive variables (AK/SK, password) are not
empty in
list_tf_variables.pyoutput - Deployment —
terraform planshows no errors; user confirmed deployment; afterapply,terraform state listshows all expected resources - Service reachability — Wait 10-15 min for cloud-init, then
curl -s http://\x3CEIP>:8001returns 200 - GPU —
ssh root@\x3CEIP> "nvidia-smi"shows GPU device,ssh root@\x3CEIP> "docker ps"shows YOLO container running
See Verification Method and Acceptance Criteria for details.
Best Practices
- Always
terraform planbeforeapply - Start with
charging_unit=month; switch toyearafter validation - Allow 10-15 min post-deploy for cloud-init
- Monitor GPU via
nvidia-smi; adjustecs_flavorif underutilized
Reference Documents
| Document | Description |
|---|---|
| CLI Installation Guide | Install Python, Playwright CLI, Terraform |
| IAM Policies | Permissions, agency setup, failure handling |
| Verification Method | Step-by-step verification per workflow step |
| Acceptance Criteria | Full deployment acceptance checklist |
| Related Commands | Terraform, scripts, remote access reference |
Notes
- Only
cn-north-4region supported terraform.auto.tfvars.jsonis sensitive — never commit to VCSnormalize_tf_providers.pywrites region to tfvars; AK/SK left empty if env vars not set, user must fill manually- Tool chain: Playwright CLI + Python + Terraform — no KooCLI
- Make sure OpenClaw is installed (local or Docker)
- Run the install command in chat:
/install huawei-cloud-sac-yolo - After installation, invoke the skill by name or use
/huawei-cloud-sac-yolo - Provide required inputs per the skill's parameter spec and get structured output
What is huawei-cloud-sac-yolo?
Deploy YOLO training platform on Huawei Cloud with GPU ECS via Terraform. Use when building or managing a YOLO GPU training environment. Trigger: deploy YOLO... It is an AI Agent Skill for Claude Code / OpenClaw, with 35 downloads so far.
How do I install huawei-cloud-sac-yolo?
Run "/install huawei-cloud-sac-yolo" in the OpenClaw or Claude Code chat to install it in one step — no extra setup required.
Is huawei-cloud-sac-yolo free?
Yes, huawei-cloud-sac-yolo is completely free, licensed under MIT-0. You can download, install and use it at no cost.
Which platforms does huawei-cloud-sac-yolo support?
huawei-cloud-sac-yolo is cross-platform and runs anywhere OpenClaw / Claude Code is available (cross-platform).
Who created huawei-cloud-sac-yolo?
It is built and maintained by huaweicloud-skills-team (@huaweiclouddev); the current version is v0.0.1.