在麒麟系统(基于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仓库,支持软件包的本地分发和安装。

相关推荐
chiou72212 分钟前
为 Ubuntu 安装的软件创建桌面图标
linux·ubuntu·lua
binary思维20 分钟前
Ubuntu挂起和休眠
linux·运维·ubuntu
初叶 crmeb38 分钟前
JAVA单商户易联云小票打印替换模板
java·linux·python
qq_4474294140 分钟前
数据结构与算法:图论——拓扑排序
linux·c语言·学习·图论
緈福的街口41 分钟前
【leetcode】459.重复的子字符串
linux·算法·leetcode
某不知名網友1 小时前
linux信号详解
linux·运维·服务器
Logan Lie1 小时前
Linux运维笔记:服务器安全加固
linux·运维·服务器·安全
ROC_bird..1 小时前
linux——文件系统
linux
UFIT1 小时前
使用Haproxy搭建Web群集
linux·运维
会飞的土拨鼠呀1 小时前
监控 100 台服务器磁盘内存CPU利用率
运维·服务器