征程6 上基于 DEB 工具实现包管理

1.引言

在开发、调测过程中,开发人员需要将系统软件、应用软件部署到 Soc 板端,以用于运行调试。传统的部署方式是通过解压复制或者调用部署脚本。这样的部署方式需要有着方式不统一、维护投入大的缺点。

在 linux 系统上,大多采用包管理的方式管理软件包,常见的包管理方式如上。相比于部署脚本的方式,使用统一的包管理工具有规范和优化软件包的发布、管理流程,减少维护工作量、可溯源性高的优点,适合多版本、多种类软件包的场景。

在 J6 上,底软支持基于 DEB 的包管理方式,支持通过 apt、dpkg 的方式安装软件包。本文将讲解基于 DEB 工具的包管理方式,并以管理 Boyan.deb 软件包为例,展示包的构建、在 征程6 上的部署等内容。

2.Deb 软件包原理介绍

.deb 是 Debian 和基于 Debian 系统(如 Ubuntu)使用的软件包格式,它包含软件及其安装信息。它的主要作用是简化软件的分发和安装,即用于板端软件包部署。

2.1 deb 包的结构

.deb 包中主要包括 可执行程序、控制文件两大部分。一个常见的 。deb 包的目录结构如下。可执行程序部分是需要安装在板端的程序内容,如下的 data.tar.gz 路径;控制文件是脚本集合,用于辅助软件包的安装、卸载操作,如下的 control.tar.gz 路径。

software_1.0-1.deb
│
├── control.tar.gz
│   ├── control
│   ├── preinst
│   ├── postinst
│   ├── prerm
│   └── postrm
│
└── data.tar.gz
    ├── usr
    │   └── local
    │       └── bin
    │           └── software
    └── etc
        └── software
            └── config.conf

2.2 deb 包的安装原理

.deb 包的安装流程主要依赖 deb 包管理工具 和 辅助安装脚本。deb 包安装工具负责解压、复制、部署;辅助安装脚本负责安装前后的定制化操作。整个安装流程可以总结为以下 7 步:

  1. 解压软件包:
  • dpkg 首先会解压 。deb 包的内容到一个临时目录。.deb 文件实际上是一个包含多个文件的归档,主要包括:
    • control.tar.gz:包含控制文件(如 control、postinst、prerm 等)。
    • data.tar.gz 或 data.tar.xz:包含实际的安装文件。
    • debian-binary:标识该包使用的 dpkg 版本。
  1. 检查控制文件:
  • dpkg 读取并解析 control 文件,该文件包含了包的元数据(如包名、版本、依赖关系等)。
  1. 执行预装脚本(preinst):
  • 如果存在 preinst 脚本,dpkg 会在正式安装文件之前执行该脚本。这个脚本通常用于在安装之前执行某些准备工作。
  1. 解压文件到目标目录:
  • dpkg 将 data.tar。* 解压到系统的根目录(/),覆盖或新建文件和目录。
  1. 设置文件权限和所有权:
  • 解压后,dpkg 会根据包中的元数据设置文件的权限和所有权。
  1. 执行配置脚本(postinst):
  • dpkg 接下来会执行 postinst 脚本。这个脚本通常用于执行安装后的配置工作,例如启动服务、注册系统组件等。
  1. 记录包信息:
  • dpkg 会在 /var/lib/dpkg/status 文件中记录已安装包的信息,方便系统和用户查询包的状态。

2.3 deb 包的卸载原理

.deb 包的卸载流程原理同安装流程原理。卸载流程也主要依赖 deb 包管理工具 和 辅助安装脚本。deb 包安装工具负责删除;辅助卸载脚本负责卸载前后的定制化操作。整个卸载流程可以总结为以下 4 步:

  1. 执行预卸载脚本(prerm):
  • 如果存在 prerm 脚本,dpkg 会在移除文件之前执行该脚本。这个脚本通常用于停止服务、解除系统注册等。
  1. 删除文件:
  • dpkg 会删除安装包中包含的文件和目录。
  1. 执行后卸载脚本(postrm):
  • dpkg 会执行 postrm 脚本。这个脚本通常用于清理卸载后的遗留文件或重置系统配置等。
  1. 更新包信息:
  • dpkg 会更新 /var/lib/dpkg/status 文件,移除关于该包的记录。

3.Boyan 软件包管理示例

以管理 Boyan.deb 软件包为例,本节将展示 Boyan-runtime.deb 软件包的构建、在 J6 上的安装部署。

3.1 Boyan.deb 包构建

Boyan.deb 包生成的核心步骤是两两步:一是控制文件的生成;二是软件包 data 的生成。将 Boyan.deb 包的生成接入到 Boyan 整包的编译构建流程中,其整体构建流程如下:

在这里插入图片描述

在编译完成后,生成 runtime_tmp_package 目录,存放可执行程序、控制文件、辅助安装脚本等文件,用于构建 Boyan_Runtime.deb 软件包。最终,runtime_tmp_package 目录的结构如下:

runtime_tmp_package
│
├── DEBIAN                     // Package info文件
│   ├── control
│   ├── preinst
│   ├── postinst
│   ├── prerm
│   └── postrm
│
└── middleware                // Package data
│   ├── bin
│   ├── etc
|   │   ├── j6                // 配置文件
|   │   │   └── sm            
|   │   │   └── em            
|   │   │   └── ...           
│   ├── lib                   // 动态库
│   │   ├── libexec.so
│   │   ├── libsm_client.so
│   ├── pub                   // 三方库
│   │   ├── lib 
│   │   │   └── ...
│   ├── config_repo           // 配置文件库
│   │   ├── default 
│   │   │   └── ...
│   │   ├── pilot5.1 
│   │   │   └── ...
│   │   ├── ... 
│   │   │   └── ...
│   └── ...

其中,可执行程序可直接从编译产出物拷贝,控制文件和辅助安装脚本则需要编写。

控制文件(Control 文件)需要描述软件包的相关信息,必须包含包名、版本等必要信息。Boyan_Runtime.deb 包的控制文件如下:

Package: boyan-runtime-j6
Version: 1.11.1
Section: utils
Priority: optional
Architecture: arm64
Depends: 
Maintainer: Auto_Bsw <Auto_Bsw@horizon.cc>
Description: Basic Software. Boyan-runtime package is used to install in j6 soc for runtime. This package contains lib, bin and configs for all boyan modules. 

辅助安装脚本用于 停止服务进程、启动服务经常、构建执行脚本 等工作,各个辅助安装脚本的作用如下:

  • preinst(安装前脚本):停止 em_service 和 boyan 的相关服务
  • postinst(安装后脚本):创建 em_service 启动脚本
  • prerm(卸载前脚本):停止 em_service 和 boyan 的相关服务
  • postrm(卸载后脚本):删除 em_service 启动脚本

通过上述步骤,将产出物都按照目录结构放置在 runtime_tmp_package 目录下,再通过 dpkg 工具构建指令构建 deb 包即可,构建指令如下:

dpkg-deb -b runtime_tmp_package/ Boyan_Runtime.deb

3.2 Boyan.deb 包部署

构建 Boyan.deb 包后,将软件包拷贝到 征程6 板端,并通过 dpkg 命令安装软件包,安装指令如下:

dpkg -i Boyan_Runtime_Full_J6_V1.11.1_20240920-110923.deb

安装日志如下:

Selecting previously unselected package boyan-runtime-j6.
(Reading database ... 24654 files and directories currently installed.)
Preparing to unpack Boyan_Runtime_Full_J6_V1.11.1_20240920-110923.deb ...
Running pre-installation tasks...
Termiate em_service and boyan service...
Stop boyan service...
Mount middleware partition...
Unpacking boyan-runtime-j6 (1.11.1) ...
Setting up boyan-runtime-j6 (1.11.1) ...
Running post-installation tasks...
Please restart the device...

安装后通过 dpkg -l 指令查询到包的安装状态、版本、架构等信息,显示如下。当安装新版本软件时,dpkg 工具会通过版本比较、依赖检查等方式管理多版本包的升级和替换。

 ii  boyan-runtime-j6                      1.11.1                         arm64        Basic Software. Boyan-runtime package is used to install in j6 soc for runtime. This package contains lib, bin and configs for all boyan modules.

安装后查看/middleware 分区下的文件安装情况:

total 24
drwxr-xr-x.  7 root root 4096 Jan  1 09:23 .
drwxr-xr-x   1 root root  340 Jan 27  2024 ..
drwxr-xr-x   3 root root 4096 Jan  1 09:23 bin
drwxr-xr-x  12 root root 4096 Jan  1 09:23 config_repo
drwxr-xr-x  12 root root 4096 Jan  1 09:23 etc
lrwxrwxrwx   1 root root   35 Jan  1 09:23 init.sh -> /middleware/bin/em_service_boyan.sh
drwxr-xr-x   2 root root 4096 Jan  1 09:23 lib
drwxr-xr-x   3 root root 4096 Jan  1 09:23 pub

如上,软件包完成安装,可启动软件正常运行。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mfbz.cn/a/884197.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

罕见,回复问询后闪电终止,业绩存下滑风险

《IPO魔女》认为&#xff0c;和美精艺利润低且大幅波动&#xff0c;报告期公司毛利率持续大幅下滑。而2023年同行业的上市公司均出现了业绩大幅下滑的情况&#xff0c;还未上市的和美精艺恐怕也存在业绩下滑的风险。此外&#xff0c;2020年至2022年&#xff0c;和美精艺研发投入…

docker的harbor仓库登录问题

目录 一、问题描述 二、证书信任问题 三、DNS解析问题 四、解决 参考链接&#xff1a;Docker login Harbor报错解决&#xff1a;Error response from daemon: Get https:..-阿里云开发者社区 一、问题描述 问题&#xff1a; 挂机或者挂机重启之后harbor登录不上 查看日…

【质优价廉】GAP9 AI算力处理器赋能智能可听耳机,超低功耗畅享未来音频体验!

当今世界&#xff0c;智能可听设备已经成为了流行趋势。随后耳机市场的不断成长起来&#xff0c;消费者又对AI-ANC&#xff0c;AI-ENC&#xff08;环境噪音消除&#xff09;降噪的需求逐年增加&#xff0c;但是&#xff0c;用户对于产品体验的需求也从简单的需求&#xff0c;升…

【Qt笔记】QStackedWidget控件详解

目录 引言 一、基础功能 二、属性设置 2.1 属性介绍 2.2 代码示例 2.3 代码解析 三、常用API 3.1 添加子部件 3.2 插入子部件 3.3 移除子部件 3.4 设置当前页面索引值 3.5 设置当前显示子部件 3.6 返回索引处子部件指针 3.7 返回子部件索引值 四、信号与槽 4.…

代码随想录Day 58|拓扑排序、dijkstra算法精讲,题目:软件构建、参加科学大会

提示&#xff1a;DDU&#xff0c;供自己复习使用。欢迎大家前来讨论~ 文章目录 图论part08**拓扑排序精讲**题目&#xff1a;117. 软件构建拓扑排序的背景解题思路&#xff1a;模拟过程 **dijkstra&#xff08;朴素版&#xff09;精讲**题目&#xff1a;47. 参加科学大会解题思…

OpenCV视频I/O(5)视频采集类VideoCapture之从视频流中获取下一帧的函数grab()的使用

操作系统&#xff1a;ubuntu22.04 OpenCV版本&#xff1a;OpenCV4.9 IDE:Visual Studio Code 编程语言&#xff1a;C11 算法描述 从视频文件或捕获设备中抓取下一帧。 grab() 函数是 OpenCV 中 VideoCapture 类的一个成员函数&#xff0c;用于从视频流中获取下一帧而不立即检…

Android Studio 真机USB调试运行频繁掉线问题

一、遇到问题 Android Studio使用手机运行项目时&#xff0c;总是频繁掉线&#xff0c;连接很不稳定&#xff0c;动不动就消失&#xff0c;基本上无法使用 二、问题出现原因 1、硬件问题&#xff1a;数据线 换条数据线试试&#xff0c;如果可以&#xff0c;那就是数据线的…

element plus block报错

解决&#xff1a; ::v-deep input[aria-hidden"true"] {display: none !important }

9.3 Linux_I/O_文件I/O相关函数

打开与关闭 1、打开文件 int open(const char *pathname, int flags); int open(const char *pathname, int flags, mode_t mode);返回值&#xff1a;成功返回文件描述符&#xff0c;失败返回EOF pathname&#xff1a;文件路径 flags&#xff1a;标志&#xff0c;其中O_RDO…

《面向对象是怎样工作的》笔记

6、1、在面向对象的世界中&#xff0c;我们需要事先为所有的行动准备好方法并通过消息传递来调用方法&#xff0c;这样事物才会开始运作。 2、实际上&#xff0c;类、继承和多态应该被明确定义为能提高软件的可维护性和可重用行的结构。类将变量和子程序汇总在一起&#xff0c…

Vue 技术入门 day1 模版语法、数据绑定、事件处理、计算属性与监视、class和style绑定、条件渲染v-if/v-show、列表渲染v-for

目录 1.Vue 核心 1.1. Vue 简介 1.1.1 介绍与描述 1.1.2 Vue 的特点 1.2 模板语法 1.2.1 模板的分类 1.2.2 插值语法 1.2.3 指令语法 1.2.4 实例 1.3 数据绑定 1.3.1 单向数据绑定 1.3.2 双向数据绑定 1.3.3 MVVM 模型 1.3.4 data与el的2种写法 1.3.5 实例 1.3.…

信息安全工程师(25)网络安全体系框架主要组成和建设内容

一、主要组成 信息安全战略&#xff1a;确立组织的信息安全目标和方向&#xff0c;指导整个网络安全体系的建设和运营。信息安全政策和标准&#xff1a;制定和执行一系列信息安全政策、标准和规范&#xff0c;确保网络安全活动有法可依、有章可循。信息安全管理&#xff1a;包括…

网站建设中常见的网站后台开发语言有哪几种,各自优缺点都是什么?

市场上常见的网站后台开发语言有PHP、Python、JavaScript、Ruby、Java和.NET等。这些语言各有其独特的优缺点&#xff0c;适用于不同的开发场景和需求。以下是对这些语言的具体介绍&#xff1a; PHP 优点&#xff1a;PHP是一种广泛用于Web开发的动态脚本语言&#xff0c;特别适…

《论文阅读》 用于产生移情反应的迭代联想记忆模型 ACL2024

《论文阅读》 用于产生移情反应的迭代联想记忆模型 ACL2024 前言简介任务定义模型架构Encoding Dialogue InformationCapturing Associated InformationPredicting Emotion and Generating Response损失函数问题前言 亲身阅读感受分享,细节画图解释,再也不用担心看不懂论文啦…

成都睿明智科技有限公司赋能商家高效变现

在这个日新月异的数字时代&#xff0c;抖音电商正以不可阻挡之势崛起&#xff0c;成为众多品牌与商家竞相角逐的新战场。在这片充满机遇与挑战的蓝海中&#xff0c;成都睿明智科技有限公司如同一颗璀璨新星&#xff0c;凭借其专业的服务、创新的策略和敏锐的市场洞察&#xff0…

NLP 文本分类任务核心梳理

解决思路 分解为多个独立二分类任务将多标签分类转化为多分类问题更换 loss 直接由模型进行多标签分类 数据稀疏问题 标注更多数据&#xff0c;核心解决方案&#xff1a; 自己构造训练样本 数据增强&#xff0c;如使用 chatGPT 来构造数据更换模型 减少数据需求增加规则弥补…

[element-ui]记录对el-table表头样式的一些处理

1、表头换行 & 列表项换行 可用element-table组件自带的方法实现列标题换行的效果 2、小圆点样式

第五部分:5---三张信号表,信号表的系统调用

目录 信号的递达、未决、阻塞&#xff1a; 进程维护的三张信号表&#xff1a; 普通信号与实时信号的记录&#xff1a; 信号结构的系统调用&#xff1a; bolck表的系统调用&#xff1a; 实例&#xff1a;设置屏蔽信号集中的所有信号都频闭 pending表读取&#xff1a; 信号…

计算机网络——TCP/IP网络模型

1. TCP/IP网络模型有哪几层 对于同一台设备上的进程间通信&#xff0c;有很多种方式&#xff0c;比如管道、消息队列、共享内存、信号等。而对于不同设备上的进程间通信&#xff0c;就需要网络通信&#xff0c;而设备是多样性的&#xff0c;所以要兼容多种多样的设备&#xff…

STM32快速复习(十二)FLASH闪存的读写

文章目录 一、FLASH是什么&#xff1f;FLASH的结构&#xff1f;二、使用步骤1.标准库函数2.示例函数 总结 一、FLASH是什么&#xff1f;FLASH的结构&#xff1f; 1、FLASH简介 &#xff08;1&#xff09;STM32F1系列的FLASH包含程序存储器、系统存储器和选项字节三个部分&…