如何在 CentOS 上托管 deb/apt 存储库?

San*_*dra 7 linux ubuntu debian centos

我想为 Ubuntu Precise 制作一个 Puppet 客户端及其依赖项的镜像,但托管在我的 CentOS 6 主机上。

如果我做

cd /var/ftp
wget -A deb -r -np -nH --cut-dirs=1 http://apt.puppetlabs.com/pool/precise/dependencies/
wget -A deb -r -np -nH --cut-dirs=1 http://apt.puppetlabs.com/pool/precise/main/
Run Code Online (Sandbox Code Playgroud)

然后在 Ubuntu Precise 上添加以下内容 /etc/yum.repos.d/mypuppet.repo

deb ftp://puppet.example.com precise main
deb ftp://puppet.example.com precise dependencies
Run Code Online (Sandbox Code Playgroud)

然后我得到

W: Failed to fetch ftp://puppet.example.com/dists/precise/dependencies/binary-amd64/Packages  Unable to fetch file, server said 'Failed to open file.  '
Run Code Online (Sandbox Code Playgroud)

是否有关于如何在 CentOS 上托管 deb/apt 存储库的工具或方法?

daw*_*wud 7

我想说这个任务的合适工具是debmirror(1),它可以在 CentOS 存储库中找到。

确保从密钥服务器导入 puppetlabs 存储库的 GPG 密钥:

# gpg --recv-keys 1054B7A24BD6EC30
gpg: requesting key 4BD6EC30 from hkp server pool.sks-keyservers.net
gpg: key 4BD6EC30: public key "Puppet Labs Release Key (Puppet Labs Release Key) <info@puppetlabs.com>" imported
gpg: 3 marginal(s) needed, 1 complete(s) needed, classic trust model
gpg: depth: 0  valid:   3  signed:   4  trust: 0-, 0q, 0n, 0m, 0f, 3u
gpg: depth: 1  valid:   4  signed:   6  trust: 3-, 0q, 0n, 0m, 1f, 0u
gpg: depth: 2  valid:   1  signed:   1  trust: 1-, 0q, 0n, 0m, 0f, 0u
gpg: next trustdb check due at 2014-05-11
gpg: Total number processed: 1
gpg:               imported: 1  (RSA: 1)
Run Code Online (Sandbox Code Playgroud)

然后,从他们的存储库中获取包:

# debmirror --check-gpg --keyring=/path/to/keyring.gpg --method=http \ 
  --root=/ --arch amd64 --dist precise --section main,dependencies   \
  --nosource --host apt.puppetlabs.com --progress /path/to/local/repo
Run Code Online (Sandbox Code Playgroud)

这样您就可以确保目录结构正确并且所有预期的文件都存在。