好的,所以我对oci,apache,php和suse有这个可怕的问题。首先,版本:
PHP 5.3.15 (cli)
Apache/2.2.22 (Linux/SUSE)
OCI8 1.4.9
SUSE 12.2 32 bit
Oracle client 10.2.0.4
我有非常简单的php文件:
<?php
error_reporting(E_ALL);
ini_set('display_errors', '1');
oci_connect('user', 'passwd', 'host/sid');
?>
当我从命令行运行它时执行正常:
machine:~ # php oci.php
machine:~ #
但是当我在浏览器中运行它时,它会给我:
Warning: oci_connect() [function.oci-connect]: OCIEnvNlsCreate() failed. There is something wrong with your system - please check that ORACLE_HOME and LD_LIBRARY_PATH are set and point to the right directories
我一直在努力解决这个问题,我很确定我的apache配置是正确的。
我在任何apache进程启动之前导出所有必需的变量 - 我添加了
LD_LIBRARY_PATH=$LD_LIBRARY_PATH:/path/to/oracle/home/lib; export LD_LIBRARY_PATH
ORACLE_HOME=/path/to/oracle/home; export ORACLE_HOME
TNS_ADMIN=/path/to/oracle/home/network/admin; export TNS_ADMIN
NLS_LANG=POLISH_POLAND.EE8MSWIN1250; export NLS_LANG
在/etc/init.d/apache2
脚本的开头(我通过/etc/init.d/apache2 start
启动apache。)
Apache从wwwrun
用户运行,该用户位于oinstall
和dba
个群组中:
machine:~ # cat /etc/apache2/uid.conf
User wwwrun
Group www
machine:~ # id wwwrun
uid=30(wwwrun) gid=8(www) groups=8(www),113(oinstall),114(dba)
machine:~ # l $ORACLE_HOME
total 216
drwxr-xr-x 48 oracle oinstall 4096 Jan 25 17:07 ./
drwxrwxr-x 3 oracle oinstall 4096 Jan 25 17:01 ../
...
machine:~ #
我在Environment
输出的phpinfo();
部分中没有任何环境变量 - 这可能是问题吗?如果是,我该如何解决这个问题?这是某种安全问题吗?我已经阅读了启用SELinux的问题,但我没有,我的防火墙已关闭。
非常感谢任何帮助!
答案 0 :(得分:6)
问题解决了!感谢these(设置Oracle环境部分)说明和ken_yap对this主题的回答。
要将变量放入Apache的 Environment 部分,您只需将它们添加到/etc/sysconfig/apache2
文件中:LD_LIBRARY_PATH=/path/to/oracle/lib
。
答案 1 :(得分:4)
另一个解决方案(不需要root访问权限)是在php页面中添加以下行:
putenv("ORACLE_HOME=/opt/app/oracle/product/11.2.0/db_1");
putenv("LD_LIBRARY_PATH=/opt/app/oracle/product/11.2.0/db_1/lib:/lib:/usr/lib");
此致
答案 2 :(得分:0)
对于Debian用户-编辑文件
/etc/apache2/envvars
在文件末尾添加指向您的OCI库的链接-例如
export LD_LIBRARY_PATH=/opt/oracle/instantclient_12_2
答案 3 :(得分:0)
使用nginx
的Centos 7的另一种方法
$ sudo vim /etc/ld.so.conf.d/oracle-instantclient.conf
// Add path to oracle client lib, the XX is the version, ex: /usr/lib/oracle/XX/client64/lib
$ sudo ldconfig
$ sudo service php-fpm restart
完成!