0

0

composer如何在内网环境中使用?

穿越時空

穿越時空

发布时间:2026-02-22 15:55:03

|

489人浏览过

|

来源于php中文网

原创

内网使用composer需配置代理或离线方案:有代理时用composer config -g http-proxy设置;无网络则用artifact源预下载包,或搭satis镜像站;务必确保php版本、扩展及composer.lock平台约束与内网环境一致。

composer如何在内网环境中使用?

composer 在内网环境中能用,但默认完全不可用——它会卡在连接 packagist.org 上,报错类似 Could not fetch https://packagist.org/packages.json 或直接超时。必须人工接管网络路径,核心就两条路:走代理(有出口)或彻底离线(无出口)。

有 HTTP 代理时:全局配 http-proxy 最省事

内网能连公司统一代理(比如 http://10.1.1.100:8080),就别折腾环境变量或改 PHP 配置,直接让 Composer 自己记下来:

  • 运行 composer config -g http-proxy http://10.1.1.100:8080,配置写入 ~/.composer/config.json(Windows 是 %APPDATA%\Composer\config.json
  • 验证是否生效:composer diagnose 输出里应看到 HTTP proxy: http://10.1.1.100:8080
  • 若代理要账号密码,格式是 http://user:pass@10.1.1.100:8080,注意 @: 等特殊字符得 URL 编码(如 user%40domain:P%40ssw0rd
  • 不支持 SOCKS、不支持 HTTPS 代理地址(https://... 开头会失败),别试

常见翻车点:运维给的地址带 https 前缀,或者漏了端口;还有人把 https-proxy 当成必须项配了,其实 Composer 不强制要求——它 fallback 到 HTTP 就行。

完全断网时:用 artifact 源 + 预下载包最可靠

没代理、没外网,唯一办法是把依赖包提前打包好,运进来。别信“复制 vendor 目录”这种懒办法——composer install 会校验 composer.lock 和平台约束,缺一个 ZIP 包就停住。

  • 在外网机器上,确保项目有 composer.lock,执行:composer install --no-dev --prefer-dist --no-autoloader --no-scripts,触发所有包下载到缓存目录(~/.composer/cache/files/
  • 把整个 files/ 目录拷进内网,在项目根目录建 artifacts/ 文件夹,把里面所有 .zip 文件放进去
  • 修改项目 composer.json,加一段仓库配置:
    {"repositories": [{"type": "artifact", "url": "./artifacts/"}]}
  • 内网执行:composer install --no-dev --prefer-dist --no-autoloader --no-scripts,Composer 会从 artifacts/ 找包,不发任何网络请求

关键细节:--no-autoloader 避免因缺 ext-zip 等扩展而失败;--prefer-dist 强制走 ZIP 包,不走 Git 克隆;artifacts/ 必须是相对路径,不能写绝对路径。

mallcloud商城
mallcloud商城

mallcloud商城基于SpringBoot2.x、SpringCloud和SpringCloudAlibaba并采用前后端分离vue的企业级微服务敏捷开发系统架构。并引入组件化的思想实现高内聚低耦合,项目代码简洁注释丰富上手容易,适合学习和企业中使用。真正实现了基于RBAC、jwt和oauth2的无状态统一权限认证的解决方案,面向互联网设计同时适合B端和C端用户,支持CI/CD多环境部署,并提

下载

长期用内网:搭个 Satis 静态镜像站更可持续

单个项目偶尔离线,artifact 够用;但团队多个项目、要频繁更新依赖,就得建本地镜像源。Satis 是 Composer 官方推荐的轻量方案,不依赖数据库,纯静态文件,Nginx 一扔就能用。

  • 在外网机器装 Satis:composer create-project composer/satis
  • satis.json,明确列出要同步的包(别开 "require-all": true,全量同步几百 G,没人受得了)
  • 运行:php bin/satis build satis.json web/,生成 packages.json 和所有 ZIP 包
  • web/ 整个目录放到内网服务器(比如 http://192.168.10.100),确保能直接访问到 http://192.168.10.100/packages.json
  • 内网机器全局设源:composer config -g repos.packagist '{"type":"composer","url":"http://192.168.10.100"}'

注意:packages.json 必须能被 GET 到,别用带身份验证的 Web 目录;Satis 不会自动同步新版本,得定期手动跑 satis build 更新。

容易忽略的坑:composer.lock 和 PHP 平台约束必须严丝合缝

内网部署失败,八成不是网络问题,而是 composer.lock 和目标机器不匹配。Composer 会检查 PHP 版本、扩展、架构,差一点就拒绝安装。

  • 检查 composer.lock 里的 "platform" 字段,例如:"php": "8.2.10",必须和内网机器 php -v 输出一致
  • 确认内网机器装了 ext-zipext-curlext-json —— 缺一个,composer install 可能中途报错退出
  • composer.lock 中每个包的 dist.url 应该是稳定镜像地址(如阿里云),而不是 GitHub raw 链接;后者离线时无法校验 SHA256,直接失败
  • 打包传输 vendor/?别干这事。权限丢失、符号链接损坏、平台相关二进制(如 bin/phpunit)可能无法执行

真正稳妥的做法,永远是在跟目标环境一致的机器上,用 composer install --prefer-dist 生成原始 vendor/,再打包。不是“复制”,是“复现”。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
composer是什么插件
composer是什么插件

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

159

2023.12.25

nginx 重启
nginx 重启

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

240

2023.07.27

nginx 配置详解
nginx 配置详解

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

517

2023.08.04

nginx配置详解
nginx配置详解

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

567

2023.08.04

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

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

242

2024.02.23

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

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

561

2024.07.09

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

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

3606

2024.08.07

nginx部署php项目教程汇总
nginx部署php项目教程汇总

本专题整合了nginx部署php项目教程汇总,阅读专题下面的文章了解更多详细内容。

49

2026.01.13

pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法
pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法

本专题系统整理pixiv网页版官网入口及登录访问方式,涵盖官网登录页面直达路径、在线阅读入口及快速进入方法说明,帮助用户高效找到pixiv官方网站,实现便捷、安全的网页端浏览与账号登录体验。

1030

2026.02.13

热门下载

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

精品课程

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

共86课时 | 3.4万人学习

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

共28课时 | 2.6万人学习

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

共93课时 | 7.2万人学习

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

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