Takeaways Key
- Sambungan PHP tersuai, seperti Phalcon, boleh dipasang pada Heroku menggunakan alat PHP Buildpack, yang menubuhkan persekitaran untuk menjalankan aplikasi di Heroku.
- Proses ini melibatkan membuat fail PhalCon.sh tersuai dalam direktori Buildpack-PhP/Bin, mengedit fail bin/kompilasi untuk melaksanakannya, dan menambah sambungan teks = phalcon.so ke conf/php.ini Fail.
- Permohonan baru mesti dibuat di Heroku, dengan fail komposer.json kosong untuk menunjukkan ia adalah aplikasi PHP. Heroku akan membolehkan sambungan PHP yang sepadan dan meletakkannya dalam folder sokongan/binaan/sambungan/no-debug-non-zts-20121212.
- Root Web mesti ditentukan dalam fail ProcFile, dan laman web Phalcon diklon ke dalam folder repo. Setelah menolak semua komitmen ke repositori pusat, klon Phalconphp.com yang sedang berjalan di Heroku akan diwujudkan.
Untuk menggunakan Heroku, anda mesti mendaftar untuk akaun Heroku. Heroku umumnya bekerja dengan antara muka baris arahan. Untuk menggunakan antara muka itu, anda perlu memasang pakej toolbelt Heroku untuk sistem operasi anda. Jika anda menggunakan Linux, buka terminal dan taipkan arahan berikut.
wget -qO- https://toolbelt.heroku.com/install.sh | shSelepas memasang toolbelt, anda akan mempunyai akses kepada perintah Heroku dari shell arahan anda. Sahkan menggunakan alamat e -mel dan kata laluan yang anda gunakan semasa membuat akaun Heroku anda:
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.pubTekan Enter pada prompt untuk memuat naik kekunci SSH sedia ada anda atau buat yang baru, digunakan untuk menolak kod kemudian.
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>mbstring dan mcrypt adalah yang utama - mbstring digunakan oleh enjin templating (volt), serta beberapa validator, escaper dan penapis, sementara mcrypt digunakan dalam komponen keselamatan (menghasilkan hash selamat dan lain -lain)
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 | sh3
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
Buat direktori untuk aplikasi anda dan ubah kepadanya:
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>
Konfigurasikan akar web dan gunakan tapak sampel
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.
Memasang Phalcon (atau mana -mana pelanjutan PHP lain) di Heroku jelas tidak mudah atau mudah tetapi jika anda menggunakan binaan, ia menjadi lebih mudah didekati.
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
Bagaimana saya boleh memasang sambungan PHP tersuai pada Heroku? Pertama, anda perlu membuat fail bernama 'composer.json' dalam root projek anda. Fail ini akan mengandungi sambungan PHP yang ingin anda pasang. Sebagai contoh, jika anda ingin memasang lanjutan 'gd', fail 'composer.json' anda sepatutnya kelihatan seperti ini:
{
"memerlukan": {}
}
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.
Kenapa saya mendapat kesilapan ketika cuba memasang pelanjutan PHP pada Heroku? Salah satu sebab yang sama ialah pelanjutan yang anda cuba pasang tidak serasi dengan versi PHP yang anda gunakan. Anda boleh menyemak versi PHP dengan menjalankan arahan 'php -v' di terminal anda. Sekiranya pelanjutan tidak serasi dengan versi PHP anda, anda perlu mengemas kini versi PHP anda atau mencari versi pelanjutan yang serasi dengan versi PHP anda. Pelanjutan tidak tersedia dalam repositori PECL. Heroku menggunakan repositori PECL untuk memasang sambungan PHP. Sekiranya pelanjutan tidak terdapat di repositori PECL, anda tidak boleh memasangnya di Heroku. .ini fail pada Heroku. Untuk melakukan ini, anda perlu membuat fail '.user.ini' dalam root projek anda. Fail ini akan mengandungi tetapan PHP tersuai anda. Contohnya, jika anda ingin meningkatkan saiz muat naik fail maksimum, fail '.user.ini' anda sepatutnya kelihatan seperti ini:
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.
Bagaimana saya boleh mengemas kini versi PHP saya di Heroku? Pertama, anda perlu menentukan versi PHP baru dalam fail 'Composer.json' anda. Sebagai contoh, jika anda ingin mengemas kini ke Php 7.4, fail 'composer.json' anda sepatutnya kelihatan seperti ini:
{ { 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!

URL panjang, sering berantakan dengan kata kunci dan parameter penjejakan, boleh menghalang pelawat. Skrip pemendekan URL menawarkan penyelesaian, mewujudkan pautan ringkas yang sesuai untuk media sosial dan platform lain. Skrip ini sangat berharga untuk laman web individu a

Berikutan pengambilalihan berprofil tinggi oleh Facebook pada tahun 2012, Instagram mengadopsi dua set API untuk kegunaan pihak ketiga. Ini adalah API Grafik Instagram dan API Paparan Asas Instagram. Sebagai pemaju membina aplikasi yang memerlukan maklumat dari a

Laravel memudahkan mengendalikan data sesi sementara menggunakan kaedah flash intuitifnya. Ini sesuai untuk memaparkan mesej ringkas, makluman, atau pemberitahuan dalam permohonan anda. Data hanya berterusan untuk permintaan seterusnya secara lalai: $ permintaan-

Ini adalah bahagian kedua dan terakhir siri untuk membina aplikasi React dengan back-end Laravel. Di bahagian pertama siri ini, kami mencipta API RESTful menggunakan Laravel untuk aplikasi penyenaraian produk asas. Dalam tutorial ini, kita akan menjadi dev

Laravel menyediakan sintaks simulasi respons HTTP ringkas, memudahkan ujian interaksi HTTP. Pendekatan ini dengan ketara mengurangkan redundansi kod semasa membuat simulasi ujian anda lebih intuitif. Pelaksanaan asas menyediakan pelbagai jenis pintasan jenis tindak balas: Gunakan Illuminate \ Support \ Facades \ http; Http :: palsu ([ 'Google.com' => 'Hello World', 'github.com' => ['foo' => 'bar'], 'forge.laravel.com' =>

Pelanjutan URL Pelanggan PHP (CURL) adalah alat yang berkuasa untuk pemaju, membolehkan interaksi lancar dengan pelayan jauh dan API rehat. Dengan memanfaatkan libcurl, perpustakaan pemindahan fail multi-protokol yang dihormati, php curl memudahkan execu yang cekap

Adakah anda ingin memberikan penyelesaian segera, segera kepada masalah yang paling mendesak pelanggan anda? Sembang langsung membolehkan anda mempunyai perbualan masa nyata dengan pelanggan dan menyelesaikan masalah mereka dengan serta-merta. Ia membolehkan anda memberikan perkhidmatan yang lebih pantas kepada adat anda

Tinjauan Landskap PHP 2025 menyiasat trend pembangunan PHP semasa. Ia meneroka penggunaan rangka kerja, kaedah penempatan, dan cabaran, yang bertujuan memberi gambaran kepada pemaju dan perniagaan. Tinjauan ini menjangkakan pertumbuhan dalam PHP Versio moden


Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

AI Hentai Generator
Menjana ai hentai secara percuma.

Artikel Panas

Alat panas

PhpStorm versi Mac
Alat pembangunan bersepadu PHP profesional terkini (2018.2.1).

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

mPDF
mPDF ialah perpustakaan PHP yang boleh menjana fail PDF daripada HTML yang dikodkan UTF-8. Pengarang asal, Ian Back, menulis mPDF untuk mengeluarkan fail PDF "dengan cepat" dari tapak webnya dan mengendalikan bahasa yang berbeza. Ia lebih perlahan dan menghasilkan fail yang lebih besar apabila menggunakan fon Unicode daripada skrip asal seperti HTML2FPDF, tetapi menyokong gaya CSS dsb. dan mempunyai banyak peningkatan. Menyokong hampir semua bahasa, termasuk RTL (Arab dan Ibrani) dan CJK (Cina, Jepun dan Korea). Menyokong elemen peringkat blok bersarang (seperti P, DIV),

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

Pelayar Peperiksaan Selamat
Pelayar Peperiksaan Selamat ialah persekitaran pelayar selamat untuk mengambil peperiksaan dalam talian dengan selamat. Perisian ini menukar mana-mana komputer menjadi stesen kerja yang selamat. Ia mengawal akses kepada mana-mana utiliti dan menghalang pelajar daripada menggunakan sumber yang tidak dibenarkan.
