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


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/dupes  
brew tap homebrew/versions  
brew tap homebrew/homebrew-php
brew install php72
echo export PATH="$(brew --prefix homebrew/php/php72)/bin:$PATH" >> ~/.bash_profile # 代替系統自帶的 php
source ~/.bash_profile

驗證 PHP 以及 php-fpm 版本:

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.phpcomposer.com # 改為國內源

安裝 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 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM