<<../../_common/intro/_packages_intro.md>>
<<../../_common/intro/_packages_serving.md>>
<<../../_common/intro/_packages_storing.md>>
在之前的本系列代码练习中,虽然您可能没有意识到,但您已经体验过到设备的软件按需交付。在本练习中,您将进一步揭开它的神秘面纱,了解到包被交付和存储到 Fuchsia 设备中的过程的具体细节。
<<../_common/_restart_femu.md>>
运行如下命令,以启动包服务器并允许模拟器加载软件包:
fx serve-updates
该命令打印的输出类似如下所示。它表示服务器正在运行,并已成功将模拟器注册为目标设备:
[serve-updates] Discovery...
[serve-updates] Device up
[serve-updates] Registering devhost as update source
[serve-updates] Ready to push packages!
[serve-updates] Target uptime: 139
[pm auto] adding client: [fe80::5888:cea3:7557:7384%qemu]:46126
[pm auto] client count: 1
fx serve-updates
命令会启动用于将包交付到目标设备的 本地包服务器。该服务器默认在 8083 端口上运行。
在浏览器中访问 http://localhost:8083
,会加载出一个当前包仓库中可用的包的列表的网页。列表中的每一项都是可被交付到设备的包。
包由 Fuchsia 设备按需解析并加载。让我们在 spinning-square
示例包上进行操作来稍作展示。
在设备命令行中,您可以确定某个已知的包目前是否在设备上。
fx shell pkgctl pkg-status fuchsia-pkg://fuchsia.com/spinning-square-rs
Package in registered TUF repo: yes (merkle=ef65e2ed...)
Package on disk: no
打开新终端,开始流式传输 pkg-resolver
的设备日志。
ffx log --filter pkg-resolver
这里展示了从包服务器加载的包的所有实例。
在设备命令行中,尝试解析包:
fx shell pkgctl resolve fuchsia-pkg://fuchsia.com/spinning-square-rs
注意 pkg-resolver
的输出中增加的新行:
[pkg-resolver][pkg-resolver][I] Fetching blobs for fuchsia-pkg://devhost/spinning-square-rs: [
6b547fb59fda56866eea01cda90add0aabc1af7c7418c7850011ec6e99a996f1,
7c1a9fd1c11e9b6b1d3c3184cf350cecfc91ec083b412d20c18b5187d0983d88,
]
[pkg-resolver][pkg-resolver][I] resolved fuchsia-pkg://fuchsia.com/spinning-square-rs as fuchsia-pkg://devhost/spinning-square-rs to 21967ecc643257800b8ca14420c7f023c1ede7a76068da5faedf328f9d9d3649 with TUF
在设备命令行中,再次在设备上查看包状态:
fx shell pkgctl pkg-status fuchsia-pkg://fuchsia.com/spinning-square-rs
Package in registered TUF repo: yes (merkle=ef65e2ed...)
Package on disk: yes (path=/pkgfs/versions/ef65e2ed...)
Fuchsia 解析了包并按需从本地 TUF 仓库中将其加载了!
现在 spinning-square
包已经成功解析,接下来可以探索包内容。在解析之后,包就可以在目标设备上用它的内容地址引用。
在设备命令行中,可以使用 pkgctl get-hash
命令来确认 spinning-square
的包摘要。
fx shell pkgctl get-hash fuchsia-pkg://fuchsia.com/spinning-square-rs
该命令会返回如下的唯一包摘要:
ef65e2ed...
使用 pkgctl open
命令并提供完整的包摘要,来查看包内容。
fx shell pkgctl open {{ '<var>' }}ef65e2ed...{{ '</var>' }}
opening ef65e2ed...
package contents:
/bin/spinning_square
/lib/VkLayer_khronos_validation.so
/lib/ld.so.1
/lib/libasync-default.so
/lib/libbackend_fuchsia_globals.so
/lib/libc++.so.2
/lib/libc++abi.so.1
/lib/libfdio.so
/lib/librust-trace-provider.so
/lib/libstd-e3c06c8874beb723.so
/lib/libsyslog.so
/lib/libtrace-engine.so
/lib/libunwind.so.1
/lib/libvulkan.so
/meta/contents
/meta/package
/meta/spinning-square-rs.cm
/meta/spinning-square-rs.cmx
/data/fonts/RobotoSlab-Regular.ttf
/meta/fuchsia.abi/abi-revision
/data/vulkan/explicit_layer.d/VkLayer_khronos_validation.json
这个命令列出了包的元数据和包中的每个内容 BLOB(Binary Large OBject,二进制大型对象)。其中的 bin/
项目对应可执行文件,lib/
项目对应共享库依赖,还有后面的额外元数据和资源。
祝贺!您现在对 Fuchsia 的独特性和这样一个新平台的设计目标都有了更好的理解。
在下一个模块中,您将了解到有关 Fuchsia 这个开源项目和用于构建与自定义系统的工具的更多知识: