Skip to content
Thuan Bui's Blog
Go back

Hướng dẫn cài đặt Nginx, PHP-FPM, MariaDB và phpMyAdmin trên MacOS sử dụng Homebrew

Updated:

Có nhiều cách để giả lập môi trường máy chủ trên máy tính cá nhân để phục vụ nhu cầu phát triển web.

Mình đã thử qua nhiều cách khác nhau để tạo môi trường phát triển web trên máy tính nhưng tất cả các phương pháp kể trên đều không đáp ứng được đúng nhu cầu.

Lý do mình cần tạo môi trường máy chủ ảo với Nginx và MariaDB do tất cả các VPS (Virtual Private Server) mình đang dùng đều đang chạy EasyEngine (Nginx + MariaDB + PHP-FPM 5.6). Mình muốn thiết lập môi trường giả lập trên máy tính tương tự như trên VPS để hạn chế lỗi khi đồng bộ qua lại giữa localhost và server.

Mình chọn cách tự cài đặt và cấu hình các ứng dụng máy chủ cần thiết trực tiếp lên Macbook của mình (không sử dụng máy chủ VirtualBox). Tuy hơi mất thời gian cài đặt ban đầu, nhưng sẽ bảo đảm độ ổn định sử dụng lâu dài.

Dưới đây là các bước cài đặt trọn bộ Nginx + MariaDB + PHP-FPM 5.6 + phpMyAdmin trên Macbook Air chạy hệ điều hành Sierra 10.12.3

I. Cài đặt XCode

Đầu tiên, cần phải cài đặt chương trình Xcode từ App store: Link

Trên thực tế, chúng ta không cần dùng Xcode trong quá trình phát triển web. Lý do phải cài đặt nó vì Homebrew (sẽ nói trong phần sau) cần sử dụng vài ứng dụng đi kèm với Xcode.

Sau đỏ mở Terminal và cài đặt tiếp Xcode command line tools:

Terminal window
xcode-select --install

Sau đó các bạn mở ứng dụng Xcode vừa cài đặt, bấm ⌘ + , để truy cập mục Preferences. Chuyển đến mục Locations và chọn Command Line Tools  phiên bản mới nhất vừa cài đặt. Ví dụ dưới đây là Xcode 8.1

II. Cài đặt Homebrew

Homebrew là phần mềm quản lý các gói chương trình trên OS X - tương tự như apt trên Linux.

Terminal window
ruby -e "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/master/install)"

Chạy lệnh sau để kiểm tra xem hệ thống có gặp vấn đề gì với homebrew không.

Terminal window
brew doctor

Nếu bạn cài đặt trên hệ điều hành Sierra mới cóng, chắc chắn sẽ không có lỗi gì và sẽ thấy thông báo dưới đây

Your system is ready to brew.

Chạy tiếp lệnh sau để chắc chắn bạn đang sử dụng Homebrew phiên bản mới nhất

Terminal window
brew update && brew upgrade

III. Cài đặt Nginx

Cài dặt Nginx bằng lệnh sau:

Terminal window
brew install nginx

Cấu hình

Đầu tiên bạn cần phải thiết lập quyền root cho Nginx:

Terminal window
sudo cp -v /usr/local/opt/nginx/*.plist /Library/LaunchDaemons/
sudo chown root:wheel /Library/LaunchDaemons/homebrew.mxcl.nginx.plist

Chạy thử

Khởi động Nginx bằng lệnh sau:

Terminal window
sudo launchctl load /Library/LaunchDaemons/homebrew.mxcl.nginx.plist

Mặc định Nginx sẽ sử dụng cổng 8080 thay vì cổng 80 của HTTP. Thử nghiệm xem Nginx đã hoạt động chưa bằng lệnh

Terminal window
curl -IL http://127.0.0.1:8080

Bạn sẽ thấy kết quả báo lại như sau nếu Nginx đã hoạt động.

Terminal window
HTTP/1.1 200 OK
Server: nginx/1.6.2
Date: Mon, 19 Oct 2014 19:07:47 GMT
Content-Type: text/html
Content-Length: 612
Last-Modified: Mon, 19 Oct 2014 19:01:32 GMT
Connection: keep-alive
ETag: "5444dea7-264"
Accept-Ranges: bytes

Tạm thời tắt Nginx để cài đặt tiếp các ứng dụng khác.

Terminal window
sudo launchctl unload /Library/LaunchDaemons/homebrew.mxcl.nginx.plist

IV. Cài đặt PHP-FPM

Chạy các lệnh sau để cài đặt PHP-FPM

Terminal window
brew tap homebrew/dupes
brew tap homebrew/php
brew install --without-apache --with-fpm --with-mysql php56

Homebrew sẽ tải mã nguồn và thực hiện compile trên máy tính của bạn. Sẽ mất vài phút tuỳ theo tốc độ mạng, chịu khó đợi chút nhé.

Cấu hình PHP CLI binary

Chạy lênh sau để cấu hình hệ thống sử dụng Bash shell mặc định

Terminal window
echo 'export PATH="/usr/local/sbin:$PATH"' >> ~/.bash_profile && . ~/.bash_profile

Cấu hình tự khởi động PHP-FPM

Chạy lệnh sau để cấu hình PHP-FPM tự động chạy mỗi khi khởi động máy

Terminal window
mkdir -p ~/Library/LaunchAgents
ln -sfv /usr/local/opt/php56/homebrew.mxcl.php56.plist ~/Library/LaunchAgents/

Khởi động ngay PHP-FPM bằng lệnh dưới đây:

Terminal window
launchctl load -w ~/Library/LaunchAgents/homebrew.mxcl.php56.plist

Để kiểm tra PHP-FPM có hoạt động chưa, dùng lệnh:

Terminal window
lsof -Pni4 | grep LISTEN | grep php

Kết quả bạn nhận được sẽ như sau nếu hệ thống hoạt động đúng.

Terminal window
php-fpm 69659 frdmn 6u IPv4 0x8d8ebe505a1ae01 0t0 TCP 127.0.0.1:9000 (LISTEN)
php-fpm 69660 frdmn 0u IPv4 0x8d8ebe505a1ae01 0t0 TCP 127.0.0.1:9000 (LISTEN)
php-fpm 69661 frdmn 0u IPv4 0x8d8ebe505a1ae01 0t0 TCP 127.0.0.1:9000 (LISTEN)
php-fpm 69662 frdmn 0u IPv4 0x8d8ebe505a1ae01 0t0 TCP 127.0.0.1:9000 (LISTEN)

V. Cài đặt MariaDB

Kế tiếp là cài đặt MariaDB (phiên bản tối ưu của MySQL)

Terminal window
brew install mysql

Kế tiếp, chạy lệnh sau để Mac tự động chạy MariaDB mỗi khi máy khởi động

Terminal window
ln -sfv /usr/local/opt/mariadb/*.plist ~/Library/LaunchAgents

Để khởi động MariaDB ngay bây giờ, chạy lệnh:

Terminal window
launchctl load ~/Library/LaunchAgents/homebrew.mxcl.maria.plist

Bảo mật hệ thống

Để bảo mật cơ sở dữ liệu, chúng ta cần cấu hình hệ thống để thay đổi mật khẩu root và tinh chỉnh vài thông số.

Terminal window
mysql_secure_installation
Terminal window
> Enter current password for root (enter for none):

Nhấn ENTER vì root chưa có mật khẩu.

Terminal window
Change the root password? [Y/n]

Nhấn ENTER để bắt đầu thiết lập mật khẩu root

Terminal window
> Remove anonymous users? [Y/n]

Nhấn ENTER.

Terminal window
> Disallow root login remotely? [Y/n]

Nhấn ENTER — Bạn không cần remote login khi cài đặt SQL trên máy tính cá nhân

Terminal window
> Remove test database and access to it? [Y/n]

Nhấn ENTER — Không cần dùng đến các cơ sở dữ liệu có sẵn

Terminal window
> Reload privilege tables now? [Y/n] ENTER — Áp dụng những thay đổi ngay lập tức.

Chạy thử nghiệm

Terminal window
>mysql -uroot -p

Nhập vào mật khẩu root bạn vừa thiết lập ở bước trên. Nếu MySQL hoạt động bạn sẽ thấy hiện ra như sau:

Terminal window
Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.
mysql>

Bạn thoát ra bằng cách gõ \q:

Terminal window
mysql> \q
Bye

VI. Cài đặt phpMyAdmin

Trước tiên bạn cần cài đặt autoconf trước khi cài phpMyAdmin:

Terminal window
brew install autoconf

Chạy tiếp lệnh sau

Terminal window
echo 'PHP_AUTOCONF="'$(which autoconf)'"' >> ~/.bash_profile && . ~/.bash_profile

Bây giờ cài phpMyAdmin

Terminal window
brew install phpmyadmin

VII. Cấu hình hệ thống

Sau khi đã cài đặt toàn bộ các gói phần mềm cần thiết, chúng ta cần làm thêm bước cấu hình hệ thống để các thành phần hoạt động trơn tru với nhau.

Cấu hình nginx.conf

Đầu tiên cần tạo một số thư mục để sử dụng cấu hình trong những bước sau:

Terminal window
mkdir -p /usr/local/etc/nginx/logs
mkdir -p /usr/local/etc/nginx/sites-available
mkdir -p /usr/local/etc/nginx/sites-enabled
mkdir -p /usr/local/etc/nginx/conf.d
mkdir -p /usr/local/etc/nginx/ssl
sudo mkdir -p /var/www
sudo chown :staff /var/www
sudo chmod 775 /var/www

Kế tiếp, thay thế file cấu hình nginx.conf mặc định bằng file cấu hình tối ưu

Terminal window
rm /usr/local/etc/nginx/nginx.conf
curl -L https://gist.github.com/frdmn/7853158/raw/nginx.conf -o /usr/local/etc/nginx/nginx.conf

File này đã được tối ưu, loại bỏ các thiết lập không cần thiết so với file mặc định nginx.conf.default

Cấu hình PHP-FPM

Kế tiếp, tải file cấu hình PHP-FPM

Terminal window
curl -L https://gist.github.com/frdmn/7853158/raw/php-fpm -o /usr/local/etc/nginx/conf.d/php-fpm

Cấu hình Virtual Host mặc định

Terminal window
curl -L https://gist.github.com/frdmn/7853158/raw/sites-available_default -o /usr/local/etc/nginx/sites-available/default
curl -L https://gist.github.com/frdmn/7853158/raw/sites-available_default-ssl -o /usr/local/etc/nginx/sites-available/default-ssl
curl -L https://gist.github.com/frdmn/7853158/raw/sites-available_phpmyadmin -o /usr/local/etc/nginx/sites-available/phpmyadmin

Tiếp theo, tải các file mặc định để sử dụng cho trang localhost 127.0.0.1

Terminal window
git clone http://git.frd.mn/frdmn/nginx-virtual-host.git /var/www
rm -rf /var/www/.git

Cấu hình SSL

Bước này để tạo SSL certificates và private keys. Các bạn có thể bỏ qua không cần làm.

Tạo thư mục để chứa các file certificate và keys

Terminal window
mkdir -p /usr/local/etc/nginx/ssl

Tạo certificate và RSA key bằng lệnh sau

Terminal window
openssl req -new -newkey rsa:4096 -days 365 -nodes -x509 -subj "/C=US/ST=State/L=Town/O=Office/CN=localhost" -keyout /usr/local/etc/nginx/ssl/localhost.key -out /usr/local/etc/nginx/ssl/localhost.crt
openssl req -new -newkey rsa:4096 -days 365 -nodes -x509 -subj "/C=US/ST=State/L=Town/O=Office/CN=phpmyadmin" -keyout /usr/local/etc/nginx/ssl/phpmyadmin.key -out /usr/local/etc/nginx/ssl/phpmyadmin.crt

Kích hoạt Virtual Host

Terminal window
ln -sfv /usr/local/etc/nginx/sites-available/default /usr/local/etc/nginx/sites-enabled/default
ln -sfv /usr/local/etc/nginx/sites-available/default-ssl /usr/local/etc/nginx/sites-enabled/default-ssl
ln -sfv /usr/local/etc/nginx/sites-available/phpmyadmin /usr/local/etc/nginx/sites-enabled/phpmyadmin

Khởi động Nginx để kiểm tra kết quả

Terminal window
sudo launchctl load /Library/LaunchDaemons/homebrew.mxcl.nginx.plist

Kiểm tra kết quả

Tất cả các bước xem như đã xong 99%. Bạn có thể kiểm tra xem hệ thống đã hoạt động ổn định chưa. Truy cập các địa chỉ sau và xem kết quả có đúng như bảng không

Virtual hostKết quả
http://localhostTrang thông báo “Nginx works”
http://localhost/infophpinfo() status
http://localhost/nopeTrang “Not Found”
https://localhost:443Trang “Nginx works” (SSL)
https://localhost:443/infophpinfo() (SSL)
https://localhost:443/nopeTrang “Not Found” (SSL)
https://localhost:306phpMyAdmin (SSL)

VIII. Cấu hình lệnh điều khiển

Mặc định, mỗi khi cần tắt mở hay khởi động lại Nginx/PHP/MySQL, chúng ta phải gõ lệnh rất dài, ví dụ như lệnh sau để khởi động Nginx:

Terminal window
sudo launchctl load /Library/LaunchDaemons/homebrew.mxcl.nginx.plist

Câu lệnh này quá dài dòng và khó nhớ nên chúng ta cần làm thêm bước Cấu hình lệnh điều khiển để có thể ra lệnh tắt/mở hệ thống đơn giản dễ nhớ hơn.

Cách làm khá đơn giản, chỉ cần chạy các lệnh sau là xong:

Terminal window
curl -L https://gist.github.com/frdmn/7853158/raw/bash_aliases -o /tmp/.bash_aliases
cat /tmp/.bash_aliases >> ~/.bash_aliases
echo "source ~/.bash_aliases" >> ~/.bash_profile && . ~/.bash_profile

Nginx

Tắt/mở hay khởi động lại Nginx bằng các lệnh sau

Terminal window
nginx.start
nginx.stop
nginx.restart

Kiểm tra log:

Terminal window
nginx.logs.access
nginx.logs.default.access
nginx.logs.phpmyadmin.access
nginx.logs.default-ssl.access
nginx.logs.error
nginx.logs.phpmyadmin.error

Kiểm tra cấu hình Nginx

Terminal window
sudo nginx -t

PHP-FPM

Tắt/mở hay khởi động lại PHP-FPM:

Terminal window
php-fpm.start
php-fpm.stop
php-fpm.restart

Kiểm tra cấu hình:

Terminal window
php-fpm -t

MariaDB (MySQL)

Tắt/mở hay khởi động lại MySQL:

Terminal window
mysql.start
mysql.stop
mysql.restart

IX.Thiết lập Virtual Host

Sau khi hoàn thành bước VIII, bạn đã có thể copy file vào thư mục /var/www/  để bắt đầu làm việc. Truy cập trực tiêp web qua địa chỉ http://localhost

Tuy nhiên trên máy Mac, muốn truy cập vào thư mục /var/www/  rất phiền phức. Chỉ có cách dùng Terminal, không dùng được các chương trình editor như Sublime Text hay Visual Code Studio để chỉnh sửa code. Ngoài ra, bạn cũng không thể tạo ra nhiều tên miền ảo dạng như thuanbui.dev, thuandeptrai.dev,…

Do đó mình làm thêm bước này để có thể tạo nhiều tên miền ảo cho từng dự án. Đồng thời dễ dàng quản lý file bằng Finder.

Cài đặt DNSMasq

Để máy tính có thể truy cập các tên miền ảo .dev , chúng ta cần phải cấu hình DNS bằng cách chỉnh sửa file /etc/hosts. Ví dụ mình cần tạo ra tên miền thuanbui.dev, thêm dòng này vào /etc/hosts

Terminal window
127.0.0.1 thuanbui.dev.

Phiền phức ở chỗ mỗi lần tạo ra tên miền mới, chúng ta phải quay lại chỉnh sửa mất thời gian.

Giải quyết vấn đề này bằng cách dùng DNSMasq:

Terminal window
brew install dnsmasq

Sau đó thiết lập cấu hình file dnsmasq.conf trong thư mực /usr/local/etc/.

Terminal window
sudo nano /usr/local/etc/dnsmasq.conf

Thêm dòng này vào và lưu lại

Terminal window
address=/.dev/127.0.0.1

Dòng này sẽ yêu cầu hệ thống điều hướng tất cả các tên miền dạng .dev về địa chỉ IP của localhost, 127.0.0.1

Tiếp theo, cấu hình dnsmaq tự động chạy khi khởi động máy

Terminal window
sudo cp -fv /usr/local/opt/dnsmasq/*.plist /Library/LaunchDaemons
sudo launchctl load /Library/LaunchDaemons/homebrew.mxcl.dnsmasq.plist

Cuối cùng, bạn cần phải chỉnh cấu hình DNS của Mac OS. Truy cập System Preferences và chọn Network. Vào phần DNS và thêm IP Localhost (127.0.0.1) vào đầu danh sách các IP của DNS:

Terminal window
127.0.0.1
8.8.8.8
8.8.4.4

Vậy là xong, bạn có thể ping thử bất kỳ tên miền nào kết thúc bằng đuôi .dev, hệ thống sẽ trả về IP tương ứng là 127.0.0.1

Terminal window
$ ping thuanbui.dev
PING thuanbui.dev (127.0.0.1): 56 data bytes

Tạo Virtual Host cho tên miền .dev

Mình muốn tạo ra tên miền thuanbui.dev để làm việc trên localhost. Đầu tiên, thiết lập thư mục root của tên miền để chứa file

Terminal window
mkdir -p /Users/thuanbui/Sites/thuanbui.dev/public

Chú ý:

Kế tiếp, tạo file cấu hình nginx cho tên miền thuanbui.dev

Terminal window
sudo nano /usr/local/etc/nginx/sites-available/thuanbui.dev

Tuỳ theo mã nguồn bạn sử dụng mà cấu hình sẽ khác nhau. Dưới đây là ví dụ file cấu hình mình sử dụng để chạy WordPress

server {
listen 80;
server_name thuanbui.dev www.thuanbui.dev;
root /Users/thuanbui/Sites/thuanbui.dev/public;
location / {
try_files $uri $uri/ /index.php?$args;
}
index index.php index.html index.htm;
include /usr/local/etc/nginx/conf.d/php-fpm;
}

Chạy tiếp lệnh này để tạo file cấu hình trong thư mục sites-enables

Terminal window
ln -s /usr/local/etc/nginx/sites-available/thuanbui.dev /usr/local/etc/nginx/sites-enabled/thuanbui.dev

Khởi động lại nginx

Terminal window
nginx.restart

Vậy là xong. Từ giờ bạn có thể tải mã nguồn WordPress vào thư mục /Users/thuanbui/Sites/thuanbui.dev/public sau đó truy cập http://thuanbui.dev để bắt đầu làm việc.

Làm lại các bước tương tự nếu bạn cần tạo thêm nhiều tên miền .dev khác.


Bài viết được tổng hợp từ 2 bài hướng dẫn tiếng Anh dưới đây:


Share this post on:

Previous Post
Cấu hình SSL (https) cho Sendy trên máy chủ Nginx (EasyEngine)
Next Post
Tải mã nguồn website html xuống máy tính bằng Wget