heroku / heroku-buildpack-php
本地启动PHP应用程序的工具包,可使用或无需foreman,使用与Heroku相同的配置,用于PHP和Apache2/Nginx
- dev-main
- v256
- v255
- v254
- v253
- v252
- v251
- v250
- v249
- v248
- v247
- v246
- v245
- v244
- v243
- v242
- v241
- v240
- v239
- v238
- v237
- v236
- v235
- v234
- v233
- v232
- v231
- v230
- v229
- v228
- v227
- v226
- v225
- v224
- v223
- v222
- v221
- v220
- v219
- v218
- v217
- v216
- v215
- v214
- v213
- v212
- v211
- v210
- v209
- v208
- v207
- v206
- v205
- v204
- v203
- v202
- v201
- v200
- v199
- v198
- v197
- v196
- v195
- v194
- v193
- v192
- v191
- v190
- v189
- v188
- v187
- v186
- v185
- v184
- v183
- v182
- v181
- v180
- v179
- v178
- v177
- v176
- v175
- v174
- v173
- v172
- v171
- v170
- v169
- v168
- v167
- v166
- v165
- v164
- v163
- v162
- v161
- v160
- v159
- v158
- v157
- v156
- v155
- v154
- v153
- v152
- v151
- v150
- v149
- v148
- v147
- v146
- v145
- v144
- v143
- v142
- v141
- v140
- v139
- v138
- v137
- v136
- v135
- v134
- v133
- v132
- v131
- v130
- v129
- v128
- v127
- v126
- v125
- v124
- v123
- v122
- v121
- v120
- v119
- v118
- v117
- v116
- v115
- v114
- v113
- v112
- v111
- v110
- v109
- v108
- v107
- v106
- v105
- v104
- v103
- v102
- v101
- v100
- v99
- v98
- v97
- v96
- v95
- v94
- v93
- v92
- v91
- v90
- v89
- v88
- v87
- v86
- v85
- v84
- v83
- v82
- v81
- v80
- v78
- v76
- v75
- v74
- v72
- v71
- v70
- v69
- v68
- v67
- v66
- v65
- v64
- v63
- v62
- v61
- v60
- v59
- v58
- v57
- v56
- v55
- v54
- v53
- v52
- v51
- v50
- v49
- v48
- v47
- v46
- v45
- v44
- v43
- v42
- v41
- v40
- v39
- v37
- v36
- v35
- v34
- v33
- v32
- v31
- v30
- v29
- v28
- v27
- v26
- v25
- v24
- v23
- v22
- v21
- v20
- v19
- v18
- v17
- v16
- v15
- v14
- v13
- v12
- dev-dependabot/composer/support/devcenter/twig/twig-3.11.1
- dev-dependabot/composer/support/devcenter/devcenter-generator-dependencies-e22274d893
- dev-dependabot/bundler/test-dependencies-cbef664409
- dev-cnb-installer
- dev-develop
- dev-cgroupsv2
- dev-web-concurrency-set-by
- dev-bootimprove
- dev-gracefulstop
- dev-nginx
- dev-relpath
- dev-ci
- dev-composer-env-var
This package is auto-updated.
Last update: 2024-09-10 17:33:54 UTC
README
这是PHP应用程序的官方Heroku构建包。
它使用Composer进行依赖管理,支持所有最新的PHP版本作为运行时,并提供Apache2或Nginx网络服务器的选择。
用法
您需要至少在应用程序中使用一个空的composer.json
。
$ echo '{}' > composer.json
$ git add composer.json
$ git commit -m "add composer.json for PHP app detection"
如果您还有其他框架或语言的文件,这些文件可能会触发另一个构建包检测到您的应用程序为其之一,例如,一个可能将您的代码检测为Node.js应用程序的package.json
,即使它是一个PHP应用程序,那么您需要手动设置应用程序使用此构建包
$ heroku buildpacks:set heroku/php
这将使用官方发布的版本。要使用GitHub的默认分支,请参考以下说明。
$ heroku buildpacks:set https://github.com/heroku/heroku-buildpack-php
有关进一步的使用说明,请参阅开发中心。
自定义平台仓库
构建包使用Composer仓库来解决平台(php
、ext-something
、...)依赖。
要使用自定义Composer仓库以及额外的或不同的平台包,请将它的packages.json
的URL添加到HEROKU_PHP_PLATFORM_REPOSITORIES
配置变量中
$ heroku config:set HEROKU_PHP_PLATFORM_REPOSITORIES="https://<your-bucket-name>.s3.<your-bucket-region>.amazonaws.com/heroku-20/packages.json"
为了允许使用多个自定义仓库,配置变量可以包含多个仓库URL列表,以空格字符分隔,按优先级升序排列(这意味着最后列出的仓库首先由Composer处理包查找)。
请注意,Heroku无法提供与自定义平台仓库和包相关的问题支持。
禁用默认仓库
如果列表中的第一个条目是"-
"而不是URL,则完全禁用默认平台仓库。这可以在测试开发仓库或强制防止使用默认平台仓库中的任何包时很有用。
仓库优先级
可以控制自定义平台仓库的Composer仓库优先级:Composer是否
- 将特定仓库视为规范;
- 从仓库中排除特定包;
- 仅允许从仓库中获取特定包。
这些仓库选项(canonical
、exclude
和only
)使用以下查询字符串在仓库URL中控制
composer-repository-canonical
(true
或false
;默认为true
)composer-repository-exclude
(逗号分隔的排除包名称列表)composer-repository-only
(逗号分隔的允许包名称列表)
例如,以下配置变量将允许仅从customrepo.com
获取ext-igbinary
和ext-redis
包;所有其他包都在默认仓库中查找
$ heroku config:set HEROKU_PHP_PLATFORM_REPOSITORIES="https://customrepo.com/packages.json?composer-repository-only=ext-igbinary,ext-redis"
构建自定义仓库
有关如何构建自定义平台包(以及存放它们的仓库)的说明,请参阅以下说明。
开发
以下信息仅适用于您出于自身目的对构建包进行分支和修改。
拉取请求
请将所有拉取请求提交到以 develop
作为基分支。
自定义平台包和仓库
请参阅位于 support/build/
的README文件中的说明。