最近因为新买Mac M系列芯片笔记本,一直也没搭建过PHP的开发环境,花了一点时间特意在本机做了一次环境搭建测试具体如下。
软件清单
工具列表如下:
Xcode
VS Code
Homebrew
OpenSSL & wget
MySQL
Postgres
PHP多版本
Nginx
安装Xcode
xcode-select --install
VS Code安装此处略过。
安装homebrew
/bin/bash -c "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/master/install.sh)"
安装openssl与wget
brew install opensslbrew install wget
安装MySQL
brew install mysqlbrew services start mysqlbrew services list
# Intel x86 Chipset code /usr/local/etc/my.cnf | # Apple Silicon M1 Chipset code /opt/homebrew/etc/my.cnf |
my.cnf的配置
# Default Homebrew MySQL server config[mysqld]# Only allow connections from localhostbind-address = 127.0.0.1mysqlx-bind-address = 127.0.0.1 # Add mode only if neededsql_mode = "ONLY_FULL_GROUP_BY,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION"
使用安全密码
mysql_secure_installationbrew services restart mysql
PS:MySQL8认证需要更新每个用户mysql_native_password,但是用户名和密码前没有空格,请务必注意。
mysql> SHOW VARIABLES LIKE 'validate_password%';
mysql> SET GLOBAL validate_password.policy=LOW;
安装Postgres
brew install postgresqlbrew services start postgresqlbrew services listpsql postgres
确认用户列表
postgres-# \du
安装多版本PHP
在Mac电脑上安装多个PHP版本时不能使用PHP默认的自制内核,而需要使用shivammathur/php。
brew tap shivammathur/php brew install shivammathur/php/php@7.2brew install shivammathur/php/php@7.3brew install shivammathur/php/php@7.4brew install shivammathur/php/php@8.0brew install shivammathur/php/php@8.1
设置php7.4为 php CLI版本:
brew unlink phpbrew link --overwrite --force php@7.4
对于php-fpm的每个版本更新,都需要提供唯一的端口。更改每个php-fpm的端口以匹配其php版本号。例如:php@7.4,我使用的端口为9074。
此外,如果希望php-fpm在你的用户帐户上运行,而不是_www。那么文件夹路径的差异取会决于计算机的Mac处理器(Intel x86或Apple M1 ARM),这一点也是需要非常注意的。
# Intel x86 Chipset code /usr/local/etc/php/7.4/php-fpm.d/www.conf | # Apple Silicon M1 Chipset code /opt/homebrew/etc/php/7.4/php-fpm.d/www.conf |
www.conf文件配置
内容如下:
# defaultuser = _wwwgroup = _wwwlisten = 127.0.0.1:9000 # change touser = group = stafflisten = 127.0.0.1:9074
另外,在启动php-fpm前,可以在php.ini中将upload_max_filesize和post_max_size上限进行调整,比如:10M。
不同芯片的路径如下:
# Intel x86 Chipset /usr/local/etc/php/7.2/php.ini /usr/local/etc/php/7.3/php.ini /usr/local/etc/php/7.4/php.ini /usr/local/etc/php/8.0/php.ini /usr/local/etc/php/8.1/php.ini /usr/local/etc/php/8.2/php.ini | # Apple Silicon M1 Chipset /opt/homebrew/etc/php/7.2/php.ini /opt/homebrew/etc/php/7.3/php.ini /opt/homebrew/etc/php/7.4/php.ini /opt/homebrew/etc/php/8.0/php.ini /opt/homebrew/etc/php/8.1/php.ini /opt/homebrew/etc/php/8.2/php.ini |
依据不同版本启动php-fpm
命令如下:
brew services start php@7.2brew services start php@7.3brew services start php@7.4brew services start php@8.0brew services start php@8.1brew services start php@8.2
启动完成后,确认端口与进程:
Sudo lsof -i -n -P|grep php-fpm
PHP设置别名
具体操作如下:
# Intel x86 Chipset alias php72="/usr/local/opt/php@7.2/bin/php" alias php73="/usr/local/opt/php@7.3/bin/php" alias php74="/usr/local/opt/php@7.4/bin/php" alias php80="/usr/local/opt/php@8.0/bin/php" alias php81="/usr/local/opt/php@8.1/bin/php" alias php82="/usr/local/opt/php@8.2/bin/php" | # Apple Silicon M1 Chipset alias php72="/opt/homebrew/opt/php@7.2/bin/php" alias php73="/opt/homebrew/opt/php@7.3/bin/php" alias php74="/opt/homebrew/opt/php@7.4/bin/php" alias php80="/opt/homebrew/opt/php@8.0/bin/php" alias php81="/opt/homebrew/opt/php@8.1/bin/php" alias php82="/opt/homebrew/opt/php@8.2/bin/php" |
刷新环境变量:
source ~/.bash_profilesource ~/.zshrc
依据别名查看php版本
刷新后可以测试一下别名是否能够切换不同的php版本,具体如下:
php72 -v
php73 -v
php74 -v
php80 -v
php81 -v
php82 -v
默认php -v命令:
此处也提供一个更简单的手动切换php版本方法:
在~/.bash_profile加入如下代码即可。
# Make PHP switching versions easyfunction phpv() { brew unlink php brew link --overwrite --force "php@$1" php -v}
# bash functionphpv 7.4
同于手动切换版本命令:
# brewbrew unlink phpbrew link --overwrite --force php@7.4
升级PHP
关于升级的问题,如果出现升级错误,可以使用以下方式:
brew reinstall shivammathur/php/php@7.4
在WebStorm中新增debug的方法——Xdebug
这个方法是提供给喜欢在WebStorm中调试程序的小伙伴用的,不过我也喜欢,很是方便,具体配置如下:
brew link --overwrite --force php@7.2pecl uninstall -r xdebug pecl install xdebug brew link --overwrite --force php@7.3pecl uninstall -r xdebug pecl install xdebug brew link --overwrite --force php@7.4pecl uninstall -r xdebug pecl install xdebug brew link --overwrite --force php@8.0pecl uninstall -r xdebugpecl install xdebug brew link --overwrite --force php@8.1pecl uninstall -r xdebugpecl install xdebug brew link --overwrite --force php@8.2pecl uninstall -r xdebugpecl install xdebug
更新php.ini
此处对于每个不同的版本都需要更新php.ini文件,例如,我在这里仅仅是更新php7.4的,具体内容如下:
# Intel x86 Chipsetcode /usr/local/etc/php/7.4/php.ini # Apple Silicon M1 Chipsetcode /opt/homebrew/etc/php/7.4/php.ini这里有一个小问题则需要说明:需要删除zend_extension="xdebug。因为在pecl安装过程中会将其添加到php.ini文件的顶部,并且xdebug默认端口是9003。php.ini具体内容如下:[xdebug]zend_extension="xdebug.so"xdebug.mode=debugxdebug.client_port=9003xdebug.idekey=PHPSTORM
当完成xdebug的配置后,并可以关闭所有的php-fpm进程,不过在生产环境不建议开启xdebug,新的mac或者是开发环境可以这么操作,请务必注意。
Nginx
安装Nginx
命令如下:
brew install nginxsudo nginx
测试nginx安装是否成功
成功后,做测试访问(端口请自行查看配置,默认为8080/80):
修改Nginx默认配置
# Intel x86 Chipset code /usr/local/etc/nginx/nginx.conf | # Apple Silicon M1 Chipset code /opt/homebrew/etc/nginx/nginx.conf |
添加多服务器与大文件配置
在http{}内容块中添加:
# 允许多服务器配置server_names_hash_bucket_size 512; # 大文件配置client_max_body_size 100M;
端口监听
在server{}内容块中配置:
# Fromlisten 8080;server_name localhost;index index.html; # Tolisten 80;server_name localhost test.x;index index.html index.htm index.php;
配置FastCGI
这下就可以开始配置FastCGI网关了,将其添加到默认的服务器的php-fpm中,建议安装最新版本的php,对于其他的服务器配置可以按项目需求配置。
location ~ \.php$ { fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name; include fastcgi_params; fastcgi_pass 127.0.0.1:9074; fastcgi_split_path_info ^(.+\.php)(/.+)$;} charset utf-8;
添加基础安全配置
add_header X-Frame-Options "SAMEORIGIN"; add_header X-XSS-Protection "1; mode=block"; add_header X-Content-Type-Options "nosniff";
配置完成后可以建立测试文件,具体路径如下:
Intel x86芯片路径: mv /usr/local/var/www/index.html /usr/local/var/www/index.php code /usr/local/var/www/index.php | Apple Silicon M1 芯片路径: mv /opt/homebrew/var/www/index.html /opt/homebrew/var/www/index.php code /opt/homebrew/var/www/index.php |
此处我使用index.html/index.php
重载nginx
sudo nginx -s reload
访问http://localhost/或http://localhost:8080/
至此,nginx配置php单站点服务已经基本完成,可以进行初步的php开发。
下一节将讲述多站点配置。