Maison > développement back-end > tutoriel php > Comment installer des extensions PHP personnalisées sur Heroku

Comment installer des extensions PHP personnalisées sur Heroku

Lisa Kudrow
Libérer: 2025-02-19 11:53:09
original
647 Les gens l'ont consulté

Comment installer des extensions PHP personnalisées sur Heroku

Dans ce tutoriel, nous apprendrons à installer des extensions personnalisées sur Heroku. Plus précisément, nous installerons Phalcon.

Les plats clés

  • Les extensions PHP personnalisées, telles que Phalcon, peuvent être installées sur Heroku à l'aide de l'outil PHP BuildPack, qui configure l'environnement pour exécuter des applications sur Heroku.
  • Le processus implique la création d'un fichier phalcon.sh personnalisé dans le répertoire BuildPack-Php / Bin, éditant le fichier bin / compilé pour l'exécuter et l'ajout de l'extension de texte = phalcon.so à la conf / php / php.ini fichier.
  • Une nouvelle application doit être créée sur Heroku, avec un fichier composer.json vide pour indiquer qu'il s'agit d'une application PHP. Heroku permettra les extensions de PHP correspondantes et les mettra dans le dossier de support / build / extensions / non-debug-non-zts-20121212.
  • La racine Web doit être spécifiée dans un fichier ProCFile, et le site Web PhalCon s'est cloné dans le dossier Repo. Après avoir poussé tous les engins dans le référentiel central, un clone de phalconphp.com en cours d'exécution sur Heroku sera créé.

Inscription et configurer

Pour utiliser Heroku, vous devez vous inscrire à un compte Heroku. Heroku fonctionne généralement avec une interface de ligne de commande. Pour utiliser cette interface, vous devez installer le package de la ceinture d'outils Heroku pour votre système d'exploitation. Si vous utilisez Linux, ouvrez le terminal et tapez la commande suivante.

wget -qO- https://toolbelt.heroku.com/install.sh | sh
Copier après la connexion
Copier après la connexion
Copier après la connexion

Après l'installation de la ceinture d'outils, vous aurez accès à la commande Heroku à partir de votre shell de commande. Authentifiez l'utilisation de l'adresse e-mail et du mot de passe que vous avez utilisé lors de la création de votre compte Heroku:

heroku login


Enter your Heroku credentials.
Email: fcopensuse@gmail.com
Password:
Could not find an existing public key.
Would you like to generate one? [Yn]
Generating new SSH public key.
Uploading ssh public key /home/duythien/.ssh/id_rsa.pub
Copier après la connexion
Copier après la connexion
Copier après la connexion

Appuyez sur Entrée à l'invite pour télécharger votre touche SSH existante ou en créer une nouvelle, utilisée pour pousser le code plus tard.

phalcon est une extension tierce, et donc non regroupé avec PHP. Phalcon nécessite les composants suivants:

<span>mbstring
</span><span>mcrypt
</span><span>openssl
</span><span>PDO
</span><span>PDO/Mysql
</span><span>PDO/Postgresql
</span><span>PDO/Sqlite
</span><span>PDO/Oracle</span>
Copier après la connexion
Copier après la connexion

MBSTRING et MCRYPT sont les principaux - MBSTRING est utilisé par le moteur de modèles (Volt), ainsi que par certains validateurs, l'escaper et le filtre, tandis que Mcrypt est utilisé dans la composante de sécurité (générer des hachages sécurisés, etc.)

Afin d'installer les éléments ci-dessus, nous utiliserons l'outil PHP BuildPack. Expliquons ce que cela signifie.

Selon la documentation officielle d'Héroku, les buildpacks offrent la magie et la flexibilité qui facilitent l'exécution de vos applications sur Heroku. Lorsque vous poussez votre code, le BuildPack est le composant qui gère la configuration de votre environnement afin que votre application puisse s'exécuter. Le BuildPack peut installer des dépendances, personnaliser les logiciels, manipuler des actifs et faire tout ce qui est requis pour exécuter votre application. Heroku n'avait pas toujours de buildpacks, ils sont un nouveau composant qui est venu avec la pile de cèdre.

Vous pouvez obtenir plus d'informations sur ces trois étapes et plus via la documentation BuildPack.

Pour commencer, nous fourchons ce code sur github. Cliquez sur le bouton «Fork» dans le référentiel. Pour pouvoir travailler sur le projet, vous devrez le cloner à votre machine locale.

Exécutez le code suivant:

wget -qO- https://toolbelt.heroku.com/install.sh | sh
Copier après la connexion
Copier après la connexion
Copier après la connexion

Créez le fichier phalcon.sh dans votre répertoire $ home / buildpack-php / bin avec le contenu suivant:

heroku login


Enter your Heroku credentials.
Email: fcopensuse@gmail.com
Password:
Could not find an existing public key.
Would you like to generate one? [Yn]
Generating new SSH public key.
Uploading ssh public key /home/duythien/.ssh/id_rsa.pub
Copier après la connexion
Copier après la connexion
Copier après la connexion

Ce fichier installera PhalCon, mais Heroku doit être invité à l'exécuter. Pour ce faire, vous devrez modifier le fichier bac / compilation et ajouter la ligne suivante quelque part là-dedans:

<span>mbstring
</span><span>mcrypt
</span><span>openssl
</span><span>PDO
</span><span>PDO/Mysql
</span><span>PDO/Postgresql
</span><span>PDO/Sqlite
</span><span>PDO/Oracle</span>
Copier après la connexion
Copier après la connexion

De plus, vous devez ajouter l'extension de texte = phalcon.so au fichier «conf / php / php.ini»:

git clone https://github.com/duythien/heroku-buildpack-php.git buildpack-php
cd buildpack-php
Copier après la connexion

Maintenant, nous pouvons pousser notre nouveau buildpack:

#!/bin/bash
# Build Path: /app/.heroku/php/
dep_url=git://github.com/phalcon/cphalcon.git
phalcon_dir=cphalcon
echo "-----> Building Phalcon..."

### Phalcon
echo "[LOG] Downloading PhalconPHP"
git clone $dep_url -q
if [ ! -d "$phalcon_dir" ]; then
  echo "[ERROR] Failed to find phalconphp directory $phalcon_dir"
  exit
fi
cd $phalcon_dir/build

# /app/php/bin/phpize
# ./configure --enable-phalcon --with-php-config=$PHP_ROOT/bin/php-config
# make
# make install
BUILD_DIR=
ln -s $BUILD_DIR/.heroku /app/.heroku
export PATH=/app/.heroku/php/bin:$PATH
bash ./install
cd
echo "important extension phalcon into php.ini"
echo "extension=phalcon.so" >> /app/.heroku/php/etc/php/php.ini
Copier après la connexion

Créez une nouvelle application sur Heroku

Créez un répertoire pour votre application et modifiez-le:

[...]
source $BP_DIR/bin/phalcon
[...]
Copier après la connexion

De plus, vous devez donner à Heroku une indication que cette application est une application PHP. Pour ce faire, créez un fichier vide appelé composer.json. Sur un système Unix, vous pouvez créer ce fichier comme SO:

[....]
extension=phalcon.so
; Local Variables:
; tab-width: 4
; End:
Copier après la connexion

Ensuite, exécutez ce qui suit pour initalialiser le dépôt de notre application:

git add -A
git commit -m "edit php.ini and create phalcon file"
git push origin master
Copier après la connexion

Pour créer une nouvelle application Heroku sur laquelle vous pouvez pousser, utilisez la commande de création du CLI:

mkdir phalcon-dev
cd phalcon-dev
Copier après la connexion

Cela crée l'application sur Heroku Ready et en attente de notre code, et attache également une télécommande GIT à notre base de code locale. Vous êtes maintenant prêt à déployer l'application, mais il n'y a pas encore de code. Suivez la section suivante pour ajouter du contenu à votre application.

Votre fichier composer.json doit être fait pour ressembler à ceci:

touch composer<span>.json</span>
Copier après la connexion

Il installera automatiquement des extensions telles que McRypt, MbString, etc. sur Heroku. Si vous avez besoin de mongodb, memcached, etc., modifiez le fichier davantage:

git init
git add -A
git commit -m" first commit"
Copier après la connexion

Maintenant, Heroku permettra les extensions PHP correspondantes et les mettra dans le dossier de support / build / extensions / non-debug-non-zts-20121212. Ensuite, créez un fichier test.php avec le contenu suivant:

heroku create phalcon-dev

Creating phalcon-dev... done, stack is cedar
http://phalcon-dev.herokuapp.com/ | git@heroku.com:phalcon-dev.git
Git remote heroku added
Copier après la connexion

Enfin, déployons l'installation de Phalcon:

<span>{
</span>  <span>"require": {
</span>    <span>"php": "5.5.12"
</span>  <span>}
</span><span>}</span>
Copier après la connexion

La première commande signifie remplacer le buildpack par défaut Heroku en spécifiant un buildPack personnalisé dans la configuration de buildpack_url var. Après quelques minutes, les résultats sont les suivants:

<span>{
</span>  <span>"require": {
</span>    <span>"php": "5.5.12",
</span>    <span>"ext-memcached": "*",
</span>    <span>"ext-mongo": "*"
</span>  <span>}
</span><span>}</span>
Copier après la connexion

Cela a pris notre code, l'a poussé à Heroku, l'a identifié et a exécuté un processus de construction contre lui, ce qui le prépare pour le déploiement. Maintenant, notre application est en direct sur Internet! Pour vérifier cela, ouvrez-le maintenant:

<span><span><?php phpinfo() ; ?></span></span>
Copier après la connexion

Si tout se passe bien, vous devriez voir l'écran suivant dans votre navigateur:

Comment installer des extensions PHP personnalisées sur Heroku

Configurez la racine du web et déployez l'exemple de site

vient maintenant la partie délicate qui spécifie la racine Web. La spécification de la racine Web a besoin d'un peu plus de travail et d'informations générales. La racine de l'application du site Web Phalcon dans l'arborescence Git est / app / phalcon-website / public. Pour Heroku, par défaut, la racine Web est la racine du git-arree. Ce répertoire est mappé en interne sur / app. Pour changer cela, nous devons créer un soi-disant ProCfile qui démarre un SH-Script chaque fois que le nœud Web de l'application Heroku démarre. Ce script modifie ensuite la configuration du serveur et inclut votre propre configuration qui définit la web root sur / app / phalcon-website / public. Créez un fichier ProCFile avec le contenu suivant (si vous utilisez Apache):

wget -qO- https://toolbelt.heroku.com/install.sh | sh
Copier après la connexion
Copier après la connexion
Copier après la connexion

Clone le site Web Phalcon dans le dossier Repo, et quand il est terminé, la commande git push envoie tous les validations sur votre maître local au référentiel central.

heroku login


Enter your Heroku credentials.
Email: fcopensuse@gmail.com
Password:
Could not find an existing public key.
Would you like to generate one? [Yn]
Generating new SSH public key.
Uploading ssh public key /home/duythien/.ssh/id_rsa.pub
Copier après la connexion
Copier après la connexion
Copier après la connexion

Visitez l'URL publique de l'application et le tour est joué, vous avez un clone de phalconphp.com en cours d'exécution sur Heroku ici.

Comment installer des extensions PHP personnalisées sur Heroku

en conclusion

L'installation de PhalCon (ou toute autre extension PHP) sur Heroku n'est évidemment ni facile ni simple, mais si vous utilisez BuildPacks, il devient beaucoup plus accessible.

Laissez vos commentaires dans les commentaires ci-dessous et, comme toujours, partagez cet article si vous l'avez aimé!

Les questions fréquemment posées (FAQ) sur l'installation des extensions PHP personnalisées sur Heroku

Comment puis-je installer des extensions PHP personnalisées sur Heroku?

L'installation d'extensions de PHP personnalisées sur Heroku implique quelques étapes. Tout d’abord, vous devez créer un fichier nommé «Composer.json» dans la racine de votre projet. Ce fichier contiendra les extensions PHP que vous souhaitez installer. Par exemple, si vous souhaitez installer l'extension 'gd', votre fichier 'composer.json' devrait ressembler à ceci:

{
"require": {
"ext-gd": "*"
}
}

Après avoir créé le fichier 'Composer.json', vous devez exécuter la commande 'Composer Update' dans votre terminal. Cela créera un fichier «composer.lock» dans la racine de votre projet. Vous devez commettre des fichiers «Composer.json» et «Composer.lock» dans votre référentiel GIT. Enfin, vous pouvez pousser vos modifications à Heroku en utilisant la commande «Git Push Heroku Master». Heroku installera automatiquement les extensions PHP spécifiées dans votre fichier «composer.json».

Pourquoi est-ce que je reçois une erreur en essayant d'installer une extension PHP sur Heroku?

Il pourrait y avoir plusieurs raisons pour lesquelles vous obtenez une erreur lorsque vous essayez d'installer une extension PHP sur Heroku. L'une des raisons courantes est que l'extension que vous essayez d'installer n'est pas compatible avec la version PHP que vous utilisez. Vous pouvez vérifier la version PHP en exécutant la commande «PHP -V» dans votre terminal. Si l'extension n'est pas compatible avec votre version PHP, vous devez soit mettre à jour votre version PHP ou trouver une version de l'extension qui est compatible avec votre version PHP.

Une autre raison courante pour obtenir une erreur est que le L'extension n'est pas disponible dans le référentiel PECL. Heroku utilise le référentiel PECL pour installer des extensions PHP. Si l'extension n'est pas disponible dans le référentiel PECL, vous ne pouvez pas l'installer sur Heroku.

Puis-je utiliser un fichier php.ini personnalisé sur Heroku?

Oui, vous pouvez utiliser un PHP personnalisé .ini dossier sur Heroku. Pour ce faire, vous devez créer un fichier «.user.ini» dans la racine de votre projet. Ce fichier contiendra vos paramètres PHP personnalisés. Par exemple, si vous souhaitez augmenter la taille maximale de téléchargement de fichiers, votre fichier '.User.ini' devrait ressembler à ceci:

upload_max_filesize = 10m
post_max_size = 10m

après la création Le fichier '.User.ini', vous devez le valider dans votre référentiel GIT et pousser vos modifications à Heroku. Heroku appliquera automatiquement les paramètres spécifiés dans votre fichier «.User.ini».

Comment puis-je mettre à jour ma version PHP sur Heroku?

La mise à jour de votre version PHP sur Heroku implique quelques étapes. Tout d'abord, vous devez spécifier la nouvelle version PHP dans votre fichier «Composer.json». Par exemple, si vous souhaitez mettre à jour sur PHP 7.4, votre fichier 'composer.json' devrait ressembler à ceci:

{
"require": {
"php": "^ 7.4"
}
}

Après la mise à jour du fichier 'Composer.json', vous devez exécuter la commande 'Composer Update' dans votre terminal. Cela mettra à jour le fichier «Composer.lock». Vous devez commettre des fichiers «Composer.json» et «Composer.lock» dans votre référentiel GIT. Enfin, vous pouvez pousser vos modifications à Heroku en utilisant la commande «Git Push Heroku Master». Heroku mettra automatiquement à jour votre version PHP.

Puis-je utiliser un buildPack personnalisé pour installer des extensions PHP sur Heroku?

Oui, vous pouvez utiliser un buildPack personnalisé pour installer des extensions PHP sur Heroku. Un buildPack est un script qu'Heroku exécute lorsque vous poussez vos modifications à la plate-forme. Il est responsable de la configuration de l'environnement de votre application et de l'installation de ses dépendances.

Pour utiliser un buildPack personnalisé, vous devez le spécifier dans votre fichier «app.json» ou dans le tableau de bord Heroku. Par exemple, si vous souhaitez utiliser le BuildPack 'Heroku / Php', votre fichier 'app.json' devrait ressembler à ceci:

{
"buildpacks": [
{
"URL": "HEROKU / PHP"
}
]
}

Après avoir précisé le buildPack, vous pouvez pousser vos modifications à Heroku. Heroku exécutera automatiquement le buildPack et installera les extensions PHP spécifiées.

Comment puis-je résoudre les problèmes lors de l'installation d'extensions de PHP sur Heroku?

Dépannage des problèmes lors de l'installation d'extensions de PHP sur Heroku peut être difficile à difficile , mais il y a quelques stratégies que vous pouvez utiliser. Tout d'abord, vous pouvez vérifier les journaux Heroku pour tous les messages d'erreur. Vous pouvez accéder aux journaux en exécutant la commande «Heroku Logs» dans votre terminal. Les journaux peuvent vous donner des indices sur ce qui cause le problème.

Deuxièmement, vous pouvez utiliser la commande «Heroku Run» pour exécuter les commandes directement sur votre application Heroku. Par exemple, vous pouvez exécuter la commande «php -m» pour répertorier toutes les extensions PHP installées. Cela peut vous aider à vérifier si une extension spécifique est installée ou non.

Enfin, vous pouvez utiliser la commande «Heroku Config» pour vérifier la configuration de votre application Heroku. Cela peut vous aider à vérifier si vos paramètres PHP.ini personnalisés sont appliqués ou non. Extensions PHP qui ne sont pas disponibles dans le référentiel PECL sur Heroku. Heroku utilise le référentiel PECL pour installer des extensions PHP. Si l'extension n'est pas disponible dans le référentiel PECL, vous ne pouvez pas l'installer sur Heroku.

Cependant, vous pouvez utiliser un buildPack personnalisé pour installer des extensions PHP qui ne sont pas disponibles dans le référentiel PECL. Un buildPack personnalisé peut inclure des scripts pour compiler et installer des extensions PHP à partir de la source. Cela nécessite une connaissance avancée de la script Shell PHP et UNIX.

Comment puis-je vérifier si une extension PHP est installée sur Heroku?

Vous pouvez vérifier si une extension PHP est installée sur Heroku en exécutant le Commande 'php -m' sur votre application Heroku. Cette commande répertorie toutes les extensions PHP installées. Vous pouvez exécuter cette commande en utilisant la commande «Heroku Run» dans votre terminal. Par exemple, vous pouvez exécuter la commande suivante pour répertorier toutes les extensions PHP installées:

HEROKU RUN PHP -M

Si l'extension est installée, elle doit apparaître dans la liste des extensions PHP installées.

Puis-je installer plusieurs extensions de PHP sur Heroku?

Oui, vous pouvez installer plusieurs extensions de PHP sur Heroku. Pour ce faire, vous devez spécifier toutes les extensions que vous souhaitez installer dans votre fichier «Composer.json». Par exemple, si vous souhaitez installer les extensions 'GD' et 'MBSTRING', votre fichier 'composer.json' devrait ressembler à ceci:

{
"require": {
"ext -gd ":" * ",
" ext-mbstring ":" * "
}
}

après la mise à jour du Fichier «Composer.json», vous devez exécuter la commande «Composer Update» dans votre terminal. Cela mettra à jour le fichier «Composer.lock». Vous devez commettre des fichiers «Composer.json» et «Composer.lock» dans votre référentiel GIT. Enfin, vous pouvez pousser vos modifications à Heroku en utilisant la commande «Git Push Heroku Master». Heroku installera automatiquement les extensions PHP spécifiées dans votre fichier 'composer.json'.

Puis-je utiliser le fichier 'php.ini' pour installer des extensions PHP sur Heroku?

Non, vous ne pouvez pas, vous ne pouvez pas Utilisez le fichier 'php.ini' pour installer des extensions PHP sur Heroku. Heroku ne prend pas en charge le fichier «php.ini» pour l’installation d’extensions de PHP. Au lieu de cela, vous devez utiliser le fichier «Composer.json» pour spécifier les extensions PHP que vous souhaitez installer. Heroku installera automatiquement les extensions PHP spécifiées dans votre fichier «composer.json» lorsque vous appuyez sur vos modifications sur la plate-forme.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Derniers articles par auteur
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal