sonic云真机通过linux系统接入苹果手机

背景

前期基于sonic部署搭建了在线云真机系统,基于成本考虑,想通过linux系统承载ios手机,也就是ios手机需要挂载在linux上,并通信,那需要用到usbmuxd,这是USB协议上实现多路TCP连接,将USB通信抽象为TCP通信媒介。

实操

系统:ubuntu20.04LTS、iPhone11
思路:确保宿主机中usbmuxd运行,并通过容器映射后获取信息,然后通过苹果电脑安装在iPhone上的wda操作(iPhone装完wda后就可以脱机了)

1、安装所需环境:确保宿主机安装好usbmuxd,并确认usbmuxd运行
先安装

apt install usbmuxd

如果安装后ps -ef | grep usbmuxd无法获取到运行情况,可以usbmuxd运行或直接重启sudo reboot,一般重启后就能发现服务已启动,见下

####@####-CR160:~/sonic-agent$ ps -ef | grep usbmuxd
usbmux      4444       1  0 10:38 ?        00:00:00 /usr/sbin/usbmuxd --user usbmux --systemd
iottest    15086    1896  0 10:52 pts/0    00:00:00 grep --color=auto usbmuxd

2、接入苹果手机:通过数据线接入苹果手机(linux–usb集线器–数据线–苹果手机),
过程可能手机会弹出是否信任窗口,点击信任即可
在这里插入图片描述
在这里插入图片描述

3、确认是否接入成功:以上操作后,可以发现拔插苹果手机,linux系统已经有显示挂载后的图标,见下则挂载进去了
在这里插入图片描述

sonic系统接入真机

思路:确保agent节点ios配置开启,WDA_BUNDLE_ID对应手机wda
系统相关:
sonic:1.5.0-release,docker部署

JAVA_HOME: /root/jdk-15.0.2+7
java version: 15.0.2
ANDROID_HOME: /root
ADB path: /root/platform-tools/adb
ADB version: Android Debug Bridge version 1.0.41
Version 33.0.3-8952118
Installed as /root/platform-tools/adb
chromeDriver path: /usr/bin/chromedriver
chromeDriver version: ChromeDriver 105.0.5195.52 (412c95e518836d8a7d97250d62b29c2ae6a26a85-refs/branch-heads/5195@{#853})
Node path: /usr/bin/node
Node version: v12.22.12
npm path: /usr/bin/npm
npm version: 6.14.16
adbkit path: /usr/bin/adbkit
adbkit version: 2.11.1
Appium path: /usr/bin/appium
Appium version: 1.22.0
System: linux

启动节点后观察节点上手机情况:

sudo docker logs -f sonic-agent_sonic-agent_1

检测agent日志中ios启动情况:

2022-09-18 02:41:32.522 - INFO 1 --- [main] o.cloud.sonic.agent.bridge.ios.SibTool   : iOS devices listening...
2022-09-18 02:41:32.522 - INFO 1 --- [main] o.cloud.sonic.agent.bridge.ios.SibTool   : Enable iOS Module
2022-09-18 02:41:32.787 - INFO 1 --- [pool-3-thread-1] o.cloud.sonic.agent.bridge.ios.SibTool   : iOS Devices: 00008030-####### ONLINE!
巴拉巴拉......

在这里插入图片描述
在这里插入图片描述
此时进入容器,可以发现

root@####-CR160:~# cd plugins/
root@####-CR160:~/plugins# ls
sonic-android-apk.apk  sonic-android-scrcpy.jar  sonic-go-mitmproxy  sonic-go-mitmproxy-ca-cert.cer  sonic-go-mitmproxy-ca-cert.pem  sonic-go-mitmproxy-ca.pem  sonic-ios-bridge  yadb
root@iottest-CR160:~/plugins# ./sonic-ios-bridge devices
00008030-#### online

如果usbmuxd配置有问题,则会显示

Error:failed connecting to [usbMux], you can use 巴拉巴巴等......

可以在确保宿主机运行usbmuxd情况下,重启agent即可,如果重启存在问题,可以参考以下解决:

可能会冲突的问题:
1、如果一直运行着的容器中是已经映射了usbmuxd,会引发以下挂载冲突的映射问题

####@####-CR160:~/sonic-agent$ sudo docker-compose restart
Restarting sonic-agent_sonic-agent_1 ... error

ERROR: for sonic-agent_sonic-agent_1  Cannot restart container c479ad7995c0dea6189daa249322e4929be89a82cefd46caf787e97c37f9187f: failed to create shim: OCI runtime create failed: runc create failed: unable to start container process: error during container init: error mounting "/var/run/usbmuxd" to rootfs at "/var/run/usbmuxd": mount /var/run/usbmuxd:/var/run/usbmuxd (via /proc/self/fd/6), flags: 0x5000: not a directory: unknown: Are you trying to mount a directory onto a file (or vice-versa)? Check if the specified host path exists and is the expected type

可以先vim docker-compose.yml,先把usbmuxd映射相关的注释后,启动sonic-agent_sonic-agent_1,确认容器启动正常后,查看日志无误,再次加上usbmuxd映射后启动

sudo docker-compose up -d

2、苹果连接上了,但是投屏只转圈,然后日志显示WDA_BUNDLE_ID not in your devices,这个标识wda的标识配置有误,核对后修改agent中的WDA_BUNDLE_ID后重启即可

3、有个奇怪的现象,就是usbmuxd这个当一台苹果手机都没连接时,容器中默认无法读取到拔插后的苹果设备。
当确保ps -ef | grep usbmuxd进程存在时,可以发现,只有一台苹果接入时,拔插后,设备变成不在线,必须要至少保证拔插后存在一台设备是连接中的状态(即至少2台苹果接入)才能使得拔插后,usbmuxd不会挂掉!!!

4、如果其他都操作都正常,还是获取不到设备信息,则kill -9 进程号再reboot一下看看效果。

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值