在 macOS High Sierra 10.13 搭建 PHP 開發環境

jxlwqq發表於2017-09-28

2017 年 9 月 26 日,蘋果公司正式釋出了新一代 macOS,版本為 High Sierra (11.13)。
macOS High Sierra 預裝了 Ruby(2.3.3)、PHP(7.1.7)、Perl(5.18.2)、Python(2.7.10) 等常用的指令碼語言,以及 Apache(2.4.27) Web 伺服器。

以下是我的 MNMP(macOS-nginx-MySQL-PHP)的安裝過程。

本教程用使用了三處代替:

  • 使用 iTerm2 代替了系統自帶的命令列終端
  • 使用 nginx 代替了系統自帶的 Apache
  • 使用 PHP7.2 代替了系統自帶的 PHP7.1

安裝 iTerm2

推薦 iTerm2,iTerm2 功能強大,可以替代系統預設的命令列終端。下載解壓後,將 iTerm2 直接拖入"應用程式"目錄。

安裝 PhpStorm

推薦 JetBrains PhpStorm 作為整合開發工具。

安裝 Xcode

Xcode 是蘋果出品的包含一系列工具及庫的開發套件。透過 AppStore 安裝最新版本的 Xcode(9.0)。我們一般不會用 Xcode 來開發後端專案。但這一步也是必須的,因為 Xcode 會附帶安裝一些如 Git 等必要的軟體。

安裝 Command Line Tools for Xcode

這一步會幫你安裝許多常見的基於 Unix 的工具。Xcode 命令列工具作為 Xcode 的一部分,包含了 GCC 編譯器。在命令列中執行以下命令即可安裝:

# 安裝 Xcode Command Line Tools
xcode-select --install

當 Xcode 和 Xcode Command Line Tools 安裝完成後,你需要啟動 Xcode,並點選同意接受許可協議,然後關閉 Xcode 就可以了。這一步驟也是必須的,否則 Xcode 包含的一系列開發工具都將不可用。

安裝 Homebrew

Homebrew 作為 macOS 不可或缺的套件管理器,用來安裝、升級以及解除安裝常用的軟體。在命令列中執行以下命令即可安裝:

# 使用系統自帶的 ruby 安裝 Homebrew
/usr/bin/ruby -e "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/master/install)"

安裝後可以修改 Homebrew 源,國外源一直不是很給力,這裡我們將 Homebrew 的 git 遠端倉庫改為中國科學技術大學開源軟體映象

cd "$(brew --repo)"
git remote set-url origin git://mirrors.ustc.edu.cn/brew.git
cd "$(brew --repo)/Library/Taps/homebrew/homebrew-core"
git remote set-url origin https://github.com/Homebrew/homebrew-core.git
echo 'export HOMEBREW_BOTTLE_DOMAIN=https://mirrors.ustc.edu.cn/homebrew-bottles' >> ~/.bash_profile
source ~/.bash_profile

安裝一些必要的工具包

brew install wget
brew install autoconf
brew install openssl

安裝 nginx

這裡我們選擇 nginx 代替系統自帶的 Apache,作為我們的 Web 伺服器:

brew install nginx

安裝完成後,nginx 的一些常用命令:

sudo nginx # 啟動 nginx 服務
nginx -h # nginx 幫助資訊
sudo nginx -s stop|quit|reopen|reload # 停止|退出|重啟|過載 nginx 服務

安裝 MySQL

推薦 MySQL 作為資料庫伺服器:

brew install mysql

當然,你也可以選擇安裝 PostgreSQL 或者 MariaDB。

安裝完成後,啟動 MySQL:

mysql.server start

進入 MySQL 伺服器:

mysql -u root -p

安裝 Redis

推薦 Redis 作為 noSQL 資料庫伺服器:

brew install redis

安裝完成後,啟動 Redis:

redis-server

安裝 PHP 7.2

安裝 PHP7.2 來代替系統自帶的 PHP7.1:

brew tap homebrew/homebrew-core
brew install php72
echo export PATH="$(brew --prefix homebrew/php/php72)/bin:$PATH" >> ~/.bash_profile # 代替系統自帶的 php
echo export PATH="$(brew --prefix homebrew/php/php72)/sbin:$PATH" >> ~/.bash_profile # 代替系統自帶的 php-fpm
source ~/.bash_profile

驗證 PHP 以及 php-fpm 版本:
關閉命令列視窗,然後重新開啟 item2,檢視版本

php -v
php-fpm -v

啟動 php-fpm:

sudo killall php-fpm && sudo php-fpm

根據個人的實際開發場景,降版本安裝 php5.* 也是用類似方法,即把 php72 替換為 php56

配置 nginx.conf 檔案

透過以下命令可以檢視 nginx.conf 檔案的位置:

nginx -h

輸出:

nginx version: nginx/1.12.1
Usage: nginx [-?hvVtTq] [-s signal] [-c filename] [-p prefix] [-g directives]

Options:
  -?,-h         : this help
  -v            : show version and exit
  -V            : show version and configure options then exit
  -t            : test configuration and exit
  -T            : test configuration, dump it and exit
  -q            : suppress non-error messages during configuration testing
  -s signal     : send signal to a master process: stop, quit, reopen, reload
  -p prefix     : set prefix path (default: /usr/local/Cellar/nginx/1.12.1/)
  -c filename   : set configuration file (default: /usr/local/etc/nginx/nginx.conf)
  -g directives : set global directives out of configuration file

開啟配置檔案:

vi /usr/local/etc/nginx/nginx.conf

在檔案末尾可以看到:

include servers/*;

它將同目錄下的servers目錄裡的檔案都包含了進來,由此,我們可以在servers檔案裡建立開發專案的配置資訊:

cd servers/
vi test.conf

將以下配置資訊,寫入 test.conf檔案中:

server {
    listen 8099;
    server_name localhost;
    root /home/www/php_project;
    rewrite . /index.php;
    location / {
        index index.php index.html index.htm;
        autoindex on;
    }

    #proxy the php scripts to php-fpm
    location ~ \.php$ {
        include /usr/local/etc/nginx/fastcgi.conf;
        fastcgi_intercept_errors on;
        fastcgi_pass 127.0.0.1:9000;
    }
}

在上述的/home/www/php_project的目錄下,我們建立一個 index.php 檔案:

vi /home/www/php_project/index.php

寫入內容:

<?php
phpinfo();

重啟 nginx:

sudo nginx -s stop && sudo nginx

開啟瀏覽器,訪問localhost:8099。可以看到關於 PHP 配置的資訊。

安裝 Composer

Composer 是 PHP 用來管理依賴(dependency)關係的工具。你可以在自己的專案中宣告所依賴的外部工具庫(libraries),Composer 會幫你安裝這些依賴的庫檔案。

安裝並啟動國內映象服務:

curl -sS https://getcomposer.org/installer | php
mv composer.phar /usr/local/bin/composer
composer config -g repo.packagist composer https://packagist.laravel-china.org # 改為國內源

安裝 PHP 擴充套件

不推薦用 pecl 的方式安裝 PHP 擴充套件。以 php-redis 擴充套件為例,下載原始碼包來進行安裝:

wget https://pecl.php.net/get/redis-3.1.3.tgz # 下載原始碼包
tar -zxvf redis-3.1.3.tgz # 解壓
cd redis-3.1.3
phpize # 生成編譯配置                 
./configure # 編譯配置檢測
make # 編譯
make install # 安裝

擴充套件安裝完成後,我們還需最後一步,修改php.ini檔案,並重啟 PHP-FPM:

# 追加 extension=redis.so
vi /usr/local/etc/php/7.2/php.ini

# 重啟 php-fpm
sudo killall php-fpm && sudo php-fpm -D

# 檢視是否安裝成功
php -m |grep redis 
本作品採用《CC 協議》,轉載必須註明作者和本文連結

相關文章