Na tej stronie dowiesz się, jak uruchomić kompilację AOSP za pomocą narzędzia Cuttlefish.
Sprawdzanie dostępności KVM
Cuttlefish to urządzenie wirtualne, które wymaga wirtualizacji na maszynie hosta.
W terminalu na hoście sprawdź, czy dostępna jest wirtualizacja z użyciem maszyny wirtualnej opartej na jądrze:
grep -c -w "vmx\|svm" /proc/cpuinfo
To polecenie powinno zwrócić wartość różną od 0.
W przypadku działania na komputerze z architekturą ARM64 najprostszym sposobem jest sprawdzenie pod kątem stanu /dev/kvm
:
find /dev -name kvm
Uruchamianie Mątwy
W oknie terminala pobierz, skompiluj i zainstaluj pakiety Debiana dla hosta:
sudo apt install -y git devscripts equivs config-package-dev debhelper-compat golang curl
git clone https://github.com/google/android-cuttlefish
cd android-cuttlefish
tools/buildutils/build_packages.sh
sudo dpkg -i ./cuttlefish-base_*_*64.deb || sudo apt-get install -f
sudo dpkg -i ./cuttlefish-user_*_*64.deb || sudo apt-get install -f
sudo usermod -aG kvm,cvdnetwork,render $USER
sudo reboot
Ponowne uruchomienie aktywuje instalację dodatkowych modułów jądra i stosuje reguły
udev
.Cuttlefish jest częścią platformy Android Open-Source Platform (AOSP). Kompilacje urządzenia wirtualnego można znaleźć na stronie ciągłej integracji Androida. Aby znaleźć indeks wszystkich wersji Androida, otwórz stronę integracji ciągłej Androida na stronie http://ci.android.com/.
Wpisz nazwę gałęzi. Użyj domyślnej gałęzi
aosp-main
lub gałęzi ogólnego obrazu systemu (GSI), np.aosp-android13-gsi
.Przejdź do celu kompilacji aosp_cf_x86_64_phone i kliknij userdebug, aby pobrać najnowszą kompilację.
Aby wybrać tę kompilację, kliknij zielone pole poniżej userdebug. Pojawi się panel Szczegóły z bardziej szczegółowymi informacjami o tej kompilacji. W tym panelu kliknij Artefakty, aby wyświetlić listę wszystkich artefaktów dołączonych do tej kompilacji.
W panelu Elementy pobierz elementy dotyczące Cuttlefish.
Kliknij artefakt
aosp_cf_x86_64_phone-img-xxxxxx.zip
dla x86_64 lub artefaktaosp_cf_arm64_only_phone-xxxxxx.zip
dla ARM64, który zawiera obrazy urządzeń. W nazwie pliku „xxxxxx” to identyfikator kompilacji tego urządzenia.Przewiń panel w dół i pobierz
cvd-host_package.tar.gz
. Zawsze pobieraj pakiet hosta z tej samej kompilacji co obrazy.
W systemie lokalnym utwórz folder kontenera i wyodrębnij pakiety:
Architektura x86_64:
mkdir cf
cd cf
tar -xvf /path/to/cvd-host_package.tar.gz
unzip /path/to/aosp_cf_x86_64_phone-img-xxxxxx.zip
Architektura ARM64:
mkdir cf
cd cf
tar -xvf /path/to/cvd-host_package.tar.gz
unzip /path/to/aosp_cf_arm64_only_phone-img-xxxxxx.zip
Uruchom Mątwę:
HOME=$PWD ./bin/launch_cvd --daemon
Sprawdź, czy Cuttlefish jest widoczny w adb
Podobnie jak fizyczne urządzenie, Cuttlefish jest widoczny w Android Debug Bridge (adb).
W tym samym folderze, w którym uruchomiono Cuttlefish, uruchom to polecenie, by wyświetlić listę wszystkich urządzeń z Androidem dostępnych przez adb na hoście:
./bin/adb devices
Wyświetlanie urządzenia wirtualnego i nawiązywanie z nim interakcji w internecie
Domyślnie Cuttlefish uruchamia się z usługą --start_webrtc
, która umożliwia korzystanie z komponentu WebView przez port 8443 na hoście.
Aby wyświetlić urządzenia wirtualne i korzystać z nich, otwórz w przeglądarce stronę https://localhost:8443.
Więcej informacji znajdziesz w artykule Cuttlefish: strumieniowanie WebRTC.
Zatrzymaj mątwę
Zatrzymaj urządzenie wirtualne w tym samym katalogu, z którego zostało uruchomione:
HOME=$PWD ./bin/stop_cvd