在麒麟系统(基于Ubuntu或Debuntu)的离线环境中创建本地APT仓库

在麒麟系统(基于Ubuntu或Debuntu)的离线环境中创建本地APT仓库,可以按照以下步骤操作:


步骤 1:准备依赖工具

bash 复制代码
# 安装生成仓库元数据的工具
sudo apt-get install dpkg-dev

步骤 2:收集所有需要的DEB包

将离线环境所需的.deb软件包(包括依赖包)复制到一个目录中,例如:

bash 复制代码
sudo mkdir -p /var/my-repo
cp /path/to/debs/*.deb /var/my-repo/

步骤 3:生成APT仓库元数据

bash 复制代码
cd /var/my-repo
# 生成 Packages.gz 文件
dpkg-scanpackages . /dev/null | gzip -9c > Packages.gz

步骤 4(可选):配置HTTP访问

如果其他机器需要通过HTTP访问仓库:

bash 复制代码
# 安装Nginx
sudo apt-get install nginx
# 将仓库目录链接到Nginx的Web根目录
sudo ln -s /var/my-repo /var/www/html/myrepo
# 重启Nginx
sudo systemctl restart nginx

步骤 5:配置客户端使用本地仓库

在需要访问仓库的机器上,编辑 /etc/apt/sources.list,添加:

bash 复制代码
# 文件路径方式(仅本机)
deb [trusted=yes] file:/var/my-repo ./
# 或HTTP方式(其他机器)
deb [trusted=yes] http://<服务器IP>/myrepo ./

更新APT缓存:

bash 复制代码
sudo apt-get update

步骤 6:测试安装软件

bash 复制代码
sudo apt-get install <包名>

可选优化

  1. 自动化脚本

    创建脚本 update-repo.sh,自动更新元数据:

    bash 复制代码
    #!/bin/bash
    cd /var/my-repo
    dpkg-scanpackages . /dev/null | gzip -9c > Packages.gz
  2. 签名仓库(安全增强)

    使用GPG签名仓库(需配置密钥):

    bash 复制代码
    apt-get install gnupg
    gpg --gen-key
    dpkg-scanpackages . | gzip -9c > Packages.gz
    gpg --armor --export <KEY-ID> > public.key
  3. 使用更专业的工具

    使用 reprepro 管理复杂仓库:

    bash 复制代码
    sudo apt-get install reprepro
    mkdir -p /var/my-repo/conf
    # 创建配置文件 /var/my-repo/conf/distributions

常见问题

  • 依赖缺失 :确保所有依赖的.deb包已包含在仓库中。
  • 权限问题:确保仓库目录的读取权限(HTTP服务需开放访问)。
  • 路径错误 :检查 sources.list 中的路径是否正确。

通过以上步骤,您可以在离线环境中快速搭建一个APT仓库,支持软件包的本地分发和安装。

相关推荐
JuiceFS12 小时前
从 MLPerf Storage v2.0 看 AI 训练中的存储性能与扩展能力
运维·后端
CYRUS_STUDIO16 小时前
用 Frida 控制 Android 线程:kill 命令、挂起与恢复全解析
android·linux·逆向
熊猫李17 小时前
rootfs-根文件系统详解
linux
chen94518 小时前
mysql 3节点mgr集群部署
运维·后端
LH_R19 小时前
OneTerm开源堡垒机实战(三):功能扩展与效率提升
运维·后端·安全
dessler20 小时前
Hadoop HDFS-高可用集群部署
linux·运维·hdfs
泽泽爱旅行20 小时前
awk 语法解析-前端学习
linux·前端
少妇的美梦2 天前
logstash教程
运维
chen9452 天前
k8s集群部署vector日志采集器
运维
chen9452 天前
aws ec2部署harbor,使用s3存储
运维