当前位置: 首页 > news >正文

【YashanDB数据库】PHP无法通过ODBC连接到数据库

问题分类】驱动使用

关键字】ODBC、驱动使用、PHP

问题描述】应用使用php-fpm+nginx架构,通过php的ODBC拓展连接YashanDB时出现报错:

[unixODBC][Driver Manager]Can't open lib '/home/yashandb_odbc/libyas_odbc.so': file not found

但是在应用所在的主机上使用isql连接YashanDB数据库正常,ldd检查/home/yashandb_odbc/libyas_odbc.so和libyascli.so.0均正常。

问题原因分析】php-fpm和nginx均通过systemctl的方法启动,该启动方式不会读取配置到机器中的环境变量,导致php-fpm的workers进程无法正确获取到ODBC的驱动文件

解决/规避方法

方法一:

在/lib/systemd/system/php-fpm.service的[Service]部分添加环境文件

EnvironmentFile=/etc/sysconfig/php-fpm

在/etc/sysconfig/php-fpm中添加以下内容:

LD_LIBRARY_PATH=/usr/lib:/usr/lib64:/home/yashandb_odbc:/home/yashandb_client/lib
export LD_LIBRARY_PATH
其中/home/yashandb_odbc和/home/yashandb_client/lib是odbc驱动和C驱动lib的文件夹

添加完成后需要重新启动php-fpm服务:

systemctl daemon-reload
systemctl restart php-fpm

方法二:

在/lib/systemd/system/php-fpm.service的[Service]部分添加环境变量

Environment=LD_LIBRARY_PATH=/usr/lib:/usr/lib64:<实际C驱动文件夹的lib>

添加完成后需要重新启动php-fpm服务:

systemctl daemon-reload
systemctl restart php-fpm

影响范围】所有版本

修复版本】-

http://www.lryc.cn/news/418999.html

相关文章:

  • C++ | Leetcode C++题解之第326题3的幂
  • Ubuntu20.4上搭建FFMPEG开发环境
  • 谷粒商城实战笔记-144-性能压测-性能监控-堆内存与垃圾回收
  • 大模型综述
  • Python 常用内置函数
  • 什么是大数据?
  • Linux 内核源码分析---资源分配及系统总线
  • C# POST请求 各种实现方法梳理
  • 《MySQL数据库》数据导入、导出、表处理—/—<4>
  • Java I/O (Input/Output)——文件字节流
  • VisionPro二次开发学习笔记4-使用C#创建绘图图形
  • 【langchain学习】使用JsonOutputParser让大模型生成结构化JSON数据
  • 【学习笔记】Matlab和python双语言的学习(最大最小化规划)
  • 基于SpringBoot的Redis开发实战教程
  • mysql 分区操作
  • [网鼎杯 2018]Comment
  • LVS详解
  • Yolo-World初步使用
  • Navicat Premium使用
  • LLC数字控制TMS320F28034,4-DSP的epwm配置介绍
  • MongoDB学习记录
  • vlunstack-2(复现红日安全-ATT CK实战)
  • 【生信入门】预览快速体验Linux-重生之小明闯Linux
  • 用.net core简易搭建webapi托管到IIS
  • 【计算机网络---OSI七层模型】
  • Error updating database. Cause: org.apache.shiro.UnavailableSecurity
  • 【网络安全】本地文件包含及远程文件包含漏洞详解
  • redis启动的三种方式
  • 手机怎么远程控制电脑屏幕?手机远程控制电脑方法分享
  • NET的全称、主要功能以及在计算机网络中的作用?