Thứ ba, 17/05/2016 | 00:00 GMT+7

Cách cài đặt và sử dụng Composer trên Ubuntu 16.04

Composer là một công cụ quản lý phụ thuộc phổ biến cho PHP, được tạo ra chủ yếu để hỗ trợ cài đặt và cập nhật cho các phụ thuộc dự án. Nó sẽ kiểm tra các gói khác mà một dự án cụ thể phụ thuộc vào và cài đặt chúng cho bạn, sử dụng các version phù hợp theo yêu cầu của dự án.

Hướng dẫn này sẽ giải thích cách cài đặt và bắt đầu với Composer trên hệ thống Ubuntu 16.04.

Yêu cầu

Đối với hướng dẫn này, bạn cần :

  • Hệ thống chạy Ubuntu 16.04
  • Truy cập vào server với quyền là regular user với quyền sudo

Bước 1 - Cài đặt Phụ thuộc

Trước khi ta download và cài đặt Composer, ta cần đảm bảo server của ta đã cài đặt tất cả các phần phụ thuộc.

Trước tiên, hãy cập nhật cache ẩn của trình quản lý gói bằng lệnh:

  • sudo apt-get update

Bây giờ, hãy cài đặt các phụ thuộc. Ta cần curl để download Composer và php-cli để cài đặt và chạy nó. Gói php-mbstring là cần thiết để cung cấp các chức năng cho thư viện mà ta sẽ sử dụng. git được sử dụng bởi Composer để download các phụ thuộc của dự án và unzip để extract các gói đã nén. Mọi thứ có thể được cài đặt bằng lệnh sau:

  • sudo apt-get install curl php-cli php-mbstring git unzip

Đến đây bạn có thể tiến hành bước tiếp theo.

Bước 2 - Download và cài đặt composer

Composer cung cấp một trình cài đặt, được viết bằng PHP. Đảm bảo rằng bạn đang ở trong folder chính và truy xuất trình cài đặt bằng curl :

  • cd ~
  • curl -sS https://getcomposer.org/installer -o composer-setup.php

Tiếp theo, chạy một tập lệnh PHP ngắn để xác minh trình cài đặt trùng với hàm băm SHA-384 cho trình cài đặt mới nhất được tìm thấy trên trang Khóa / Chữ ký của Người soạn thảo . Bạn cần đảm bảo bạn thay thế hàm băm mới nhất cho giá trị được đánh dấu bên dưới:

  • php -r "if (hash_file('SHA384', 'composer-setup.php') === '669656bab3166a7aff8a7506b8cb2d1c292f042046c5a994c43155c0be6190fa0355160742ab2e1c88d40d5be660b410') { echo 'Installer verified'; } else { echo 'Installer corrupt'; unlink('composer-setup.php'); } echo PHP_EOL;"
Đầu ra
Installer verified 

Để cài đặt trình composer trên phạm vi global , hãy sử dụng cách sau:

sudo php composer-setup.php --install-dir=/usr/local/bin --filename=composer 

Thao tác này sẽ download và cài đặt Composer dưới dạng một lệnh trên toàn hệ thống có tên là composer , trong /usr/local/bin . Đầu ra sẽ như thế này:

Output
All settings correct for using Composer Downloading 1.1.1... Composer successfully installed to: /usr/local/bin/composer Use it: php /usr/local/bin/composer

Để kiểm tra cài đặt của bạn, hãy chạy:

  • composer

Và bạn sẽ nhận được kết quả tương tự như sau:

Output
______ / ____/___ ____ ___ ____ ____ ________ _____ / / / __ \/ __ `__ \/ __ \/ __ \/ ___/ _ \/ ___/ / /___/ /_/ / / / / / / /_/ / /_/ (__ ) __/ / \____/\____/_/ /_/ /_/ .___/\____/____/\___/_/ /_/ Composer version 1.1.1 2016-05-17 12:25:44 Usage: command [options] [arguments] Options: -h, --help Display this help message -q, --quiet Do not output any message -V, --version Display this application version --ansi Force ANSI output --no-ansi Disable ANSI output -n, --no-interaction Do not ask any interactive question --profile Display timing and memory usage information --no-plugins Whether to disable plugins. . . .

Điều này nghĩa là Composer đã được cài đặt thành công trên hệ thống.

Nếu bạn muốn có các file thực thi Composer riêng biệt cho từng dự án mà bạn lưu trữ trên server này, bạn có thể chỉ cần cài đặt nó local , trên cơ sở từng dự án. User NPM sẽ quen thuộc với cách tiếp cận này. Phương pháp này cũng hữu ích khi user hệ thống của bạn không có quyền cài đặt phần mềm trên toàn hệ thống.

Trong trường hợp này, cài đặt có thể được thực hiện, sau khi download và xác minh lệnh cài đặt như trên, như sau:

  • php composer-setup.php

Thao tác này sẽ tạo file composer.phar trong folder hiện tại của bạn, file này có thể được thực thi bằng ./composer.phar command .

Bước 3 - Tạo file composer.json

Để sử dụng Composer trong dự án của bạn , bạn cần có file composer.json . Về cơ bản, file composer.json cho Composer biết những phụ thuộc nào nó cần download cho dự án của bạn và version nào của mỗi gói được phép cài đặt. Điều này cực kỳ quan trọng để giữ cho dự án của bạn nhất quán và tránh cài đặt các version không ổn định có thể gây ra các vấn đề tương thích ngược.

Bạn không cần phải tạo file này theo cách thủ công - rất dễ gặp lỗi cú pháp khi bạn làm như vậy. Composer tự động tạo ra các composer.json file khi bạn thêm một phụ thuộc vào dự án của bạn bằng cách sử dụng require lệnh. Các phần phụ thuộc bổ sung cũng có thể được thêm theo cách tương tự mà không cần phải chỉnh sửa file này theo cách thủ công.

Quá trình sử dụng Composer để cài đặt một gói phụ thuộc trong một dự án thường bao gồm các bước sau:

  • Xác định loại thư viện mà ứng dụng cần
  • Nghiên cứu thư viện open-souce phù hợp trên Packagist.org , repository chính thức cho Composer
  • Chọn gói bạn muốn phụ thuộc vào
  • Run composer require bao gồm phần phụ thuộc trong file composer.json và cài đặt gói

Ta sẽ xem điều này hoạt động như thế nào trong thực tế với một ứng dụng demo đơn giản.

Mục tiêu của ứng dụng này là chuyển đổi một câu đã cho thành một chuỗi thân thiện với URL - một slug . Điều này thường được sử dụng để chuyển đổi tiêu đề trang thành đường dẫn URL (như phần cuối cùng của URL cho hướng dẫn này).

Hãy bắt đầu bằng cách tạo một folder cho dự án của ta . Ta sẽ gọi nó là slugify :

  • cd ~
  • mkdir slugify
  • cd slugify

Tìm kiếm các Gói hàng trên Packagist

Bây giờ đã đến lúc tìm kiếm Packagist.org cho một gói có thể giúp ta tạo ra slug . Nếu bạn tìm kiếm cụm từ “slug” trên Packagist, bạn sẽ nhận được kết quả tương tự như sau:

Packagist Search: easy-slug / easy-slug, muffin / slug, ddd / slug, zelenin / slug, webcastle / slug, anomaly / slug-field_type

Bạn sẽ thấy hai số ở bên phải của mỗi gói trong danh sách. Số ở trên cùng biểu thị số lần gói được cài đặt và số ở dưới cùng cho biết số lần một gói được gắn dấu sao trên GitHub. Bạn có thể sắp xếp lại thứ tự các kết quả tìm kiếm dựa trên những con số này (tìm hai biểu tượng ở bên phải của thanh tìm kiếm). Nói chung, các gói có nhiều cài đặt hơn và nhiều sao hơn có xu hướng ổn định hơn, vì có rất nhiều người đang sử dụng chúng. Điều quan trọng là kiểm tra mô tả gói để biết mức độ liên quan - đó có thực sự là thứ bạn đang tìm kiếm?

Những gì ta cần là một công cụ chuyển đổi string-to-slug đơn giản. Từ kết quả tìm kiếm, gói cocur/slugify có vẻ là một kết hợp tốt, với số lượng cài đặt hợp lý và số sao. (Gói hàng ở phía dưới trang xa hơn một chút so với ảnh chụp màn hình.)

Bạn sẽ nhận thấy rằng các gói trên Packagist có tên nhà cung cấp và tên gói . Mỗi gói có một định danh duy nhất (một không gian tên) ở cùng một định dạng mà GitHub sử dụng cho các kho của nó: vendor/package . Thư viện ta muốn cài đặt sử dụng không gian tên cocur/slugify Không gian tên là thứ ta cần để yêu cầu gói trong dự án của ta .

Yêu cầu một gói

Bây giờ ta biết chính xác gói nào ta muốn cài đặt, ta có thể chạy trình composer require để bao gồm nó làm phụ thuộc và cũng tạo file composer.json cho dự án:

  • composer require cocur/slugify
Output
Using version ^2.1 for cocur/slugify ./composer.json has been created Loading composer repositories with package information Updating dependencies (including require-dev) - Installing cocur/slugify (v2.1.1) Downloading: 100% Writing lock file Generating autoload files

Như bạn thấy từ kết quả , Composer tự động quyết định version của gói nên được sử dụng. Nếu bạn kiểm tra folder của dự án ngay bây giờ, nó sẽ chứa hai file mới: composer.jsoncomposer.lock , và một folder vendor :

  • ls -l
Output
total 12 -rw-rw-r-- 1 sammy sammy 59 May 17 10:24 composer.json -rw-rw-r-- 1 sammy sammy 2894 May 17 10:24 composer.lock drwxrwxr-x 4 sammy sammy 4096 May 17 10:24 vendor

Tệp composer.lock được sử dụng để lưu trữ thông tin về version nào của mỗi gói được cài đặt và đảm bảo các version tương tự được sử dụng nếu ai đó sao chép dự án của bạn và cài đặt các phần phụ thuộc của nó. Thư mục vendor là nơi chứa các phụ thuộc của dự án. Các vendor folder không nên được commit vào điều khiển version - bạn chỉ cần bao gồm các file composer.jsoncomposer.lock.

Khi cài đặt một dự án đã chứa file composer.json , bạn cần chạy composer install để download các phụ thuộc của dự án.

Hiểu các ràng buộc về version

Nếu bạn kiểm tra nội dung của file composer.json của bạn , bạn sẽ thấy thông tin như sau:

  • cat composer.json
Output
  • {
  • "require": {
  • "cocur/slugify": "^2.1"
  • }
  • }

Bạn có thể nhận thấy ký tự đặc biệt ^ trước số version trong composer.json . Composer hỗ trợ một số ràng buộc và định dạng khác nhau để xác định version gói yêu cầu, nhằm cung cấp tính linh hoạt trong khi vẫn giữ cho dự án của bạn ổn định. Toán tử dấu mũ ( ^ ) được sử dụng bởi file composer.json được tạo tự động là toán tử được khuyến khích để có khả năng tương tác tối đa, sau cách lập phiên bản ngữ nghĩa . Trong trường hợp này, nó xác định 2.1 là version tương thích tối thiểu và cho phép cập nhật lên bất kỳ version nào trong tương lai dưới 3.0 .

Nói chung, bạn sẽ không cần phải can thiệp vào các ràng buộc version trong file composer.json của bạn . Tuy nhiên, một số tình huống có thể yêu cầu bạn chỉnh sửa các ràng buộc theo cách thủ công - ví dụ: khi một version mới chính của thư viện yêu cầu của bạn được phát hành và bạn muốn nâng cấp hoặc khi thư viện bạn muốn sử dụng không tuân theo cách lập version ngữ nghĩa.

Dưới đây là một số ví dụ để bạn hiểu rõ hơn về cách hoạt động của các ràng buộc version Composer:

Hạn chế Ý nghĩa Các version mẫu được phép
^ 1,0 > = 1,0 <2,0 1.0, 1.2.3, 1.9.9
^ 1.1.0 > = 1.1.0 <2.0 1.1.0, 1.5.6, 1.9.9
~ 1.0 > = 1,0 <2,0,0 1.0, 1.4.1, 1.9.9
~ 1.0.0 > = 1.0.0 <1.1 1.0.0, 1.0.4, 1.0.9
1.2.1 1.2.1 1.2.1
1. * > = 1,0 <2,0 1.0.0, 1.4.5, 1.9.9
1.2. * > = 1,2 <1,3 1.2.0, 1.2.3, 1.2.9

Để có cái nhìn chuyên sâu hơn về các ràng buộc của version Composer, hãy đọc tài liệu chính thức .

Bước 4 - Bao gồm Tập lệnh Tự động tải

Vì bản thân PHP không tự động xử lý việc tải các lớp, Composer cũng cung cấp một tập lệnh tự động tải mà bạn có thể đưa vào dự án của bạn để tự động tải miễn phí. Điều này làm cho việc làm việc với các phụ thuộc và xác định không gian tên của bạn dễ dàng hơn nhiều.

Điều duy nhất bạn cần làm là đưa file vendor/autoload.php vào các tập lệnh PHP của bạn, trước khi khởi tạo bất kỳ lớp nào.

Hãy quay lại ứng dụng ví dụ slugify . Ta sẽ sử dụng nano để tạo tập lệnh test.php trong đó ta sẽ sử dụng thư viện cocur / slugify :

  • nano test.php
test.php
  • <?php
  • require __DIR__ . '/vendor/autoload.php';
  • use Cocur\Slugify\Slugify;
  • $slugify = new Slugify();
  • echo $slugify->slugify('Hello World, this is a long sentence and I need to make a slug from it!');

Bạn có thể chạy tập lệnh trong dòng lệnh với:

  • php test.php

Điều này sẽ tạo ra kết quả hello-world-this-is-a-long-sentence-and-i-need-to-make-a-slug-from-it .

Bước 5 - Cập nhật các phụ thuộc của dự án

Khi nào bạn muốn cập nhật các phụ thuộc dự án của bạn , bạn chỉ cần chạy lệnh update :

  • composer update

Điều này sẽ kiểm tra các version mới hơn của các thư viện mà bạn yêu cầu trong dự án của bạn . Nếu tìm thấy version mới hơn và nó tương thích với giới hạn version được xác định trong file composer.json , version đó sẽ thay thế version đã cài đặt trước đó. Tệp composer.lock sẽ được cập nhật để áp dụng thay đổi này.

Bạn cũng có thể cập nhật một hoặc nhiều thư viện cụ thể bằng lệnh:

  • composer update vendor/package vendor2/package2

Kết luận

Hướng dẫn này bao gồm những điều cần thiết để bắt đầu với Composer trên Ubuntu 16.04. Composer là một công cụ mạnh mẽ mà mọi nhà phát triển PHP nên có trong vành đai tiện ích của họ.

Ngoài việc cung cấp một cách dễ dàng và tin cậy để quản lý các phụ thuộc của dự án, nó còn cài đặt một tiêu chuẩn thực tế mới để chia sẻ và khám phá các gói PHP do cộng đồng tạo ra.


Tags:

Các tin liên quan

Cách tập trung log với Rsyslog, Logstash và Elasticsearch trên Ubuntu 14.04
2016-05-16
Cách cài đặt và cấu hình Elasticsearch trên Ubuntu 16.04
2016-05-04
Cách cài đặt và cấu hình VNC trên Ubuntu 16.04
2016-04-26
Cách thêm không gian swap trên Ubuntu 16.04
2016-04-25
Cách cài đặt WordPress với LEMP trên Ubuntu 16.04
2016-04-25
Cách cài đặt Java với Apt-Get trên Ubuntu 16.04
2016-04-23
Cách cài đặt WordPress với LAMP trên Ubuntu 16.04
2016-04-22
Cách thêm và xóa người dùng trên Ubuntu 16.04
2016-04-21
Cách cài đặt Git trên Ubuntu 16.04
2016-04-21
Có gì mới trong Ubuntu 16.04
2016-04-21