Sistema: di Windows 10
Il mio problema: Impostazione Genymotion per puntare al l'SDK personalizzato non ha avuto alcun effetto. Ho ancora ricevuto il:
Couldn't start project on Android: could not install smartsocket listener: cannot bind to 127.0.0.1:5037: Only one usage of each socket address (protocol/network address/port) is normally permitted. (10048) could not read ok from ADB Server * failed to start daemon * error: cannot connect to daemon
Quello che ho scoperto è stata la differenza tra le versioni di ADB utilizzate in tutto il sistema.Ecco il comando che ho usato per trovarli:
where /r C:\ adb.exe
Questo prodotto i risultati:
C:\Program Files\Expo XDE\resources\app\node_modules\xdl\binaries\windows\adb\adb.exe
C:\Program Files\Genymobile\Genymotion\tools\adb.exe
C:\Users\kyle\AppData\Local\Android\Sdk\platform-tools\adb.exe
C:\Users\kyle\AppData\Local\Android\Sdk\platform-tools\adb backup\adb.exe
Navigazione verso ogni directory e in esecuzione:
adb.exe version
mi ha permesso di vedere che l'Expo è stato esecuzione della versione ADB:
Android Debug Bridge version 1.0.36
Revision fd9e4d07b0f5-android
Mentre Genymotion utilizzando l'SDK personalizzato aveva versione (C: \ Users \ Kyle \ AppData \ Local \ Android \ SDK \ platform-tools \ adb.exe):
Android Debug Bridge version 1.0.39
Revision 3db08f2c6889-android
Come prova ho preso il file adb (adb.exe, AdbWinApi.dll, AdbWinUsbApi.dll) dal
c:\Users\kyle\AppData\Local\Android\Sdk\platform-tools\adb.exe
e li mise in una cartella di backup. Ho quindi spostato i file adb situati a
c:\Program Files\Expo XDE\resources\app\node_modules\xdl\binaries\windows\adb\adb.exe
nella stessa posizione. Ho ucciso ADB con:
adb kill-server
che ha causato un riavvio del server adb automaticamente a causa di avere il mio dispositivo Genymotion già in esecuzione. Ho premuto il pulsante "Riavvia" all'interno di Expo XDE e ha immediatamente iniziato a funzionare. Ecco il registro in cui mi ha colpito il pulsante di riavvio al 01:13:04:
12:45:53 AM
could not install *smartsocket* listener: cannot bind to 127.0.0.1:5037: Only one usage of each socket address (protocol/network address/port) is normally permitted. (10048)
could not read ok from ADB Server
* failed to start daemon *
error: cannot connect to daemon
1:13:04 AM
Restarting project and clearing packager cache (Hold shift while clicking restart to avoid clearing cache).
1:13:11 AM
Starting React Native packager...
1:13:17 AM
Scanning 543 folders for symlinks in C:\Users\kyle\git\betalog\node_modules (49ms)
1:13:17 AM
1:13:19 AM
Couldn't adb reverse: closed
1:13:20 AM
Project opened! You can now use the "Share" or "Device" buttons to view your project.
1:13:26 AM
Couldn't adb reverse: closed
1:13:26 AM
Downloading latest version of Expo
1:13:28 AM
Installing Expo on device
1:13:33 AM
Opening on Android device
1:13:56 AM
Building JavaScript bundle: finished in 59643ms.
1:14:01 AM
Dependency graph loaded.
1:14:03 AM
Your JavaScript transform cache is empty, rebuilding (this may take a minute).
Conclusione: Genymotion e Expo può essere necessario utilizzare la stessa versione di adb in modo che Expo possa comunicare correttamente con l'simulato dispositivo. Indicando Genymotion nella posizione dell'SDK Android e assicurando che Expo XDE abbia la stessa versione consentirà una corretta comunicazione tra i dispositivi. Ho spostato la versione di Expo XDE nel percorso dell'SDK, ma potresti essere in grado di andare dall'altra parte (prendi i file ADB sdk e inseriscili nel percorso della risorsa Expo XDE).
P.S. Sono stato attraverso tutti i post StackOverflow relativi a questo problema. Solo così sapete che il mio task manager mostra tre istanze di adb.exe in esecuzione. Se uccidi qualcuno di loro, loro tornano indietro.
Spero che questo aiuti/acclamazioni
Questo errore può verificarsi indipendentemente dal funzionamento di Genymotion. –