Jadual Kandungan
akan berkembang ke
Apa yang tidak boleh/tidak boleh melakukan alat ini?
Apa yang akan datang?
Soalan Lazim Mengenai Komposer Global Memerlukan
Kenapa dianggap berbahaya untuk menggunakan keperluan global komposer?
Apakah alternatif untuk memerlukan komposer global?
cgr Bagaimana saya boleh membantu mengelakkan masalah pergantungan global?
Bagaimana cara memasang dan menggunakan CGR?
Apakah perbezaan antara pemasangan tempatan dan pemasangan global dalam komposer?
Bagaimana untuk menguruskan kebergantungan global dalam komposer?
Bolehkah saya menggunakan pemasangan tempatan dan global dalam komposer?
Apakah risiko yang tidak betul menguruskan kebergantungan dalam komposer?
Bagaimana menyelesaikan konflik ketergantungan dalam komposer?
Bagaimana untuk menjaga kebergantungan komposer terkini?
Rumah pembangunan bahagian belakang tutorial php Komposer Global memerlukan dianggap berbahaya?

Komposer Global memerlukan dianggap berbahaya?

Feb 15, 2025 pm 01:24 PM

Composer Global Require Considered Harmful?

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
apabila memasang pakej yang boleh digunakan dalam pelbagai projek (terutamanya alat baris arahan). Kemudian, suatu hari, saya dapat melihat perbincangan ini.

composer global require

Singkatnya, kebanyakan orang kini seolah -olah berfikir keperluan global adalah amalan buruk melainkan pakej yang dipasang secara global tidak mempunyai kebergantungan. Secara teknikal, ini masuk akal apabila seseorang menggunakan persekitaran tunggal untuk semua projek, tetapi seperti yang saya komen dalam perbincangan itu, apabila setiap projek menggunakan mesin maya atau persekitaran yang terpencil seperti Docker, isu ini tidak relevan, dan keadaan keseluruhannya sebenarnya tidak akan sebenarnya menyebabkan kerosakan.

Composer Global Require Considered Harmful? 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:

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

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.

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
Salin selepas log masuk
Salin selepas log masuk
Perintah di atas menggunakan laluan direktori bin Global Composer untuk melanjutkan

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
Salin selepas log masuk

maka anda boleh mengakses CGR dengan menjalankan $PATH, yang harus mengeluarkan fail bantuan umum komposer. vagrant ssh

memasang pakej komposer global dengan betul

cgr

Di Homestead bertambah baik, alias berguna dikonfigurasi, di mana menaip

akan berkembang ke

, yang sangat mudah apabila memasang
cgr phpunit/phpunit
Salin selepas log masuk
untuk setiap projek, jadi anda boleh menjalankannya dari folder root. Untuk menguji pemasangan PHPUNIT global, kita perlu memadamkan alias ini terlebih dahulu (komen garis yang sama dalam

), 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.
Salin selepas log masuk
Sudah tentu, mereka semua boleh dipasang secara normal. Mari kita periksa sama ada mereka bekerja.

composer global require consolidation/cgr
Salin selepas log masuk
Salin selepas log masuk

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!

Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

Video Face Swap

Video Face Swap

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

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas

Tutorial Java
1653
14
Tutorial PHP
1251
29
Tutorial C#
1224
24
Jelaskan JSON Web Tokens (JWT) dan kes penggunaannya dalam PHP API. Jelaskan JSON Web Tokens (JWT) dan kes penggunaannya dalam PHP API. Apr 05, 2025 am 12:04 AM

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,

Apakah penghitungan (enums) dalam Php 8.1? Apakah penghitungan (enums) dalam Php 8.1? Apr 03, 2025 am 12:05 AM

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.

Huraikan prinsip -prinsip yang kukuh dan bagaimana ia memohon kepada pembangunan PHP. Huraikan prinsip -prinsip yang kukuh dan bagaimana ia memohon kepada pembangunan PHP. Apr 03, 2025 am 12:04 AM

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.

Bagaimanakah sesi merampas kerja dan bagaimana anda dapat mengurangkannya dalam PHP? Bagaimanakah sesi merampas kerja dan bagaimana anda dapat mengurangkannya dalam PHP? Apr 06, 2025 am 12:02 AM

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.

Terangkan pengikatan statik lewat dalam php (statik: :). Terangkan pengikatan statik lewat dalam php (statik: :). Apr 03, 2025 am 12:04 AM

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.

Apakah Prinsip Reka Bentuk API REST? Apakah Prinsip Reka Bentuk API REST? Apr 04, 2025 am 12:01 AM

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.

Bagaimanakah anda mengendalikan pengecualian dengan berkesan dalam PHP (cuba, menangkap, akhirnya, membuang)? Bagaimanakah anda mengendalikan pengecualian dengan berkesan dalam PHP (cuba, menangkap, akhirnya, membuang)? Apr 05, 2025 am 12:03 AM

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.

Apakah kelas tanpa nama di PHP dan kapan anda boleh menggunakannya? Apakah kelas tanpa nama di PHP dan kapan anda boleh menggunakannya? Apr 04, 2025 am 12:02 AM

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.

See all articles