Files
amber-pm/Packaging-demo/README.md
2025-10-28 13:21:43 +00:00

142 lines
4.3 KiB
Markdown
Raw Blame History

This file contains ambiguous Unicode characters
This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.
# APM 软件包打包流程
本文档为开发者准备,若您只是想从 deb 软件包打包 APM 软件包,您可以通过 `amber-pm-convert`指令进行全自动一键转换
通过 `apm search amber-pm- ` 即可搜索到所有可用的 base 列表
---
## APM 软件包结构规范
在阅读前请确保您对overlayfs有了基本的了解
overlayfs 原理解析https://www.cnblogs.com/arnoldlu/p/13055501.html
---
一个典型的 APM 软件/中层依赖包应当包含以下内容
```
├── DEBIAN
│ ├── control
│ └── postinst
└── var
└── lib
└── apm
└── eom
├── entries
│ ├── applications
│ ├── doc
│ ├── glib-2.0
│ └── man
├── files
│ ├── core
│ └── work
├── info
└── info_debug
```
* DEBIAN目录包含了软件包的基本信息和依赖的环境信息
1. 以下是 control 文件的内容
```
Package: eom
Version: 1.26.0-2-apm
Architecture: amd64
Maintainer: APM Converter <apm-convert@spark-app.store>
Depends: amber-pm-bookworm
Installed-Size: 45228
Description: APM converted package from eom
This package was automatically converted from the original deb package.
Based on: amber-pm-bookworm
```
Package: 包名。应当唯一。若使用转换器进行转换,默认和原包名一致
Version: 版本号。若使用转换器进行转换,默认在原版本号后加`-apm`
Architecture: 软件包架构。同 dpkg 进行填写即可。若使用转换器进行转换,默认和原包架构一致
Depends: 依赖包。填写直接依赖的base即可
Installed-Size: 安装后的大小。若使用转换器进行转换,会自动填写
Description: 包描述。若使用转换器进行转换,会自动填写
2. 以下是 postinst 文件内容
```
#!/bin/bash
PACKAGE_NAME="$DPKG_MAINTSCRIPT_PACKAGE"
if [ "$1" = "remove" ] || [ "$1" = "purge" ]; then
echo "清理卸载残留"
rm -rf "/var/lib/apm/$PACKAGE_NAME"
else
echo "非卸载,跳过清理"
fi
```
若无特殊需求,内容保持一致即可,用于在卸载软件包后清理环境
* /var/lib/apm 包含了APM 软件容器的文件和信息
软件应当被放置在 /var/lib/apm/软件包名/ 处
此处有两个目录,两个文件
entries 可选,包含了软件包需要被放到 /usr/share/ 的文件,如 desktop icon 等
files 必须,包含了软件包的 upperdir 和 workdir
info 必须包含了直接依赖的base信息。若应用使用了多层的依赖会一层一层寻找info信息直到找到底层依赖
info_debug 可选,包含了打包时解析的依赖信息
entries下的内容同软件需要放置到 /usr/share/ 下的内容
> 注意: .desktop 文件应当新加一行 X-APM-APPID=包名 来允许软件管理器管理
files的内容请见下一节
## APM upperdir 制作流程
以下为手动制作 upperdir 的流程
首先,安装 apm 并使用`sudo apm install` 安装你所需要的 base
随后新建三个文件夹corework 和 ace-env ,执行
`sudo mount -t overlay overlay -o lowerdir='/var/lib/apm/apm/files/ace-env/var/lib/apm/base包的包名如amber-pm-trixie/files/ace-env',upperdir=core/,workdir=work/ ./ace-env`
随后chroot进入进行安装操作直接进行 apt install 或者其他都可以,完成后解除挂载 ./ace-env
你便得到了:
* core: 保存新增文件
* work: 保存变更信息
需把这两个目录重新拥有并权限换成755后放入对应的目录进行 apm 打包
你也可以测试一下刚刚打包的软件
fuse-overlayfs -o lowerdir='/var/lib/apm/apm/files/ace-env/var/lib/apm/base包的包名如amber-pm-trixie/files/ace-env',upperdir=core/,workdir=work/ ./ace-env
即可只读挂载。这一步 apm run 包名 会帮你做好。
> apm run 包名: 寻找 /var/lib/apm/包名/是否存在。若存在根据info文件合成 fuser-overlayfs 参数进行挂载随后用ACE工具chroot进入进行启动
./ace-run 即可进入,可以尝试启动一下刚刚安装的应用
## APM 打包
使用 `dpkg-deb --build 软件包目录 输出目录` 即可进行打包
## APM 底层 Base Runtime 的构建
详见 https://gitee.com/amber-ce/amber-pm-common