0

0

如何使用Satis只镜像你需要的Composer包_构建一个轻量级的公司内部Composer代理

穿越時空

穿越時空

发布时间:2025-11-30 15:17:45

|

381人浏览过

|

来源于php中文网

原创

Satis是Composer官方推荐的轻量级私有仓库生成工具,通过配置satis.json指定需镜像的包(如doctrine/orm、guzzlehttp/guzzle等),结合require-all设为false实现精准控制,避免全量同步;利用satis build命令生成包含packages.json和dist文件的静态仓库,部署至内网Web服务器后,客户端通过添加仓库URL或全局配置优先使用内部源,提升安装速度并减少外部依赖,适合企业级PHP依赖管理。

如何使用satis只镜像你需要的composer包_构建一个轻量级的公司内部composer代理

在公司内部搭建一个轻量级的 Composer 代理,既能提升依赖安装速度,又能避免对 packagist.org 的频繁请求,还能精确控制哪些包可以被使用。Satis 正是为此设计的工具——它是一个静态的 Composer 仓库生成器,能让你只镜像需要的包,而不是整个 Packagist。

什么是 Satis?

Satis 是 Composer 官方推荐的一个工具,用于构建私有的、精简的 Composer 镜像仓库。它不像完全镜像那样同步所有包,而是根据你配置的规则,只抓取指定的包及其版本,生成一个 packages.json 文件供 Composer 使用。

这意味着你可以:

  • 只允许团队使用经过审核的开源包
  • 缓存常用包以加快 CI/CD 和本地安装速度
  • 减少对外部网络的依赖
  • 托管私有包(配合 artifact 或 VCS)

安装与初始化 Satis

通过 Composer 全局或项目方式安装 Satis:

composer global require composer/satis

确保 ~/.composer/vendor/bin 在你的 PATH 中,以便使用 satis 命令。

初始化配置文件

satis init

这会生成一个默认的 satis.json 文件。

配置只镜像你需要的包

编辑 satis.json,明确列出你需要的包。例如:

{ "name": "My Company Composer Repository", "homepage": "https://packages.mycompany.com", "repositories": [ { "type": "vcs", "url": "https://github.com/doctrine/orm" }, { "type": "vcs", "url": "https://github.com/guzzle/guzzle" }, { "type": "vcs", "url": "https://github.com/symfony/http-foundation" } ], "require-all": false, "require": { "doctrine/orm": "^2.10", "guzzlehttp/guzzle": "^7.4", "symfony/http-foundation": "^6.0" }, "output-dir": "web" }

关键点说明:

  • repositories:声明源,支持 VCS、artifact、composer 等类型
  • require:精确控制你要镜像的包和版本约束
  • require-all:设为 false 表示只处理 require 中列出的包,不递归抓取全部依赖
  • output-dir:生成的静态文件目录,通常设为 web 可访问路径

生成静态仓库

运行构建命令:

satis build satis.json .

Satis 会:

码上飞
码上飞

码上飞(CodeFlying) 是一款AI自动化开发平台,通过自然语言描述即可自动生成完整应用程序。

下载
  • 克隆或下载你指定的包
  • 分析其 composer.json
  • 提取元数据并写入 web/packages.json
  • 将实际的 dist 文件(zip/tar)复制到 web/dist/ 目录

完成后,web/ 目录就是一个完整的静态 Composer 仓库。

部署为内部代理服务

web/ 目录部署到公司内网 Web 服务器,比如 Nginx:

server { listen 80; server_name packages.mycompany.com; root /var/www/satis/web; index index.html; autoindex off; }

确保 PHP 不需要执行,这只是静态文件服务。

客户端使用你的 Satis 仓库

在项目 composer.json 中添加仓库:

{ "repositories": [ { "type": "composer", "url": "https://packages.mycompany.com" } ] }

或者全局设置(推荐给所有员工):

composer config -g repositories.company composer https://packages.mycompany.com

这样 Composer 会优先从你的 Satis 源查找包,未命中时才会回退到 packagist.org(除非你设置 "packagist.org": false 来禁用)。

自动化更新

建议通过 CI/CD 或定时任务定期重建仓库:

# crontab -e 0 3 * * * cd /path/to/satis && satis build satis.json . >> build.log 2>&1

也可以结合 webhook,在你关注的包有新版本时触发重建。

基本上就这些。Satis 虽然功能简单,但非常适合构建轻量、可控的内部 Composer 代理。不复杂但容易忽略的是:一定要关掉 require-all,否则可能意外拉取成千上万个包,失去“轻量”的意义。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
PHP Symfony框架
PHP Symfony框架

本专题专注于PHP主流框架Symfony的学习与应用,系统讲解路由与控制器、依赖注入、ORM数据操作、模板引擎、表单与验证、安全认证及API开发等核心内容。通过企业管理系统、内容管理平台与电商后台等实战案例,帮助学员全面掌握Symfony在企业级应用开发中的实践技能。

78

2025.09.11

composer是什么插件
composer是什么插件

Composer是一个PHP的依赖管理工具,它可以帮助开发者在PHP项目中管理和安装依赖的库文件。Composer通过一个中央化的存储库来管理所有的依赖库文件,这个存储库包含了各种可用的依赖库的信息和版本信息。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

153

2023.12.25

nginx 重启
nginx 重启

nginx重启对于网站的运维来说是非常重要的,根据不同的需求,可以选择简单重启、平滑重启或定时重启等方式。本专题为大家提供nginx重启的相关的文章、下载、课程内容,供大家免费下载体验。

233

2023.07.27

nginx 配置详解
nginx 配置详解

Nginx的配置是指设置和调整Nginx服务器的行为和功能的过程。通过配置文件,可以定义虚拟主机、HTTP请求处理、反向代理、缓存和负载均衡等功能。Nginx的配置语法简洁而强大,允许管理员根据自己的需要进行灵活的调整。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

502

2023.08.04

nginx配置详解
nginx配置详解

NGINX与其他服务类似,因为它具有以特定格式编写的基于文本的配置文件。本专题为大家提供nginx配置相关的文章,大家可以免费学习。

500

2023.08.04

tomcat和nginx有哪些区别
tomcat和nginx有哪些区别

tomcat和nginx的区别:1、应用领域;2、性能;3、功能;4、配置;5、安全性;6、扩展性;7、部署复杂性;8、社区支持;9、成本;10、日志管理。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

233

2024.02.23

nginx报404怎么解决
nginx报404怎么解决

当访问 nginx 网页服务器时遇到 404 错误,表明服务器无法找到请求资源,可以通过以下步骤解决:1. 检查文件是否存在且路径正确;2. 检查文件权限并更改为 644 或 755;3. 检查 nginx 配置,确保根目录设置正确、没有冲突配置等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

339

2024.07.09

Nginx报404错误解决方法
Nginx报404错误解决方法

解决方法:只需要加上这段配置:try_files $uri $uri/ /index.html;即可。想了解更多Nginx的相关内容,可以阅读本专题下面的文章。

3517

2024.08.07

俄罗斯Yandex引擎入口
俄罗斯Yandex引擎入口

2026年俄罗斯Yandex搜索引擎最新入口汇总,涵盖免登录、多语言支持、无广告视频播放及本地化服务等核心功能。阅读专题下面的文章了解更多详细内容。

158

2026.01.28

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
第二十四期_PHP8编程
第二十四期_PHP8编程

共86课时 | 3.4万人学习

成为PHP架构师-自制PHP框架
成为PHP架构师-自制PHP框架

共28课时 | 2.5万人学习

第二十三期_PHP编程
第二十三期_PHP编程

共93课时 | 6.9万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号