需求背景:公司内网不能联网,同时开发工作需要各种python的模块,因此需要搭建一个pypi的本地镜像源。
参考网上的方法,总结了大致有下面几种方式搭建pypi本地源:
最终选择了bandersnatch,主要理由是前面几种基本采用的是缓存机制,安装或者下载模块后缓存在本地,在没有网络的环境下一旦部署很容易出现需要的模块没有被缓存,重新添加比较麻烦,当然前面几种的好处就是比较节省硬盘空间。
pypi 全部资源量非常巨大,截至目前已经达到9.4T(20211026),我准备了11T的硬盘空间,
查询所需要的空间: Statistics · PyPI
根据官方的文档:bandersnatch · PyPI
安装的方式有多种,我采用的是docker 的部署方式。
docker pull pypa/bandersnatch
$ sudo docker run -it -v /srv/pypi:/srv/pypi pypa/bandersnatch:latest bash #我本地硬盘mount到了/srv/pypi
root@97a753fce661:/bandersnatch# bandersnatch mirror
2021-10-26 13:12:53,502 WARNING: Config file '/etc/bandersnatch.conf' missing, creating default config. (main.py:200)
2021-10-26 13:12:53,502 WARNING: Please review the config file, then run 'bandersnatch' again. (main.py:201)
directory = /srv/pypi
首先还是需要执行bandersnatch mirror直到开始下载文件,此时会生成todo文件(必须需要有该文件),按ctrl+c取消mirror.
root@97a753fce661:/bandersnatch# ls -l /srv/pypi/
total 7220
-rw------- 1 root root 1 Oct 26 11:56 generation
-rw------- 1 root root 7381714 Oct 26 12:16 todo
drwxr-xr-x 5 root root 4096 Oct 26 11:56 web
修改/etc/bandersnatch.conf中的下面内容,为何不一开始就替换为国内源呢?是因为常用的国内源似乎暂不支持xmlrpc服务,导致无法获取到文件元数据信息,只好先从官网获取元数据信息,获取到以后再换成国内源进行下载。
download-mirror = https://pypi.doubanio.com/
download-mirror-no-fallback = False
同时我在该文件中增加了过滤,去除超大文件的下载,过滤选项可参考:Mirror filtering — bandersnatch 5.0.0 documentation
[plugins]
enabled =
size_project_metadata
[size_project_metadata]
max_package_size = 10G
[plugins]
enabled =
allowlist_project
[allowlist]
packages =
numpy
因为我剩余空间还比较多,我将过滤package大小设置成了100G,且只下载最新的20次版本,当然我们也可以一开始就可以设置要下载的版本数量,全部下载似乎的确没必要且占空间
[plugins]
enabled =
size_project_metadata
latest_release
[latest_release]
keep = 20
[size_project_metadata]
max_package_size = 100G
安装apache,提供http服务
apt-get install -y apache2
cd /var/www/html/
rm -rf index.html
ln -s /srv/pypi/web pypi
或者配置~/.pip/pip.conf文件
|