php - 在 centOs 上使用 PHP 5.6 安装 OCI8 (vagrant)

标签 php linux oracle vagrant

根据我的理解和以前的安装,要在 centOs 上安装 oci8 和 php 5.6,我需要完成以下步骤:

  • 使用 RPM 安装 oracle-instantclient11.2-basic 和 oracle-instantclient11.2-devel。
  • 使用 pecl 安装 oci8 php 扩展。
  • 为 php.ini 添加扩展。

这就是我在配置文件中所做的。

installOracleInstantClient() {
  # ===================================================================
  # Install Oracle Support for PHP
  # ===================================================================
  if [ $(rpm -qa | grep -c 'oracle-instantclient') -eq 0 ]; then
    printLog 'Installing Oracle Client'
    yum --quiet -y install libaio

    yum -y --nogpgcheck --quiet install /opt/packages/oracle-instantclient11.2-basic-11.2.0.4.0-1.x86_64.rpm
    yum -y --nogpgcheck --quiet install /opt/packages/oracle-instantclient11.2-devel-11.2.0.4.0-1.x86_64.rpm

    cat > /etc/environment <<EOM
ORACLE_HOME="/usr/lib/oracle/11.2/client64"
LD_LIBRARY_PATH="/usr/lib/oracle/11.2/client64/lib"
EOM

    cat > /etc/profile.d/oracle.sh <<EOM
export ORACLE_HOME=/usr/lib/oracle/11.2/client64
export PATH=$PATH:$ORACLE_HOME/bin
export LD_LIBRARY_PATH=$ORACLE_HOME/lib
export TNS_ADMIN=$ORACLE_HOME/network/admin
EOM

    export ORACLE_HOME=/usr/lib/oracle/11.2/client64
    export PATH=$PATH:$ORACLE_HOME/bin
    export LD_LIBRARY_PATH=$ORACLE_HOME/lib
    export TNS_ADMIN=$ORACLE_HOME/network/admin


    mkdir -p /usr/lib/oracle/11.2/client64/network/admin -p
  fi
}

installPHP() {
  if [ $(rpm -qa | grep -c 'php') -eq 0 ]; then
    printLog 'Installing PHP'

    installGcc;

    installEPEL;

    installGit;

    printLog 'Adding php5.6 repositories'

    rpm -Uvh http://vault.centos.org/7.0.1406/extras/x86_64/Packages/epel-release-7-5.noarch.rpm
    rpm -Uvh http://rpms.famillecollet.com/enterprise/remi-release-7.rpm

    yum install yum-utils

    printLog 'installing php packages'
    yum --enablerepo=remi,remi-php56 install --quiet -y php php-common php-cli php-pear php-pdo php-devel php-ldap php-mbstring php-bcmath php-mysqlnd php-soap php-gd php-xml php-simplexml php-curl php-zip php-oci8 php-ldap php-zip php-fileinfo

    # php-mssql php-sqlite php-mcrypt

    printLog 'Installing OCI8 extension for PHP'
    printf "instantclient,/usr/lib/oracle/11.2/client64" | pecl install oci8-2.0.12

    # bits to add oci to php.ini
    echo 'extension=oci8.so' >> /etc/php.ini

    sudo sh -c "echo /usr/lib/oracle/11.2/client64 > /etc/ld.so.conf.d/oracle.conf"
    sudo ldconfig

  fi
}

installOracleInstantClient;
installPHP;

在机器配置上,我收到以下错误:

default: PHP Warning:  PHP Startup: Unable to load dynamic library '/usr/lib64/php/modules/oci8.so' - libclntsh.so.18.1: cannot open shared object file: No such file or directory in Unknown on line 0

default: PHP Warning:  PHP Startup: Unable to load dynamic library '/usr/lib64/php/modules/pdo_oci.so' - libclntsh.so.18.1: cannot open shared object file: No such file or directory in Unknown on line
 0 

当我 ssh 进入机器并执行 php -v 时也是如此。

执行 ldd -r/usr/lib64/php/modules/oci8.so 返回一堆 Undefined symbol 错误和预期的 libclntsh.so。 18.1 => 未找到 行。

此外,php -i 不会返回正确安装 oci8 时通常显示的 OCI8 block 。

知道我做错了什么吗?

最佳答案

使用“remi-php56”存储库,您不需要从源代码构建扩展,一切都在存储库中;)

  • php-oci8 提供 oci8 版本 2.0.12 和 pdo_oci8

(pecl命令只会安装oci8扩展,不会安装PDO驱动)

软件包是使用 Oracle Client 18c 构建的,允许连接到服务器版本 18c、12.2、12.1 和 11.2。

关于php - 在 centOs 上使用 PHP 5.6 安装 OCI8 (vagrant),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55472961/

相关文章:

php - 在php中初始化一个类时,如何将变量传递给该类以在其函数中使用?

php - 为什么准备好的语句可以防止注入(inject)?

php - 使用子数组写入 Json 文件

linux - 我想在后台进程中使用 pos-receive 自动化我的 Angular 构建

Oracle:导入 CSV 文件

mysql - MDB文件到Mysql

php - 打开 session.cookie_secure 会注销我的用户吗?

javascript - Cronjob 停止执行 nodejs

获取S3路径的linux命令

c# - 设计策略 : Query and Update data across 2 different databases