使用bandersnatch搭建pypi 本地镜像源(20211026)

2023-11-02 12:50

本文主要是介绍使用bandersnatch搭建pypi 本地镜像源(20211026),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

需求背景:公司内网不能联网,同时开发工作需要各种python的模块,因此需要搭建一个pypi的本地镜像源。

参考网上的方法,总结了大致有下面几种方式搭建pypi本地源:

  • devpi: 企业内网利用devpi搭建pypi私服 - 简书
  • pip2pi: https://yangfannie.com/1439.html
  • pypiserver: https://zhongneng.github.io/2019/02/16/creat-pip/
  • bandersnatch: 基于bandersnatch搭建pip本地源_永不消逝的记忆-CSDN博客

最终选择了bandersnatch,主要理由是前面几种基本采用的是缓存机制,安装或者下载模块后缓存在本地,在没有网络的环境下一旦部署很容易出现需要的模块没有被缓存,重新添加比较麻烦,当然前面几种的好处就是比较节省硬盘空间。


准备工作

pypi 全部资源量非常巨大,截至目前已经达到9.4T(20211026),我准备了11T的硬盘空间,

查询所需要的空间: Statistics · PyPI

安装

根据官方的文档:bandersnatch · PyPI

安装的方式有多种,我采用的是docker 的部署方式。

docker pull pypa/bandersnatch

配置和部署:

  • 启动docker 镜像
$ sudo docker run -it -v /srv/pypi:/srv/pypi pypa/bandersnatch:latest bash #我本地硬盘mount到了/srv/pypi
  • 第一次执行bandersnatch mirror会生成/etc/bandersnatch.conf
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)
  • 编辑 /etc/bandersnatch.conf文件,主要是修改一下存放文件的路径
directory = /srv/pypi
  • 再次执行bandersnatch mirror,开始mirror。(国内从官网下载文件,速度较慢且不稳定,如果网速能接受等待全部下载完即可)
  • 如果发现从官网下载速度或者稳定性欠佳,可修改成国内源下载文件。

        首先还是需要执行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

  •         修改完成后执行bandersnatch mirror,就会发现使用豆瓣源下载文件了,速度有了大幅提升。

      

  • 经过漫长的下载(一周的时间),终于下载完成了,下载了5T多,因为设置了10G以上不下载,部分常用的没有下载下来,例如numpy,panda等,可以在/etc/bandersnatch.conf设置白名单,例如:
    [plugins]
    enabled =allowlist_project[allowlist]
    packages =numpy

    因为我剩余空间还比较多,我将过滤package大小设置成了100G,且只下载最新的20次版本,当然我们也可以一开始就可以设置要下载的版本数量,全部下载似乎的确没必要且占空间

    [plugins]
    enabled =size_project_metadatalatest_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 install <package> -i http://xx.xx.xx.xx/pypi/simple/ --trusted-host xx.xx.xx.xx
  • 或者配置~/.pip/pip.conf文件

    root@743d3aff75df:~/.pip# cat ~/.pip/pip.conf

    [global]

    index-url = http://xx.xx.xx.xx/pypi/simple

    [install]

    trusted-host=xx.xx.xx.xx 

这篇关于使用bandersnatch搭建pypi 本地镜像源(20211026)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/330709

相关文章

中文分词jieba库的使用与实景应用(一)

知识星球:https://articles.zsxq.com/id_fxvgc803qmr2.html 目录 一.定义: 精确模式(默认模式): 全模式: 搜索引擎模式: paddle 模式(基于深度学习的分词模式): 二 自定义词典 三.文本解析   调整词出现的频率 四. 关键词提取 A. 基于TF-IDF算法的关键词提取 B. 基于TextRank算法的关键词提取

使用SecondaryNameNode恢复NameNode的数据

1)需求: NameNode进程挂了并且存储的数据也丢失了,如何恢复NameNode 此种方式恢复的数据可能存在小部分数据的丢失。 2)故障模拟 (1)kill -9 NameNode进程 [lytfly@hadoop102 current]$ kill -9 19886 (2)删除NameNode存储的数据(/opt/module/hadoop-3.1.4/data/tmp/dfs/na

Hadoop数据压缩使用介绍

一、压缩原则 (1)运算密集型的Job,少用压缩 (2)IO密集型的Job,多用压缩 二、压缩算法比较 三、压缩位置选择 四、压缩参数配置 1)为了支持多种压缩/解压缩算法,Hadoop引入了编码/解码器 2)要在Hadoop中启用压缩,可以配置如下参数

Makefile简明使用教程

文章目录 规则makefile文件的基本语法:加在命令前的特殊符号:.PHONY伪目标: Makefilev1 直观写法v2 加上中间过程v3 伪目标v4 变量 make 选项-f-n-C Make 是一种流行的构建工具,常用于将源代码转换成可执行文件或者其他形式的输出文件(如库文件、文档等)。Make 可以自动化地执行编译、链接等一系列操作。 规则 makefile文件

使用opencv优化图片(画面变清晰)

文章目录 需求影响照片清晰度的因素 实现降噪测试代码 锐化空间锐化Unsharp Masking频率域锐化对比测试 对比度增强常用算法对比测试 需求 对图像进行优化,使其看起来更清晰,同时保持尺寸不变,通常涉及到图像处理技术如锐化、降噪、对比度增强等 影响照片清晰度的因素 影响照片清晰度的因素有很多,主要可以从以下几个方面来分析 1. 拍摄设备 相机传感器:相机传

pdfmake生成pdf的使用

实际项目中有时会有根据填写的表单数据或者其他格式的数据,将数据自动填充到pdf文件中根据固定模板生成pdf文件的需求 文章目录 利用pdfmake生成pdf文件1.下载安装pdfmake第三方包2.封装生成pdf文件的共用配置3.生成pdf文件的文件模板内容4.调用方法生成pdf 利用pdfmake生成pdf文件 1.下载安装pdfmake第三方包 npm i pdfma

零基础学习Redis(10) -- zset类型命令使用

zset是有序集合,内部除了存储元素外,还会存储一个score,存储在zset中的元素会按照score的大小升序排列,不同元素的score可以重复,score相同的元素会按照元素的字典序排列。 1. zset常用命令 1.1 zadd  zadd key [NX | XX] [GT | LT]   [CH] [INCR] score member [score member ...]

搭建Kafka+zookeeper集群调度

前言 硬件环境 172.18.0.5        kafkazk1        Kafka+zookeeper                Kafka Broker集群 172.18.0.6        kafkazk2        Kafka+zookeeper                Kafka Broker集群 172.18.0.7        kafkazk3

git使用的说明总结

Git使用说明 下载安装(下载地址) macOS: Git - Downloading macOS Windows: Git - Downloading Windows Linux/Unix: Git (git-scm.com) 创建新仓库 本地创建新仓库:创建新文件夹,进入文件夹目录,执行指令 git init ,用以创建新的git 克隆仓库 执行指令用以创建一个本地仓库的

【IPV6从入门到起飞】5-1 IPV6+Home Assistant(搭建基本环境)

【IPV6从入门到起飞】5-1 IPV6+Home Assistant #搭建基本环境 1 背景2 docker下载 hass3 创建容器4 浏览器访问 hass5 手机APP远程访问hass6 更多玩法 1 背景 既然电脑可以IPV6入站,手机流量可以访问IPV6网络的服务,为什么不在电脑搭建Home Assistant(hass),来控制你的设备呢?@智能家居 @万物互联