https://github.com/Losses/rune/commit/8a83f4c75b61a1052f1283839bc68ccd03f0d5c7
花了两天,做了个超巨大的重构,把架构拆开了,现在总算可以开始做 Rune 的四种模式了
额外提一下,这么把架构撑起来是为了给接入第三方串流媒体留空间。第一步先做 Rune Private Cloud 是为了把 local first app 的 UI 架构层做起来,允许媒体文件和元信息从远端缓存。
这么做架构的另外一个好处是,移动端软件可以把电脑当成一个 Server 连过去,主动选择同步电脑上的哪些音乐,理线享用。你既可以从电脑上拿音乐,也可以从别的手机上拿音乐,也可以从你家 NAS 上拿音乐,这样的音乐流动架构是更加灵活的。
https://www.theverge.com/2025/1/9/24339971/nintendo-game-boy-lego-release-date-october-2025
Читать полностью…总结一下这个新架构,主要隔了一层,加两个东西:数据存哪、在哪播
这样能隔出来几个模式:
本地播放:数据存本地,在本地播
遥控:数据存远端,在远端播
串流:数据存远端,在本地播
推送:数据存本地,在远端播
Getty Images and Shutterstock to Merge https://newsroom.gettyimages.com/en/getty-images/getty-images-and-shutterstock-to-merge-creating-a-premier-visual-content-company
Читать полностью…Nvidia announces $3k personal AI supercomputer called Digits https://www.theverge.com/2025/1/6/24337530/nvidia-ces-digits-super-computer-ai
Читать полностью…因为要做遥控模式,所以得把整个事件系统重构一下,现在响应的格式也被集中处理了,这样可以在数据通信层做一次抽象,如果你在遥控其他设备的播放,就走 WebSocket 把结果返回操作机器上,否则直接返回到本地。
做这个设计是为了区分点对点的数据通信,还有广播式的数据通信。
你可以想象一下 Nexus Q 的场景,家里有一个 Rune based Smart Speaker,你家里所有的电脑和手机,只要装上软件就能控制它放什么歌。发起操作请求的设备需要针对特定操作获得响应,但是其他设备只需要知道播放状态的刷新就好,所以得区分两类消息。
Rune 的遥控模式就打算实现成这个样子(其实有点像不支持串流媒体的 Sonos)。
这种架构分离可以支持无头播放设备(Rune 智能音箱)和任何有屏播放器(装了 Rune 的智能设备和电脑)。
这一点做完之后,在架构上我们就有了一个类似 Server 的东西(或者说 Private Cloud),从这个 Server 上我打算再利用 MusicBrainz 和 Acoustic 的开放数据,搭建一个你自己的、有隐私保障的 Auto Tagging Server。
菩萨用户可以开公有云的 Tagging 服务器,你也可以自己搭服务器。
从这个架构开始继续向外延伸,Rune V3/4 应该就会(但我不一定会做) Self-hosted 音乐串流服务器,还有 Self-hosted Podcast Server,这样整个架构和演化路线就说得通了。