前面和网上说的都差不多(和 Linux 编译安装类似),去 Oracle 下载如下的安装包(可以选择版本,我这里选择的是 12.2)

  • instantclient-basic-macos.x64-12.2.0.1.0-2.zip
  • instantclient-sdk-macos.x64-12.2.0.1.0-2.zip
  • instantclient-sqlplus-macos.x64-12.2.0.1.0-2.zip
由于 macOS 开启了 SIP 基本上所有的操作都需要在 /usr/local/ 目录下进行

解压:

sudo unzip instantclient-basic-macos.x64-12.2.0.1.0-2.zip -d /usr/local/
sudo unzip instantclient-sdk-macos.x64-12.2.0.1.0-2.zip -d /usr/local/
sudo unzip instantclient-sqlplus-macos.x64-12.2.0.1.0-2.zip -d /usr/local/

# 设置环境变量
vim ~/.bash_profile
export LD_LIBRARY_PATH="/usr/local/instantclient_12_2"
默认都会解压到 /usr/local/instantclient_12_2 目录下

网上的资料都是表示这个时候直接使用 pecl install oci8,而实际上 macOS 默认并没有安装这个命令;这个时候也没有安装 Homebrew

所以我先安装 Pear,先是参考这篇文章

curl -O https://pear.php.net/go-pear.phar
php -d detect_unicode=0 go-pear.phar

以下摘录于官方文档

You're now ready to configure PEAR for installation.

First you need to change the Installation Base.

  1. So type 1, and then press Enter.
  2. Enter /usr/local/pear
  3. Press Enter.

Then, you will need to change the Binaries directory.

  1. Type 4, and then press Enter.
  2. Enter /usr/local/bin
  3. Press Enter.

到这里基本上可以使用 pecl 了,执行如下命令

sudo pecl install oci8

运行安装表示还是会报错缺失 PHP_AUTOCONF 未配置; 查询之后得知需要安装 autoconf 并且不建议直接安装(说是太多依赖,我没有验证),应该使用 Homebrew

安装 Homebrew

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

由于众所周知的原因, 慢如蜗牛; 于是查询解决方案, 参考如下

  • macOS系统下安装Homebrew
  • 实际上有些地方是不一致的,比如文中提到的没有的变量再接下来的 homebrew-core 的 clone 中无法生效,导致这个仓库会非常慢,暂时也没有得到什么解决方案
  • 按照完成之后再将几个地址换成国内的镜像,如文中所述
  • 之后直接运行命令 brew install autoconf

默认在命令行中 brew 是没有提示的,那么可以参考官方文档 https://docs.brew.sh/Shell-Completion 进行设置,开启提示

然后再次运行,应该就可以安装了

sudo pecl install oci8

然后重启 Apache sudo apachectl restart,通过访问有 phpinfo(); 的页面去确认。

这个时候一般 OCI8 是安装好了,可是项目需要的是 PDO_OCI,使用老的办法炮制 sudo pecl install pdo_oci 发现安装不了,说没有这个库,或者是要求 PHP 版本小于 6

这个时候只能通过编译源码中的扩展来实现(这些步骤和在 Ubuntu 下编译就是一模一样的了)

  1. 查看 PHP 版本 php -v 得到版本 7.1.23 那么去 PHP 官网下载对应版本的源码 https://www.php.net/releases/
  2. 解压到方便操作的地方,比如我放在桌面
  3. 进入目录后进入 ext/pdo_oci/
  4. 将命令行切换到这个目录,然后运行 phpize
./configure --with-pdo-oci=instantclient,/usr/local/instantclient_12_2,12.2
make

# 这里会报安装失败,原因是无法创建目录由于 SIP 的原因
sudo make install

由于 SIP 的原因到这一步就无法再继续了,只能够关闭 SIP,而关闭 SIP 需要重启按住 cmd + R 然后再菜单栏中打开终端

# 关闭 SIP
csrutil disable

# 重启
reboot

然后进入系统之后再次编译安装即可成功(可以选择是否恢复 SIP,重启并设置 csrutil enable

最后配置 php.ini

extension = pdo_oci.so

再重启 Apache sudo apachectl restart,再次访问项目,已经可以正常打开

到这里目的已经达成了


hefengxian
206 声望1 粉丝