一、关闭SIP保护机制
macOS的System Integrity Protection功能,默认为开启状态,会保护相关目录,不让用户读写(对开发者很不友好),编译前需要先关闭.
* csrutil status: 可参看当前SIP状态
* 重启系统时,长按command+R键,直到出现苹果图标,单击utils->terminal,调出终端命令界面,输入csrutil disable可关闭SIP功能.系统正常启动后,此命令操作不成功.
* 操作成功后重启系统
在编译之前需要先安装相关SDK libs,可直接通过`xcode-select --install`来安装,不需安装Apple Xcode开发软件程序
macOS Catalina填坑
SDK lib安装完后,正常流程是建立相关目录软链后接即可编译.命令如下
sudo ln -s /Library/Developer/CommandLineTools/SDKs/MacOSX10.15.sdk/usr/include /usr/include
但升级至macOS Catalina之后,运行上面命令,提示'ln: /usr/include: Read-only file system'.切换至/usr下,发现没有include文件夹,自己也无法创建.通过global bing搜索发现(没装VPN),Apple在Catalina里引入了新的安全机制(https://support.apple.com/en-us/HT210650),一些系统目录被安全隔离了,用户无法去改变,即使是sudo操作.后续不断查找参考外文资料,折腾发现,放在/usr/local下是可以的.果断复制/Library/Developer/CommandLineTools/SDKs/MacOSX10.15.sdk/usr/lib
里的php文件夹至/usr/local/include
下(建软链接应该也是可以的)
二、忽略以上失败 改操作/usr/local/include 这个目录有权限
复制/usr/bin/phpize至/usr/local下,修改line 8:
includedir="eval echo ${prefix}/local/include
/php" # 注意local
运行sudo ../phpize成功,接着运行./configure失败.提示信息显示相关php库文件路径不对,和上面原因一样.最后通过修改php-config(bash) line 9:
include_dir="${prefix}/local/include/php"
再运行./configure --with-php-config=/usr/local/php-config
,生成配置文件成功.接着运行make命令成功.但接下来的make install报错误.摸索发现还是因Catalina 安全保护机制,usr/lib目录下无法进行复制操作.后面经过尝试,修改php.ini里的extension_dir为自定义访问目录(/usr/local/lib/php/extensions),再将make成功执行后生成的redis.so文件复制过去即可.
cp /user/bin/phpize /user/local/phpize
vim /user/local/phpize
修改
includedir="`eval echo ${prefix}/local/include`/php" # 注意local line8
cd ~/phpredis
/usr/local/phpize
cp /usr/bin/php-config /usr/local/php-config
vim /usr/local/php-config
include_dir="${prefix}/local/include/php" #line 9 add local
./configure --with-php-config=/user/local/php-config
make
vim /private/etc/php.ini
extension_dir=/usr/local/lib/php/extension
make install
cp modules/redis.so /usr/local/lib/php/extension/redis.so
vim /private/etc/php.ini
extension=redis.so
php -m