mirror of
https://gitee.com/amber-ce/amber-pm
synced 2026-03-26 15:39:50 +08:00
修改文档
This commit is contained in:
135
Packaging-demo/README.md
Normal file
135
Packaging-demo/README.md
Normal file
@@ -0,0 +1,135 @@
|
|||||||
|
# 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/ 下的内容
|
||||||
|
|
||||||
|
files的内容请见下一节
|
||||||
|
|
||||||
|
## APM upperdir 制作流程
|
||||||
|
|
||||||
|
以下为手动制作 upperdir 的流程
|
||||||
|
|
||||||
|
首先,安装 apm 并使用`sudo apm install` 安装你所需要的 base
|
||||||
|
|
||||||
|
随后,新建三个文件夹,core,work 和 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 软件包目录 输出目录` 即可进行打包
|
||||||
83
README.md
83
README.md
@@ -1,50 +1,73 @@
|
|||||||
# APM
|
# APM 琥珀软件包管理器
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
APM 是一款基于 fuse-overlayfs , dpkg , ACE 的容器软件包管理系统
|
APM 是一款基于 fuse-overlayfs , dpkg , AmberCE 容器的软件包管理系统,支持在debian, fedora, arch等发行版上运行
|
||||||
|
|
||||||
源码在 src
|
APM 目前提供 debian 12/13 和 deepin 25 基础环境,支持把适配以上环境中的应用转换成 APM 应用
|
||||||
|
|
||||||
原理:https://www.cnblogs.com/arnoldlu/p/13055501.html
|
APM 会自动从主机获取 Nvidia 驱动文件,因此无需担心 N 卡无法加速问题
|
||||||
|
|
||||||
## 体验demo: 查看 https://gitee.com/amber-ce/amber-pm/releases
|
您可在 [src](src/) 目录找到 apm 的源代码
|
||||||
|
|
||||||
|
overlayfs 原理解析:https://www.cnblogs.com/arnoldlu/p/13055501.html
|
||||||
|
|
||||||
|
## 使用方法
|
||||||
|
```
|
||||||
|
APM - Amber Package Manager 1.0.10
|
||||||
|
|
||||||
|
Usage:
|
||||||
|
apm [COMMAND] [OPTIONS] [PACKAGES...]
|
||||||
|
|
||||||
|
Commands:
|
||||||
|
install 安装软件包
|
||||||
|
remove 卸载软件包
|
||||||
|
update 更新软件包信息
|
||||||
|
list 查看可用软件包信息
|
||||||
|
search 搜索软件包
|
||||||
|
download 下载包
|
||||||
|
clean 清除缓存软件包
|
||||||
|
autoremove 自动移除不需要的包
|
||||||
|
full-upgrade 完全升级软件包
|
||||||
|
run <package> 运行指定软件包的可执行文件
|
||||||
|
ssaudit <path> 使用 ssaudit 进行本地软件安装,详情见 spark-store
|
||||||
|
debug 显示调试系统信息并进入调试环境
|
||||||
|
amber 彩蛋功能
|
||||||
|
xmp360 彩蛋功能
|
||||||
|
bronya 彩蛋功能
|
||||||
|
|
||||||
|
-h, --help 显示此帮助信息
|
||||||
|
|
||||||
|
```
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
制作apm包upperdir的流程
|
|
||||||
|
|
||||||
先安装 apm (从release)
|
## APM deb 包全自动转换器使用方法
|
||||||
|
|
||||||
sudo apm install base包后,在
|
```
|
||||||
|
用法: amber-pm-convert --base <basename> [--base <basename> ...] <deb文件路径> [--pkgname <包名>] [--version <版本号>]
|
||||||
|
|
||||||
sudo mount -t overlay overlay -o lowerdir='/var/lib/apm/apm/files/ace-env/var/lib/apm/amber-pm-trixie/files/ace-env',upperdir=core/,workdir=work/ ./ace-env
|
参数说明:
|
||||||
|
--basename 必填参数,指定基础环境名称,可多次使用指定多个基础环境
|
||||||
|
deb文件路径 必填参数,要转换的DEB文件路径
|
||||||
|
--pkgname 可选参数,指定新包的包名(默认使用原DEB包名)
|
||||||
|
--version 可选参数,指定新包的版本号(默认在原版本后追加'-apm')
|
||||||
|
|
||||||
随后chroot进入进行安装操作,直接进行 apt install 或者其他都可以,完成后
|
示例:
|
||||||
|
amber-pm-convert --base amber-pm-trixie /path/to/package.deb
|
||||||
core: 保存新增文件
|
amber-pm-convert --base amber-pm-bookworm-spark-wine /path/to/package.deb --pkgname new-pkg --version 1.0.0
|
||||||
work: 保存变更信息
|
最下层的base在最后面,从上到下写base
|
||||||
需把这两个目录重新拥有并权限换成755
|
|
||||||
|
|
||||||
|
|
||||||
fuse-overlayfs -o lowerdir='/var/lib/apm/apm/files/ace-env/var/lib/apm/amber-pm-trixie/files/ace-env',upperdir=core/,workdir=work/ ./ace-env
|
```
|
||||||
|
|
||||||
即可只读挂载。这一步 apm run 包名 会帮你做好。
|
> 注意:因为 apm 软件包为特殊的 deb 软件包,若您在使用 Debian 或其他使用 dpkg 管理软件包的发行版,您可使用apt直接把 apm 软件包安装到系统中,同样可使用。对于这种情况,请使用系统自带的 apt 进行软件包管理。
|
||||||
|
|
||||||
> apm run 包名: 寻找 /var/lib/apm/包名/是否存在。若存在,根据info文件合成 fuser-overlayfs 参数进行挂载,随后用ACE工具chroot进入进行启动
|
## APM 的原理和软件包的介绍
|
||||||
|
|
||||||
./ace-run 即可进入,可以尝试启动一下刚刚安装的应用
|
详见 [Packaging-demo](Packaging-demo)
|
||||||
|
|
||||||
spec(对于APM内的包):
|
## APM 构建 Tips
|
||||||
对于base
|
|
||||||
/var/lib/apm/包名/files/ace-env 是 lowerdir
|
|
||||||
|
|
||||||
对于core
|
APM 使用了特殊的精简版 AmberCE 兼容环境。相关的 Tips 见 [Tips](tips.md)
|
||||||
/var/lib/apm/包名/files/core是upperdir
|
|
||||||
/var/lib/apm/包名/files/work是upperdir的work
|
|
||||||
/var/lib/apm/包名/files/ace-env是chroot进的目录(需要在打包好的包内加上允许读写这个目录——或者后续换成tmp的挂载点)
|
|
||||||
/var/lib/apm/包名/info是配置信息,目前只写了依赖的base,后续可以定义默认启动指令等
|
|
||||||
/var/lib/apm/包名/entries是desktop位置,后续会加到自动展示中
|
|
||||||
|
|
||||||
|
|
||||||
core的依赖需要写base
|
|
||||||
|
|||||||
@@ -17,23 +17,24 @@ APM - Amber Package Manager ${VERSION}
|
|||||||
Usage:
|
Usage:
|
||||||
$SCRIPT_NAME [COMMAND] [OPTIONS] [PACKAGES...]
|
$SCRIPT_NAME [COMMAND] [OPTIONS] [PACKAGES...]
|
||||||
|
|
||||||
|
|
||||||
Commands:
|
Commands:
|
||||||
install 安装软件包
|
install 安装软件包
|
||||||
remove 卸载软件包
|
remove 卸载软件包
|
||||||
update 更新软件包信息
|
update 更新软件包信息
|
||||||
|
list 查看可用软件包信息
|
||||||
|
search 搜索软件包
|
||||||
download 下载包
|
download 下载包
|
||||||
clean 清除缓存软件包
|
clean 清除缓存软件包
|
||||||
autoremove 自动移除不需要的包
|
autoremove 自动移除不需要的包
|
||||||
full-upgrade 完全升级软件包
|
full-upgrade 完全升级软件包
|
||||||
run <package> 运行指定软件包的可执行文件
|
run <package> 运行指定软件包的可执行文件
|
||||||
ssaudit <path> 使用 ssaudit 进行软件安装,详情见 spark-store
|
ssaudit <path> 使用 ssaudit 进行本地软件安装,详情见 spark-store
|
||||||
debug 显示调试系统信息并进入调试环境
|
debug 显示调试系统信息并进入调试环境
|
||||||
amber 彩蛋功能
|
amber 彩蛋功能
|
||||||
xmp360 彩蛋功能
|
xmp360 彩蛋功能
|
||||||
bronya 彩蛋功能
|
bronya 彩蛋功能
|
||||||
|
|
||||||
-h, --help 显示此帮助信息
|
|
||||||
|
|
||||||
|
|
||||||
EOF
|
EOF
|
||||||
}
|
}
|
||||||
|
|||||||
7
tips.md
7
tips.md
@@ -4,7 +4,7 @@
|
|||||||
|
|
||||||
2. apm 添加了一个钩子(debian only),在安装到 /var/lib/apm 下的应用存在ace-env时,进行configure nvidia操作;若存在entries,则进行链接到/usr/share/applications操作
|
2. apm 添加了一个钩子(debian only),在安装到 /var/lib/apm 下的应用存在ace-env时,进行configure nvidia操作;若存在entries,则进行链接到/usr/share/applications操作
|
||||||
|
|
||||||
3. apm 内置 ubuntu rootfs的修改如下
|
3. apm 内置 rootfs的修改如下
|
||||||
|
|
||||||
|
|
||||||
* 安装xz-utils
|
* 安装xz-utils
|
||||||
@@ -26,8 +26,7 @@
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
* 重要:如何在APM内更新内容——如何覆盖?
|
|
||||||
* deb全自动转apm
|
|
||||||
* apm版融合商店
|
* apm版融合商店
|
||||||
* 类似 Wine 运行器的方式全图形化傻瓜式打包
|
* 类似 Wine 运行器的方式全图形化傻瓜式打包
|
||||||
* 自动融合 APM 应用到系统主机,并实现右键卸载
|
* 自动融合 APM 应用到系统主机,并实现右键卸载
|
||||||
@@ -43,3 +42,5 @@
|
|||||||
* 完成amd64软件源配置
|
* 完成amd64软件源配置
|
||||||
* 修改aptss以兼容APM源加速
|
* 修改aptss以兼容APM源加速
|
||||||
* apm环境变量添加 IS_APM_ENV=1 GTK_USE_PORTAL=1
|
* apm环境变量添加 IS_APM_ENV=1 GTK_USE_PORTAL=1
|
||||||
|
* 重要:如何在APM内更新内容——如何覆盖?
|
||||||
|
* deb全自动转apm
|
||||||
Reference in New Issue
Block a user