Komposer Global memerlukan dianggap berbahaya?
mata utama
- Kecuali pakej yang dipasang secara global tidak mempunyai kebergantungan, kini dianggap amalan buruk untuk memasang pakej yang digunakan di pelbagai projek. Ini kerana apabila pakej berkongsi ruang yang sama, konflik pergantungan boleh berlaku.
-
composer global require
Penyelesaian lain ialah memasang setiap alat baris perintah ke dalam projek tempatan sendiri menggunakan , menguruskan secara manual - atau fail binari. Walau bagaimanapun, ini boleh menambah kerumitan dan tediousness. Perubahan yang dicadangkan kepada arahan global mungkin melihat projek "global" tetapi terpencil dipasang ke lokasi tertentu, dengan vendor dan direktori bin yang terdapat di lokasi biasa mereka.
composer require
$PATH
Alat baru CGR (Komposer Global memerlukan) telah dibangunkan sebagai alternatif kepada pelaksanaan global. Ia mewujudkan pemasangan terpencil untuk setiap pakej, mengelakkan isu pergantungan global. Walau bagaimanapun, alat ini masih dalam bukti fasa konsep dan mungkin berubah. Adalah disyorkan untuk mengujinya, tetapi jangan terlalu bergantung pada masa ini. - kami telah membincangkan amalan terbaik komposer sebelum ini, dan saya sentiasa menganjurkan menggunakan
composer global require
OP Penyelesaian yang disyorkan untuk masalah ini ialah:
sebagai alternatif, pengguna harus menggunakan
untuk memasang setiap alat baris perintah ke dalam projek tempatan mereka sendiri dan menguruskan fail
atau binari secara manual (contohnya, dengan sudah ada dari direktori
composer require
Bagi saya, ini adalah komplikasi yang tidak boleh diterima. Komposer sentiasa menjadi kebanggaan PHP kerana mudah digunakan dan menjadikan pengurusan pakej baru mesra - tempatan $PATH
atau $PATH
global. Pautan simbol perlu diwujudkan (terutamanya memandangkan sistem operasi yang tidak diselaraskan seperti Windows) boleh menambah tediousness. Kemudian, OP selanjutnya mencadangkan perubahan bagaimana arahan global berfungsi:
setuju penuh. Ia akan menjadi menakjubkan untuk dapat memasang setiap komposer pakej yang dipasang secara global ke dalam direktori kuarantinnya sendiri dan mempunyai kebergantungan kuarantin sendiri dan bukannya berpotensi bertentangan dengan pakej yang dipasang di seluruh dunia.Projek "global" tetapi terpencil boleh dipasang ke
~/.composer/global/[something]
; , atau pilihan yang lebih baik mungkin~/.composer/global/[something]/bin
. Rentetan~/.composer/vendor/bin
boleh dipilih dalam beberapa cara;~/.composer/bin
[something]
org/project
Saya benar -benar bersetuju dengan pendekatan ini, nampaknya menjadi yang terbaik dari kedua -dua dunia. Jelas sekali, ini boleh menyebabkan beberapa masalah keserasian mundur, tetapi itu tidak bermakna ia tidak akan berlaku dalam versi 2.0 komposer. Taylor Otwell terus memberi respons kepada pandangan ini di bawah:~/.composer/global/org/project/vendor/org/project
Selepas ini, dalam semangat sumber terbuka yang benar, OP kemudian membina pelaksanaan global alternatif ke dalam alat yang berasingan: CGR. Mari lihat bagaimana ia berfungsi.cgr - komposer global memerlukan alternatif
Saya akan melaksanakan semua arahan berikut pada contoh Homestead yang lebih baik
Untuk memulakan dengan CGR, kami memasangnya sebagai pakej global.
Jika folder bin komposer tidak berada dalam pembolehubah jalan, tambahkannya:
composer global require consolidation/cgr
pembolehubah persekitaran (lokasi lalai di Homestead bertambah baik - lokasi anda mungkin berbeza). Perintah kedua mengkonfigurasi direktori bin yang digunakan oleh CGR, manakala arahan ketiga memuatkan perubahan ini. Ini juga akan memuat secara automatik setiap kali antara muka terminal dijalankan sebagai pengguna itu (dalam kes saya, menggunakan vagrant melalui
).echo "export PATH=$PATH:$HOME/.composer/vendor/bin/" >> ~/.bashrc echo "export CGR_BIN_DIR=$HOME/.composer/vendor/bin" >> ~/.bashrc source ~/.bashrc
maka anda boleh mengakses CGR dengan menjalankan $PATH
, yang harus mengeluarkan fail bantuan umum komposer. vagrant ssh
cgr
akan berkembang ke
, yang sangat mudah apabila memasangcgr phpunit/phpunit
), kemudian keluar dari shell dan masuk semula supaya alias akan dimuat semula. Kemudian, menjalankan pemasangan Global PHPUNIT baru ini menggunakan output versi harus menghasilkan sesuatu seperti yang berikut: phpunit
vendor/bin/phpunit
phpunit
Sekarang mari kita cuba memasang dua pakej yang tidak serasi. ~/.bash_aliases
vagrant@homestead:~$ phpunit --version PHPUnit 5.4.2 by Sebastian Bergmann and contributors.
composer global require consolidation/cgr
semuanya berjalan lancar! Pakej global yang sebelum ini bertentangan kerana ketidakcocokan ketergantungan kini boleh wujud bersama dan boleh digunakan di seluruh sistem operasi tanpa sebarang masalah!
Apa yang tidak boleh/tidak boleh melakukan alat ini?
Dalam beberapa kes, anda mungkin mahu memasang plugin komposer. Seperti yang dinyatakan dalam bahagian Sekatan, plugin ini tidak tersedia secara global dalam semua projek global kerana CGR memasang setiap pakej global ke dalam foldernya sendiri dan mempunyai pokok pergantungan sendiri. Oleh itu, jika anda ingin memasang plugin yang mengubah tingkah laku komposer biasa, anda masih perlu menggunakan composer global require
bukannya CGR. Sebagai contoh, CGR sendiri adalah plugin seperti itu.
Apa yang akan datang?
ujian, ujian, ujian! Jika anda adalah pengguna yang kerap dari arahan Global memerlukan, saya sangat mengesyorkan agar anda menguji alat baru ini dan memberi Greg Anderson beberapa maklum balas tentang berapa banyak yang memenuhi keperluan global anda dan sama ada terdapat penambahbaikan.
Sila ambil perhatian bahawa alat ini pada masa ini hanya bukti konsep, dan pelaksanaan mungkin atau mungkin tidak dinamakan semula, dibungkus semula, akhirnya diintegrasikan ke dalam teras komposer, dan banyak lagi. Dalam erti kata lain, gunakannya seberapa banyak yang anda boleh, tetapi jangan terlalu bergantung pada masa ini.
Semasa pakej global anda dipasang, mengapa tidak memberitahu kami apa yang anda fikirkan composer global require
? Adakah ia berbahaya seperti yang difikirkan oleh ramai orang sekarang? Atau adakah ia hanya menjadi berhati -hati dan mempunyai persekitaran pembangunan terpencil? Apa lagi? Sila nyatakan komen anda di bawah!
Soalan Lazim Mengenai Komposer Global Memerlukan
Kenapa dianggap berbahaya untuk menggunakan keperluan global komposer?
Keperluan global komposer dianggap berbahaya kerana ia boleh membawa kepada konflik pergantungan. Apabila anda memasang pakej secara global, mereka semua berkongsi ruang yang sama, yang bermaksud mereka berkongsi set ketergantungan yang sama. Jika dua pakej memerlukan versi yang berbeza dari ketergantungan yang sama, ia boleh membawa kepada konflik dan kesilapan. Adalah disyorkan untuk memasang set kebergantungannya sendiri untuk setiap projek untuk mengelakkan masalah tersebut.
Apakah alternatif untuk memerlukan komposer global?
Jangan gunakan keperluan global komposer, anda boleh membuat projek komposer baru untuk setiap alat yang anda perlukan. Dengan cara ini, setiap alat akan mempunyai set kebergantungan sendiri, dengan itu mengurangkan risiko konflik. Anda juga boleh menggunakan alat seperti CGR, yang mencipta pemasangan terpencil untuk setiap pakej, dengan itu mengelakkan isu pergantungan global.
cgr Bagaimana saya boleh membantu mengelakkan masalah pergantungan global?
cgr (komposer global memerlukan) adalah alat untuk membuat pemasangan terpencil untuk setiap pakej. Ini bermakna setiap pakej dan kebergantungannya dipasang dalam direktori berasingannya sendiri, mengelakkan risiko konflik antara kebergantungan pakej yang berbeza. Ini menjadikannya alternatif yang lebih selamat untuk menggunakan keperluan global komposer.
Bagaimana cara memasang dan menggunakan CGR?
Untuk memasang CGR, anda boleh menggunakan arahan composer global require consolidation/cgr
. Selepas pemasangan, anda boleh menggunakan CGR seperti anda akan menggunakan keperluan global komposer. Sebagai contoh, untuk memasang pakej, anda boleh menggunakan arahan cgr require package-name
.
Apakah perbezaan antara pemasangan tempatan dan pemasangan global dalam komposer?
Dalam komposer, pemasangan tempatan bermakna pakej dan kebergantungannya dipasang di direktori projek. Ini adalah cara yang disyorkan untuk memasang pakej, kerana ia mengelakkan konflik pergantungan. Sebaliknya, pemasangan global memasang pakej dan kebergantungan mereka dalam direktori global, yang boleh membawa kepada konflik jika pakej yang berbeza memerlukan versi yang berbeza dari ketergantungan yang sama.
Bagaimana untuk menguruskan kebergantungan global dalam komposer?
Menguruskan kebergantungan global dalam komposer boleh mencabar kerana risiko konflik. Walau bagaimanapun, alat seperti CGR boleh membantu dengan membuat pemasangan terpencil untuk setiap pakej. Anda juga boleh menguruskan kebergantungan global dengan membuat projek komposer baru untuk setiap alat yang diperlukan, memastikan setiap alat mempunyai set dependensi sendiri.
Bolehkah saya menggunakan pemasangan tempatan dan global dalam komposer?
Ya, anda boleh menggunakan pemasangan tempatan dan global dalam komposer. Walau bagaimanapun, adalah disyorkan untuk menggunakan pemasangan tempatan jika mungkin untuk mengelakkan konflik pergantungan. Jika anda perlu menggunakan pakej secara global, pertimbangkan untuk menggunakan alat seperti CGR untuk membuat pemasangan terpencil.
Apakah risiko yang tidak betul menguruskan kebergantungan dalam komposer?
Menguruskan kebergantungan dalam komposer yang salah boleh membawa kepada konflik dan kesilapan. Sekiranya dua pakej memerlukan kebergantungan yang sama dari versi yang berbeza, ia boleh menyebabkan masalah debug yang sukar. Ia juga boleh menyebabkan tingkah laku yang tidak dijangka aplikasi, kerana versi kebergantungan yang berbeza mungkin mempunyai fungsi dan tingkah laku yang berbeza.
Bagaimana menyelesaikan konflik ketergantungan dalam komposer?
Untuk menyelesaikan konflik ketergantungan dalam komposer, anda boleh cuba mengemas kini pakej ke versi terkini, kerana ini dapat menyelesaikan konflik. Jika ini tidak berfungsi, anda mungkin mahu memikirkan semula pakej yang anda gunakan dan mencari alternatif yang tidak mempunyai kebergantungan yang bertentangan. Alat seperti CGR juga boleh membantu dengan membuat pemasangan terpencil untuk setiap pakej.
Bagaimana untuk menjaga kebergantungan komposer terkini?
Untuk memastikan kebergantungan komposer terkini, anda boleh menggunakan perintah composer update
. Ini mengemas kini semua pakej ke versi terbaru mereka berdasarkan kekangan versi yang dinyatakan dalam fail composer.json
. Anda juga boleh menggunakan arahan composer outdated
untuk melihat pakej mana yang tersedia untuk versi yang lebih baru.
Atas ialah kandungan terperinci Komposer Global memerlukan dianggap berbahaya?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

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

Video Face Swap
Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

Artikel Panas

Alat panas

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6
Alat pembangunan web visual

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas











JWT adalah standard terbuka berdasarkan JSON, yang digunakan untuk menghantar maklumat secara selamat antara pihak, terutamanya untuk pengesahan identiti dan pertukaran maklumat. 1. JWT terdiri daripada tiga bahagian: header, muatan dan tandatangan. 2. Prinsip kerja JWT termasuk tiga langkah: menjana JWT, mengesahkan JWT dan muatan parsing. 3. Apabila menggunakan JWT untuk pengesahan di PHP, JWT boleh dijana dan disahkan, dan peranan pengguna dan maklumat kebenaran boleh dimasukkan dalam penggunaan lanjutan. 4. Kesilapan umum termasuk kegagalan pengesahan tandatangan, tamat tempoh, dan muatan besar. Kemahiran penyahpepijatan termasuk menggunakan alat debugging dan pembalakan. 5. Pengoptimuman prestasi dan amalan terbaik termasuk menggunakan algoritma tandatangan yang sesuai, menetapkan tempoh kesahihan dengan munasabah,

Fungsi penghitungan dalam Php8.1 meningkatkan kejelasan dan jenis keselamatan kod dengan menentukan pemalar yang dinamakan. 1) Penghitungan boleh menjadi bilangan bulat, rentetan atau objek, meningkatkan kebolehbacaan kod dan keselamatan jenis. 2) Penghitungan adalah berdasarkan kelas dan menyokong ciri-ciri berorientasikan objek seperti traversal dan refleksi. 3) Penghitungan boleh digunakan untuk perbandingan dan tugasan untuk memastikan keselamatan jenis. 4) Penghitungan menyokong penambahan kaedah untuk melaksanakan logik kompleks. 5) Pemeriksaan jenis dan pengendalian ralat yang ketat boleh mengelakkan kesilapan biasa. 6) Penghitungan mengurangkan nilai sihir dan meningkatkan keupayaan, tetapi memberi perhatian kepada pengoptimuman prestasi.

Penerapan prinsip pepejal dalam pembangunan PHP termasuk: 1. Prinsip Tanggungjawab Tunggal (SRP): Setiap kelas bertanggungjawab untuk hanya satu fungsi. 2. Prinsip Terbuka dan Tutup (OCP): Perubahan dicapai melalui lanjutan dan bukannya pengubahsuaian. 3. Prinsip Penggantian Lisch (LSP): Subkelas boleh menggantikan kelas asas tanpa menjejaskan ketepatan program. 4. Prinsip Pengasingan Antara Muka (ISP): Gunakan antara muka halus untuk mengelakkan kebergantungan dan kaedah yang tidak digunakan. 5. Prinsip Inversi Ketergantungan (DIP): Modul peringkat tinggi dan rendah bergantung kepada abstraksi dan dilaksanakan melalui suntikan ketergantungan.

Sesi rampasan boleh dicapai melalui langkah -langkah berikut: 1. Dapatkan ID Sesi, 2. Gunakan ID Sesi, 3. Simpan sesi aktif. Kaedah untuk mengelakkan rampasan sesi dalam PHP termasuk: 1. Gunakan fungsi Sesi_Regenerate_ID () untuk menjana semula ID Sesi, 2. Data sesi stor melalui pangkalan data, 3.

Mengikat statik (statik: :) Melaksanakan pengikatan statik lewat (LSB) dalam PHP, yang membolehkan kelas panggilan dirujuk dalam konteks statik dan bukannya menentukan kelas. 1) Proses parsing dilakukan pada masa runtime, 2) Cari kelas panggilan dalam hubungan warisan, 3) ia boleh membawa overhead prestasi.

Prinsip reka bentuk Restapi termasuk definisi sumber, reka bentuk URI, penggunaan kaedah HTTP, penggunaan kod status, kawalan versi, dan benci. 1. Sumber harus diwakili oleh kata nama dan dikekalkan pada hierarki. 2. Kaedah HTTP harus mematuhi semantik mereka, seperti GET digunakan untuk mendapatkan sumber. 3. Kod status hendaklah digunakan dengan betul, seperti 404 bermakna sumber tidak wujud. 4. Kawalan versi boleh dilaksanakan melalui URI atau header. 5. Boots Operasi Pelanggan Hateoas melalui pautan sebagai tindak balas.

Dalam PHP, pengendalian pengecualian dicapai melalui percubaan, menangkap, akhirnya, dan membuang kata kunci. 1) blok percubaan mengelilingi kod yang boleh membuang pengecualian; 2) Blok tangkapan mengendalikan pengecualian; 3) Akhirnya Blok memastikan bahawa kod itu sentiasa dilaksanakan; 4) Lemparan digunakan untuk membuang pengecualian secara manual. Mekanisme ini membantu meningkatkan keteguhan dan mengekalkan kod anda.

Fungsi utama kelas tanpa nama dalam PHP adalah untuk membuat objek satu kali. 1. Kelas tanpa nama membenarkan kelas tanpa nama ditakrifkan secara langsung dalam kod, yang sesuai untuk keperluan sementara. 2. Mereka boleh mewarisi kelas atau melaksanakan antara muka untuk meningkatkan fleksibiliti. 3. Beri perhatian kepada prestasi dan kebolehbacaan kod apabila menggunakannya, dan elakkan berulang kali menentukan kelas tanpa nama yang sama.
