Dans ce tutoriel, nous apprendrons à installer des extensions personnalisées sur Heroku. Plus précisément, nous installerons Phalcon.
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
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
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>
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
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
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>
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
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
Créez un répertoire pour votre application et modifiez-le:
[...] source $BP_DIR/bin/phalcon [...]
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:
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
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
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>
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"
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
Enfin, déployons l'installation de Phalcon:
<span>{ </span> <span>"require": { </span> <span>"php": "5.5.12" </span> <span>} </span><span>}</span>
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>
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>
Si tout se passe bien, vous devriez voir l'écran suivant dans votre navigateur:
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
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
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.
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é!
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».
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.
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».
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.
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.
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.
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:
Si l'extension est installée, elle doit apparaître dans la liste des extensions PHP installées.
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'.
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!