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

发布于:2025-03-19 ⋅ 阅读:(13) ⋅ 点赞:(0)

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


步骤 1:准备依赖工具

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

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

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

sudo mkdir -p /var/my-repo
cp /path/to/debs/*.deb /var/my-repo/

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

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

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

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

# 安装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,添加:

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

更新APT缓存:

sudo apt-get update

步骤 6:测试安装软件

sudo apt-get install <包名>

可选优化

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

    #!/bin/bash
    cd /var/my-repo
    dpkg-scanpackages . /dev/null | gzip -9c > Packages.gz
    
  2. 签名仓库(安全增强)
    使用GPG签名仓库(需配置密钥):

    apt-get install gnupg
    gpg --gen-key
    dpkg-scanpackages . | gzip -9c > Packages.gz
    gpg --armor --export <KEY-ID> > public.key
    
  3. 使用更专业的工具
    使用 reprepro 管理复杂仓库:

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

常见问题

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

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