推荐学习书目
Learn Python the Hard Way
Python Sites
PyPI - Python Package Index
http://diveintopython.org/toc/index.html
Pocoo
值得关注的项目
PyPy
Celery
Jinja2
Read the Docs
gevent
pyenv
virtualenv
Stackless Python
Beautiful Soup
结巴中文分词
Green Unicorn
Sentry
Shovel
Pyflakes
pytest
Python 编程
pep8 Checker
Styles
PEP 8
Google Python Style Guide
Code Style from The Hitchhiker's Guide
g632104866
V2EX  ›  Python

使用 kkRepo 搭建 Python PyPI 私服

  •  
  •   g632104866 · 1 day ago · 902 views

    在 Python 项目中,PyPI 私服通常承担两个角色:一是托管公司内部的 Python 包,二是代理和缓存 PyPI 官方仓库的第三方依赖。这样既能让 CI/CD 发布内部包有统一入口,也能减少公网网络波动对 pip install 的影响。

    kkRepo 是一个兼容 Nexus 客户端访问习惯的自托管制品仓库,支持 Maven 、npm 、PyPI 、Go 、Helm 、Docker/OCI 等多种制品格式。对于 PyPI 场景,它支持 hosted 、proxy 和 group 仓库,并保留常见的 /repository/<repo>/... URL 结构,方便从 Nexus 迁移或替换。

    一、快速启动 kkRepo

    本地体验可以直接使用官方 quickstart 脚本,它会拉起 kkRepo 和 MySQL:

    curl -fsSL https://raw.githubusercontent.com/klboke/kkrepo/main/scripts/quickstart.sh | bash
    

    启动完成后访问:

    管理控制台: http://127.0.0.1:19090/admin/
    用户侧浏览器: http://127.0.0.1:19090/browse/
    健康检查: http://127.0.0.1:19091/actuator/health
    

    首次进入管理控制台时,需要创建初始 Local/admin 管理员密码。

    本地 quickstart 默认使用 File blob storage ,适合试用和开发验证。生产环境建议使用独立 MySQL ,并将 blob 存储切换为 OSS/S3 。

    二、创建 PyPI 仓库

    进入 /admin/ 后,建议按 PyPI 常见用法创建三类仓库:

    pypi-hosted    hosted ,用于发布公司内部 Python 包
    pypi-proxy     proxy ,用于代理 PyPI 官方仓库
    pypi-group     group ,用于 pip 安装依赖的统一入口
    

    创建 pypi-proxy proxy 仓库时,上游地址可以填写 PyPI 官方 simple index 地址:

    https://pypi.org/simple/
    

    创建 pypi-group group 仓库时,把下面几个成员仓库加入 group:

    pypi-hosted
    pypi-proxy
    

    这样客户端只需要从 pypi-group 一个地址安装依赖:公司内部发布到私服的包会从 pypi-hosted 命中,第三方开源依赖会通过 pypi-proxy 回源并缓存。发布时仍然写入 pypi-hosted

    img img2

    9 replies    2026-06-27 01:34:18 +08:00
    jackOff
        1
    jackOff  
       1 day ago
    pypi 缓存代理和 maven 缓存代理是什么很困难的技术吗? ai 生成一下的事情
    g632104866
        2
    g632104866  
    OP
       1 day ago
    @jackOff 你的问题和主题好像没什么关系啊,另外好奇你们现在是怎么用的,用 AI 生成的吗?还是用的 Nexus 的
    g632104866
        3
    g632104866  
    OP
       1 day ago
    kkRepo 是为了解决 sonatype nexus3 痛点问题而开发开源的,解决的问题包括但不限于:
    1 、nexus 内嵌 OrientDB 、ElasticSearch ,进程很重,容易崩溃
    2 、nexus 不支持多副本高可用部署
    3 、nexus 最新的免费版本限制了维护的包个数,也限制每天的请求量,几乎没法用 。
    另外,Nexus 源代码是不开放的,PRO 版本也非常贵。
    han1988
        4
    han1988  
       1 day ago
    大佬,能不能兼容 Harbor 的 API 。好多开源项目对接的容器镜像仓库都是它。Nexu 免费版限制太多,用作容器仓库的少。
    g632104866
        5
    g632104866  
    OP
       1 day ago
    @han1988 kkRepo 已经支持 Docker/OCI 仓库了,已经包含了 docker login 、docker pull 、docker push 、manifest 、blob 、tag 、OCI referrers 、hosted/proxy/group 这些能力
    HappyAndSmile
        6
    HappyAndSmile  
       23h 51m ago
    比较好奇之前 python 没这种类似的开源项目?
    han1988
        7
    han1988  
       23h 49m ago
    @g632104866 这些知道有。需要的是兼容 Harbor REST API

    https://goharbor.io/docs/2.5.0/working-with-projects/using-api-explorer/
    g632104866
        8
    g632104866  
    OP
       23h 32m ago
    @han1988 懂了,这个需求先收了,我先了解了解
    yijiangchengming
        9
    yijiangchengming  
       14h 37m ago
    已 Start 期待 Rust 和 APT 仓库代理支持,前几天部署 gitea action 不知道为什么网络不行,总是拉取失败,部署了 nexus3 才拉取成功。
    About   ·   Help   ·   Advertise   ·   Blog   ·   API   ·   FAQ   ·   Solana   ·   3034 Online   Highest 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 44ms · UTC 08:11 · PVG 16:11 · LAX 01:11 · JFK 04:11
    ♥ Do have faith in what you're doing.