Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/zencodex/composer-mirror
Composer 全量镜像发布于2017年3月,曾不间断运行2年多。这个开源有助于理解 Composer 镜像的工作原理
https://github.com/zencodex/composer-mirror
composer flysystem mirror packagist upyun
Last synced: 2 days ago
JSON representation
Composer 全量镜像发布于2017年3月,曾不间断运行2年多。这个开源有助于理解 Composer 镜像的工作原理
- Host: GitHub
- URL: https://github.com/zencodex/composer-mirror
- Owner: zencodex
- Created: 2019-05-23T11:41:19.000Z (over 5 years ago)
- Default Branch: master
- Last Pushed: 2023-09-14T04:08:56.000Z (over 1 year ago)
- Last Synced: 2025-01-03T23:11:30.712Z (9 days ago)
- Topics: composer, flysystem, mirror, packagist, upyun
- Language: PHP
- Homepage:
- Size: 194 KB
- Stars: 594
- Watchers: 13
- Forks: 73
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
- php-awesome - ZComposer - Composer 镜像,有助于了解 Composer 镜像的原理 (Composer / PRC)
README
[![stars](https://img.shields.io/github/stars/zencodex/composer-mirror.svg)](https://github.com/zencodex/composer-mirror)
[![forks](https://img.shields.io/github/forks/zencodex/composer-mirror.svg)](https://github.com/zencodex/composer-mirror)
[![build](https://img.shields.io/badge/build-passing-brightgreen.svg)](https://github.com/zencodex/composer-mirror)
[![issues](https://img.shields.io/github/issues/zencodex/composer-mirror.svg)](https://github.com/zencodex/composer-mirror)
[![MIT](https://img.shields.io/badge/license-MIT-lightgrey.svg)](https://github.com/zencodex/composer-mirror)> 感谢 Laravel China 社区 的 Summer,提出了做镜像的建议,感谢早期参与测试的小伙伴们,给了众多的支持 🙏
> Laravel China 社区镜像,于 2019 年 9 月 4 号停用。详见:https://learnku.com/articles/30758 ,替代镜像请见 Wiki:[Wiki:Composer 国内加速:可用镜像列表](https://learnku.com/composer/wikis/30594)
## ZComposer 镜像的安装部署
推荐运行主机配置:
* [x] 内存最好不低于4G
* [x] 剩余磁盘空间不低于30G```sh
$ apt install beanstalkd
$ cd composer-mirror
$ composer install
```## 修改配置参数
> 通常根据自己部署的实际环境,修改参数。详细配置说明详见 config.default.php
`cp config.default.php config.php`,修改 config.php 中的如下参数
```php
/**
* distdir 用于存储 zip 包
*/
'distdir' => __DIR__ . '/dist/',/**
* 指向 mirrorUrl 对应的 web 实际目录
*/
'cachedir' => __DIR__ . '/cache/',/**
* packagistUrl:官方采集源
*/
'packagistUrl' => 'https://packagist.org',/**
* 镜像包发布站点, packages.json 入口根域名
*/
'mirrorUrl' => 'https://packagist.laravel-china.org',/**
* .json 中 dist 分发 zip 包的CDN域名
*/
'distUrl' => 'https://dl.laravel-china.org/',
```### supervisor 配置
`sudo vim /etc/supervisor/supervisord.conf`,添加如下配置信息:
[program:crawler]
command=php ./bin/console app:crawler
directory=/home/zencodex/composer-mirror/ ;部署代码的位置,自行替换
autostart=true
autorestart=true
redirect_stderr = true ; 把 stderr 重定向到 stdout,默认 false
stdout_logfile_maxbytes = 10MB ; stdout 日志文件大小,默认 50MB
stdout_logfile_backups = 5 ; stdout 日志文件备份数
stdout_logfile = /tmp/composer_crawler_stdout.log
[program:composer_daemon]
command=php ./bin/console app:daemon
directory=/home/zencodex/composer-mirror/ ;部署代码的位置,自行替换
autostart=true
autorestart=true
redirect_stderr = true ; 把 stderr 重定向到 stdout,默认 false
stdout_logfile_maxbytes = 10MB ; stdout 日志文件大小,默认 50MB
stdout_logfile_backups = 5 ; stdout 日志文件备份数
stdout_logfile = /tmp/composer_daemon_stdout.log### crontab 定时任务
```
# sudo crontab -e
# 根据自己环境代码的位置,替换 /home/zencodex/composer-mirror
# getcomposer 是获取最新的 composer,上传到 CDN 云存储0 */2 * * * /usr/bin/php /home/zencodex/composer-mirror/bin/console app:clear --expired=json
0 1 * * * /usr/bin/php /home/zencodex/composer-mirror/getcomposer.php
```## 常用命令
```sh
# 执行抓取任务
$ php ./bin/console app:crawler# 后台多进程模型同步又拍云
$ php ./bin/console app:daemon# 清理过期垃圾文件
$ php ./bin/console app:clear --expired=json# 扫描并校验所有json和zip文件的hash256
$ php ./bin/console app:scan
```### For Developers
* 没有使用数据库存储,完全是按目录结构存储
* 每个包的 dist/zip 文件存储的是对应 github url的下载地址,因磁盘空间有限,不在本地存储,直接推送到云端
* 清理过期文件,判断是否有更新,是否过期的依据是文件的时间戳,所以不要手动对文件做 touch,或引起时间戳变化的操作> 如果使用非又拍云的其他平台,需要注意以下代码,需要自行实现
* ClientHandlerPlugin 需要 Flysystem 的对应 Adapter 有对应接口,本例中只有 zencodex/flysystem-upyun 实现了,其他第三方包,可以参照样例自行实现
* Cloud::refreshRemoteFile,作用是刷新 CDN 缓存的文件,这个每日有调用频率限制,所以只刷新 package.json 时使用
* Cloud::refreshRemoteFile,如果使用非又拍云的平台,需要替换为自己平台刷新代码。或者参照 `ZenCodex\Support\Flysystem\Adapter\UpyunAdapter` 封装 getClientHandler。
* Cloud::prefetchDistFile 和 refreshRemoteFile 类似,调用的是云平台特殊接口,无法统一封装在 Flysystem,所以也通过 getClientHandler 处理### 注意最大子目录数的坑
代码详情见 `src/Commands/PatchCommand.php`
```php
/*
|--------------------------------------------------------------------------
| linux ext4 支持的最大子目录数有上限,大约 64000 ~ 65000,目前包的数量已经超过上限
|--------------------------------------------------------------------------
|
| 有三种解决方法,前2种基本不现实。所以自己通过尝试,找到了3 (软连接不计数的方案)
|
| 1. 更换没有子文件夹数量限制的文件系统,比如 xfs
| 2. 或者更改相关代码,重新编译 ext4 内核
| 3. 切割大的文件夹,分散不同字母开头的文件。在主文件夹里面使用软连接,软连接并不计数
|
*/
```