一、问题:QNAP 4.3.6无法DLNA串流小米AI音箱,Music Station中无法发现网络音频设备。
二、定位:
1. 刷新Music Station
dmc.php → /mnt/ext/opt/musicstation/api/dmc.php → libs/class_mediacontroller.php
发现实际通过 qRPlayerAgent -c ListRender 来获得可串流设备
2. qRPlayerAgent(C++程序)
/usr/local/medialibrary/bin/qRPlayerAgent -c ListRender
确实无小米AI音箱输出,继续定位:qRPlayerAgent → rpc: qRPlayerCenter → process() → list_render(...),发现此方法实际解析 /usr/bin/qDmcAgent -c list 结果,然后通过 dlna_device_doc_gen() 生成xml。
3. qDmcAgent
执行 /usr/bin/qDmcAgent -c list ,发现有小米AI音箱的DLNA信息。奇怪!
<root>
<version>QDMS 430.1.8.4</version>
<device>
<deviceName>小米AI音箱-xxxx</deviceName>
<deviceId>uuid:xxx-xxx-xxx-xxx-xxx</deviceId>
<ip>xxx.xxx.xxx.xxx</ip>
<mac>xx:xx:xx:xx:xx:xx</mac>
<maxVolume>100</maxVolume>
</device>
</root>
4. qRPlayerCenter 的 dlna_device_doc_gen() 方法
发现需要 qDmcAgent 返回type子节点才正常生成xml,而上一步显然没有。
5. qDmcd
qDmcAgent → rpc: qDmcd → getRanderDeviceListXML(),需要通过Sink信息来生成video,audio,photo等,然而没有抓到小米AI音箱的该项信息(也许小米本身就没有提供)导致第3步的xml没有<type>,最终导致该设备无法在 qRPlayerAgent -c ListRender 中输出。
三、解决思路(任一一个方法应该都可以):
1. 小米AI音箱的问题,需要输出Sink告知是audio设备。
2. QNAP对小米AI音箱做特殊处理(其实可以看到,QNAP已对 Sonos 做了特殊处理)。
3. 用个bash替换,手动给 qDmcAgent -c list 返回的<device>里加上<type>audio</type>
四、尝试解决
前面两个都得等厂家,先试了3,已经在网络媒体播放器里出现了。
但无法正确播放,似乎 qRPlayerAgent 通过DLNA协议串流小米AI音箱总是有问题(-4错误意味着“Renderer not found”,而 qDmcAgent 又没有问题(说明DLNA协议是ok的):
# ./qRPlayerAgent -c GetVolume --dev uuid:xxx-xxx-xxx-xxx-xxx
<root>
<version>QDMS 430.1.8.4</version>
<status>-4</status>
</root>
# ./qDmcAgent -c getVolume --uuid uuid:xxx-xxx-xxx-xxx-xxx
<root>
<version>QDMS 430.1.8.4</version>
<CurrentVolume>20</CurrentVolume>
</root>
五、曲线解决
试试Airplay?通过AirConnect将DLNA协议包装为Airplay,但是QNAP不认,qRPlayerCenter中获取Airplay的设备,必须是 _airplay._tcp :
/usr/sbin/avahi-browse -rkpt _airplay._tcp
而AirConnect包装后只有音频,协议是 _raop._tcp
# ./avahi-browse -a
+ eth0 IPv4 xxxxxx@______AI______-xxxx+ _raop._tcp local
吐了