Takeaways Key
wget -qO- https://toolbelt.heroku.com/install.sh | sh
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
Phalcon adalah lanjutan pihak ketiga, dan dengan itu tidak dibundel dengan PHP. Phalcon memerlukan komponen berikut:
<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>
Untuk memasang unsur -unsur di atas, kami akan menggunakan alat PHP Buildpack. Mari kita jelaskan apa maksudnya.
Menurut dokumentasi rasmi Heroku, Buildpacks menyediakan sihir dan fleksibiliti yang membuat aplikasi anda di Heroku begitu mudah. Apabila anda menolak kod anda, binaan adalah komponen yang mengendalikan penubuhan persekitaran anda supaya aplikasi anda dapat dijalankan. Buildpack boleh memasang kebergantungan, menyesuaikan perisian, memanipulasi aset, dan melakukan apa sahaja yang diperlukan untuk menjalankan aplikasi anda. Heroku tidak selalu mempunyai binaan, mereka adalah komponen baru yang datang dengan timbunan cedar.
Anda boleh mendapatkan lebih banyak maklumat mengenai tiga langkah ini dan banyak lagi melalui dokumentasi binaan.
Untuk memulakan, kami memasak kod ini di GitHub. Klik butang "Fork" di repositori. Untuk dapat mengusahakan projek ini, anda perlu mengklonkannya ke mesin tempatan anda.
Jalankan kod berikut:
wget -qO- https://toolbelt.heroku.com/install.sh | sh
Fail ini akan memasang Phalcon, tetapi Heroku mesti diarahkan untuk melaksanakannya. Untuk berbuat demikian, anda perlu mengedit fail bin/menyusun dan menambah baris berikut di suatu tempat di sana:
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
Di samping itu, anda perlu menambah sambungan teks = phalcon.so ke fail "conf/php/php.ini":
<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>
Sekarang kita boleh menolak binaan baru kita:
git clone https://github.com/duythien/heroku-buildpack-php.git buildpack-php cd buildpack-php
Buat aplikasi baru di Heroku
#!/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
Di samping itu, anda perlu memberi Heroku suatu petunjuk bahawa aplikasi ini adalah aplikasi PHP. Untuk melakukan ini, buat fail kosong yang dipanggil Composer.json. Pada sistem Unix, anda boleh membuat fail ini seperti:
[...] source $BP_DIR/bin/phalcon [...]
Kemudian, laksanakan yang berikut untuk tidak mengutamakan repo untuk aplikasi kami:
[....] extension=phalcon.so ; Local Variables: ; tab-width: 4 ; End:
Untuk membuat aplikasi Heroku baru yang boleh anda tolak, gunakan arahan CLI's Create:
git add -A git commit -m "edit php.ini and create phalcon file" git push origin master
Ini mewujudkan aplikasi pada Heroku bersedia dan menunggu kod kami, dan juga melekatkan jauh Git ke pangkalan tempatan kami. Anda kini bersedia untuk menggunakan permohonan itu, tetapi belum ada kod. Ikuti bahagian seterusnya untuk menambah beberapa kandungan ke aplikasi anda.
mkdir phalcon-dev cd phalcon-dev
fail composer.json anda harus dibuat untuk kelihatan seperti ini:
Ia secara automatik akan memasang sambungan seperti MCRYPT, MBSTRING, dan lain -lain pada Heroku. Sekiranya anda memerlukan mongoDB, memcached, dan lain -lain, ubah suai fail lagi:
touch composer<span>.json</span>
Sekarang Heroku akan membolehkan sambungan PHP yang sepadan dan memasukkannya ke dalam folder sokongan/binaan/sambungan/no-debug-non-zts-20121212. Seterusnya, buat fail test.php dengan kandungan berikut:
git init git add -A git commit -m" first commit"
Akhirnya, mari kita gunakan pemasangan Phalcon:
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
Perintah pertama bermaksud mengatasi binaan lalai Heroku dengan menentukan binaan tersuai dalam config var BuildPack_Url. Selepas beberapa minit, hasilnya adalah seperti berikut:
<span>{ </span> <span>"require": { </span> <span>"php": "5.5.12" </span> <span>} </span><span>}</span>
Ini telah mengambil kod kami, menolaknya ke Heroku, mengenalinya, dan menjalankan proses membina terhadapnya, menjadikannya siap untuk digunakan. Sekarang aplikasi kami hidup di Internet! Untuk mengesahkan ini, buka sekarang:
<span>{ </span> <span>"require": { </span> <span>"php": "5.5.12", </span> <span>"ext-memcached": "*", </span> <span>"ext-mongo": "*" </span> <span>} </span><span>}</span>
Jika semuanya berjalan lancar, anda harus melihat skrin berikut dalam penyemak imbas anda:
<span><span><?php phpinfo() ; ?></span></span>
kini datang bahagian rumit yang menentukan akar web. Menentukan akar web memerlukan sedikit lebih banyak kerja dan maklumat latar belakang. Root aplikasi laman web Phalcon di Pohon Git adalah/App/Phalcon-Website/Public. Bagi Heroku, secara lalai, akar web adalah akar pokok git. Direktori itu dipetakan secara dalaman ke /aplikasi. Untuk mengubahnya, kita perlu membuat procfile yang dipanggil yang memulakan skrip SH setiap kali aplikasi web Heroku Web bermula. Skrip itu kemudian mengubah konfigurasi pelayan dan termasuk konfigurasi anda sendiri yang menetapkan root web ke/app/phalcon-website/public. Buat fail ProcFile dengan kandungan berikut (jika anda menggunakan Apache):
wget -qO- https://toolbelt.heroku.com/install.sh | sh
Klon laman web Phalcon ke dalam folder repo, dan apabila ia selesai, perintah push git menghantar semua komitmen pada tuan tempatan anda ke repositori pusat.
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
Lawati URL awam dan voila, anda mempunyai klon phalconphp.com yang sedang berjalan di Heroku di sini.
Tinggalkan maklum balas anda dalam komen di bawah dan, seperti biasa, sila kongsi artikel ini jika anda menyukainya!
Soalan Lazim (Soalan Lazim) Mengenai Memasang Sambungan PHP Tersuai di Heroku
}
}
Selepas membuat fail 'composer.json', anda perlu menjalankan perintah 'kemas kini komposer' di terminal anda. Ini akan membuat fail 'composer.lock' dalam akar projek anda. Anda perlu melakukan fail 'composer.json' dan 'composer.lock' ke repositori git anda. Akhirnya, anda boleh menolak perubahan anda kepada Heroku menggunakan arahan 'Git Push Heroku Master'. Heroku secara automatik akan memasang sambungan PHP yang dinyatakan dalam fail 'Composer.json' anda.
upload_max_filesize = 10m
post_max_size = 10m
Fail '.user.ini', anda perlu melakukan repositori git anda dan menolak perubahan anda kepada Heroku. Heroku secara automatik akan memohon tetapan yang dinyatakan dalam fail '.user.ini' anda.
{ { Ya, anda boleh memasang pelbagai sambungan PHP pada Heroku. Untuk melakukan ini, anda perlu menentukan semua sambungan yang anda mahu pasang dalam fail 'Composer.json' anda. Sebagai contoh, jika anda ingin memasang sambungan 'GD' dan 'MBSTRING', fail 'COMPOSER.JSON' anda sepatutnya kelihatan seperti ini: -gd ":"*",
}
}
Selepas mengemas kini fail 'Composer.Json', anda perlu menjalankan perintah 'Kemas Kini Komposer' di terminal anda. Ini akan mengemas kini fail 'composer.lock'. Anda perlu melakukan fail 'composer.json' dan 'composer.lock' ke repositori git anda. Akhirnya, anda boleh menolak perubahan anda kepada Heroku menggunakan arahan 'Git Push Heroku Master'. Heroku secara automatik akan mengemas kini versi PHP anda. Bolehkah saya menggunakan binaan tersuai untuk memasang sambungan php pada Heroku? Buildpack adalah skrip yang dijalankan oleh Heroku apabila anda menolak perubahan anda ke platform. Ia bertanggungjawab untuk menubuhkan persekitaran aplikasi anda dan memasang kebergantungannya. Sebagai contoh, jika anda ingin menggunakan binaan 'heroku/php', fail 'app.json' anda sepatutnya kelihatan seperti ini:
"binaan": [
{
"URL": "Heroku/php"
Bagaimana saya dapat mengesahkan sama ada pelanjutan php dipasang pada heroku? Perintah 'php -m' pada aplikasi Heroku anda. Perintah ini menyenaraikan semua sambungan PHP yang dipasang. Anda boleh menjalankan arahan ini dengan menggunakan arahan 'Heroku Run' di terminal anda. Sebagai contoh, anda boleh menjalankan arahan berikut untuk menyenaraikan semua sambungan PHP yang dipasang:
Heroku Run Php -M
Jika sambungan dipasang, ia harus muncul dalam senarai sambungan PHP yang dipasang. Bolehkah saya memasang pelbagai sambungan php pada heroku?
" ext-mbstring ":"*"
Atas ialah kandungan terperinci Cara Memasang Pelanjutan PHP Custom di Heroku. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!