Orchestrazione cloud in OmniLab ATS

L'app Cloud Orchestration offre un modo scalabile e ad alte prestazioni per gestire le istanze Cuttlefish, in particolare per i dispositivi virtuali basati su ARM (CHD). OmniLab ATS supporta l'orchestrazione cloud per consentirti di eseguire test su dispositivi virtuali. Prima di iniziare a utilizzare i dispositivi virtuali, segui le istruzioni riportate in OmniLab Android Test Station per installare OmniLab ATS.

Panoramica

Cloud Orchestration consente a OmniLab ATS di delegare la gestione delle istanze Cuttlefish a un servizio Cloud Orchestrator dedicato. Questo approccio offre diversi vantaggi rispetto alle modalità locale e remota esistenti, pur mantenendo un'esperienza utente familiare:

  • Avvio parallelo delle istanze:consente di avviare più istanze Cuttlefish contemporaneamente, riducendo significativamente il tempo di overhead prima dell'inizio dei test.
  • Scalabilità:adatta ad ambienti di test su larga scala.
  • Isolamento delle risorse:disaccoppia l'ambiente di esecuzione dei test (worker ATS) dall'ambiente di emulazione del dispositivo.

Prerequisiti

  • Una macchina host in grado di eseguire Docker
  • Accesso alle immagini Docker di orchestrazione di Cuttlefish

Configura il servizio Cloud Orchestrator

Il servizio Cloud Orchestrator gestisce il ciclo di vita delle istanze Cuttlefish. Puoi eseguire il deployment del servizio in vari ambienti e supporta le architetture x86 e ARM:

  • Stesso host del worker ATS: viene eseguito in un container Docker sulla stessa macchina
  • Macchina separata: viene eseguito su un server on-premise in grado di eseguire Docker
  • Istanza cloud:viene eseguita su una macchina virtuale in un ambiente cloud, ad esempio Google Compute Engine

Installare e configurare il servizio

Segui il file README di Cloud Android Orchestration per avviare il servizio.

Autenticazione e autorizzazioni

Se il servizio Cloud Orchestrator è in esecuzione su una macchina remota, assicurati che l'host worker ATS disponga delle autorizzazioni necessarie per accedervi tramite richieste HTTP. Se la connessione HTTP non è consentita, potresti dover configurare l'inoltro delle porte SSH. Per maggiori dettagli, vedi Prova l'orchestratore cloud.

Stato previsto

Dopo l'avvio del servizio Cloud Orchestrator, dovrebbe essere raggiungibile tramite HTTP. Puoi verificarne lo stato eseguendo una query sulla relativa API:

  • Ping del servizio:dovresti essere in grado di raggiungere l'endpoint del servizio dall'host worker OmniLab ATS. Ad esempio, l'esecuzione di curl -I http://localhost:8080/v1/zones/local/hosts dovrebbe restituire una risposta HTTP riuscita (HTTP/1.1 200 OK o un reindirizzamento 302 Found a /username), confermando che il servizio è attivo e raggiungibile.

Configura OmniLab ATS per Cloud Orchestration

Prima di avviare OmniLab ATS, assicurati che tutte le istanze Cuttlefish sull'host worker OmniLab ATS siano arrestate. OmniLab ATS avvia e arresta automaticamente i dispositivi virtuali durante il ciclo di test e le istanze Cuttlefish esistenti sono in conflitto con le istanze gestite da OmniLab ATS. Per informazioni dettagliate sull'arresto delle istanze Cuttlefish, vedi Arrestare Cuttlefish.

Per attivare Cloud Orchestration in OmniLab ATS, passa flag specifici quando avvii OmniLab ATS:

mtt start --use_cloud_orchestrator \
  --cloud_orchestrator_service_url=http://HOST:PORT \
  --max_local_virtual_devices N \
  --use_host_network
  • --use_cloud_orchestrator: attiva la funzionalità di orchestrazione cloud.
  • --cloud_orchestrator_service_url: specifica l'URL in cui il servizio Cloud Orchestrator è in ascolto, ad esempio http://localhost:8080.
  • --max_local_virtual_devices: imposta il numero massimo di dispositivi virtuali che OmniLab ATS può allocare contemporaneamente. Il numero predefinito è 0.
  • --use_host_network: utilizza lo spazio dei nomi di rete dell'host per il container. Questo è necessario per accedere al servizio Cloud Orchestrator.

Eseguire un test con dispositivi orchestrati dal cloud

Questa sezione descrive i passaggi per eseguire un test su dispositivi virtuali orchestrati nel cloud.

Alcuni dispositivi

Nell'elenco dei dispositivi, OmniLab ATS mostra i dispositivi virtuali orchestrati nel cloud come segnaposto anziché i numeri di serie effettivi. I segnaposto vengono visualizzati nel formato HOSTNAME:PORT (ad esempio, thehostname:6520). Gli stati sono Disponibile o Allocato. Un segnaposto nello stato Disponibile indica che il dispositivo virtuale non è in esecuzione e può essere allocato per il test.

Seleziona Dispositivi orchestrati dal cloud

Figura 1. Selezione di dispositivi virtuali orchestrati nel cloud.

Aggiungere azioni dispositivo

Quando viene pianificato un test su questi dispositivi, ATS aggiunge automaticamente le azioni del dispositivo richieste per eseguire il provisioning e gestire le istanze Cuttlefish durante il ciclo di test.

Azioni dispositivo automatiche

Figura 2. Azioni automatiche del dispositivo.

Imposta le risorse di test

Quando pianifichi un test, devi fornire le risorse di test richieste. Nella sezione Imposta risorse di test, assicurati di mappare i file caricati ai nomi delle risorse corretti:

  • Mappa il pacchetto di strumenti dell'host, ad esempio cvd-host_package.tar.gz, al nome cvd_host_package.
  • Mappa il file ZIP dell'immagine del dispositivo al nome cvd_device_image.

Risorse di test per l'orchestrazione cloud

Figura 3. Mappatura delle risorse di test.

Visualizzare esecuzioni di test e log

Al termine del test, puoi visualizzare i log nella sezione dei file di output. I log specifici raccolti per le istanze gestite da Cloud Orchestrator includono:

  • launcher.log: Log di Avvio app Cuttlefish
  • kernel.log: Log del kernel Android standard