This is a shared transcript of a chat session with the ubicloud/ubicloud repo.

Sign in another way

Why am I getting this error:

The /var/storage directory is created in the "Vm::PrepHost" program. If "LearnStorage" runs first, it will fail.

label def prep bud Prog::Vm::PrepHost bud Prog::LearnNetwork unless vm_host.net6 bud Prog::LearnMemory bud Prog::LearnArch bud Prog::LearnCores bud Prog::LearnStorage bud Prog::InstallDnsmasq bud Prog::SetupSysstat bud Prog::SetupNftables hop_wait_prep end Exception:

df: /var/storage: No such file or directory

The error you're encountering is due to the /var/storage directory not being present when the Prog::LearnStorage program attempts to access it. This directory is crucial for the Prog::LearnStorage program to function correctly, as it parses storage device information from this location.

The Prog::Vm::PrepHost program, as defined in /prog/vm/prep_host.rb, is responsible for preparing the host, which includes creating necessary directories and performing other setup tasks. The actual creation of the /var/storage directory is likely handled in the prep_host.rb script located at /rhizome/host/bin/prep_host.rb, as part of the host preparation process.

The error occurs because the Prog::LearnStorage program runs before the Prog::Vm::PrepHost program has had a chance to create the /var/storage directory. This sequence is defined in your prep method, where Prog::LearnStorage is called after several other operations, but crucially, it does not explicitly ensure that Prog::Vm::PrepHost has completed successfully before it begins.

To resolve this issue, you need to ensure that Prog::Vm::PrepHost runs and completes successfully before Prog::LearnStorage starts. This could involve checking the sequence of operations in your prep method or introducing a dependency check in Prog::LearnStorage to ensure that the necessary directory exists before proceeding.

A potential solution is to reorder the operations in your prep method to ensure that Prog::Vm::PrepHost runs before Prog::LearnStorage. Alternatively, you could modify Prog::LearnStorage to check for the existence of /var/storage and either create it or wait until it's available before proceeding, though the former approach is more in line with ensuring that all necessary host preparation steps are completed in the correct order.

Pick up where this conversation left off.

Sign in another way