栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 系统运维 > 运维 > Linux

PHP7.3加载达梦数据库驱动(linux环境)

Linux 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

PHP7.3加载达梦数据库驱动(linux环境)

linux环境(centos7为例)

1.安装达梦数据库并创建实例。
2.安装PHP环境。
第一步:下载php源码并预配置

#安装wget工具

yum install wget -y

#下载php源码

wget https://www.php.net/distributions/php-7.3.12.tar.gz

#解压php tar包

tar xf php-7.3.12.tar.gz

#进入php解压后的目录

cd php-7.3.12

#预配置

./configure --prefix=/usr/local/php \

    --with-config-file-path=/usr/local/php/etc \

    --with-config-file-scan-dir=/usr/local/php/etc/conf.d \

    --disable-cgi \

    --enable-fpm \

    --with-fpm-user=www \

    --with-fpm-group=www \

    --enable-ftp \

    --with-curl \

    --with-gd \

    --with-gettext \

    --with-iconv-dir \

    --with-kerberos \

    --with-libedit \

    --with-openssl \

    --with-pcre-regex \

    --with-pdo-mysql \

    --with-xsl \

    --with-zlib \

    --with-mhash \

    --with-mysqli \

    --with-png-dir=/usr/lib \

    --with-jpeg-dir=/usr/lib\

    --with-freetype-dir=/usr/lib \

    --enable-mysqlnd \

    --enable-bcmath \

    --enable-libxml \

    --enable-inline-optimization \

    --enable-gd-jis-conv \

    --enable-mbregex \

    --enable-mbstring \

    --enable-opcache \

    --enable-pcntl \

    --enable-shmop \

    --enable-soap \

    --enable-sockets \

    --enable-sysvsem \

    --enable-xml \

    --enable-zip \

    --enable-calendar \

    --enable-intl \

    --enable-exif

查看最后输出是否出现error:
如果没有error出现,并且出现如下字眼,则进行下一步

Thank you for using PHP

第二步:进行编译安装

make && make install

第三步:创建启动脚本

cp php.ini-development  /usr/local/php/etc/php.ini 

cd /usr/local/php/etc/

cp php-fpm.conf.default  php-fpm.conf

默认官方提供了一个systemd管理脚本

路径为:/root/php-7.3.12/sapi/fpm下php-fpm.service

#复制一份配置文件

cp php-fpm.conf.default php-fpm.conf

#拷贝启动脚本到指定目录

cp /root/php-7.3.13/sapi/fpm/php-fpm.service /usr/lib/systemd/system/

systemctl daemon-reload

systemctl start php-fpm

systemctl enable php-fpm

systemctl status php-fpm

这个时候还没完,启动 会提示你找不到包含的配置文件:

cd /usr/local/php/etc/php-fpm.d/

cp www.conf.default www.conf

systemctl start php-fpm

systemctl status php-fpm

这个时候不出意外就是正常状态:

查看进程是否存在

ps -ef|grep php-fpm

查看端口是否启动:

ss -lntup|grep 9000

3.安装Nginx

yum install -y nginx

4.配置Nginx,vi /etc/nginx/nginx.conf, 配置server。

server {
        listen       80;

        # Load configuration files for the default server block.
        include /etc/nginx/default.d/*.conf;

        error_page 404 /404.html;
        location = /404.html {
        }

        error_page 500 502 503 504 /50x.html;
        location = /50x.html {
        }

        location ~ .php$ {
            root           html;
            fastcgi_pass   127.0.0.1:9000;
            fastcgi_index  index.php;
            fastcgi_param  SCRIPT_FILENAME  $document_root$fastcgi_script_name;
            include        fastcgi_params;
        }

    }

5.在Nginx的映射路径中添加测试页面。

cd /usr/share/nginx/html

vi index.php



#wq 保存并退出

6.重启Nginx

service nginx restart

浏览器中访问 http://IP:端口/index.php

7.找到页面中Thread Safety

8.Thread Safety为enable选择ts扩展包。

9.拷贝达梦数据库驱动到PHP扩展路径 /usr/local/php/lib/php/extensions/no-debug-non-zts-20180731中。

cp /home/dmdba/drivers/php_pdo/* /usr/local/php/lib/php/extensions/no-debug-non-zts-20180731

10.配置php.ini,在末尾添加如下参数。(注意根据Thread Safety和PHP版本选择扩展包)

;扩展路径:
extension_dir = "/usr/local/php/lib/php/extensions/no-debug-non-zts-20180731"
;扩展包名:
extension=libphp73_dm.so
extension=php73_pdo_dm.so
;DM默认连接参数:
[dm]
; 是否允许持久性连接
dm.allow_persistent = 1
; 允许建立持久性连接的最大数. -1 为没有限制.
dm.max_persistent = -1
; 允许建立连接的最大数(包括持久性连接). -1 为没有限制.
dm.max_links = -1
; 默认的主库地址
dm.default_host = 127.0.0.1
; 默认的连接用户名
dm.default_user = SYSDBA
; 默认的连接口令.
dm.default_pw = SYSDBA

11重启PHP服务

#停止服务
service php-fpm stop

#启动服务
service php-fpm start

#查看状态

service php-fpm status

12.通过php -m进行测试 如果出现异常

PHP message: PHP Fatal error:  Unable to start dm module in Unknown on line 0

检测环境变量中是否添加数据库bin路径,
假定安装到/usr/local/DMDBMS 目录。修改 php.ini,添加 extension_dir=drivers/php_pdo,extension=libphp53_dm.so,添加 php.ini中有关连接的配置。设置环境变量 export LD_LIBRARY_PATH=/usr/local/DMDBMS/bin。
在/etc/bashrc中加入了上述的环境变量并重启了电脑,然而并没有什么作用,百度了一圈也没什么结果,本来打算暂时放弃,以后再说,突然想到动态链接库的话,是不是可以通过ld相关命令来解决,于是乎在/etc/ld.so.conf.d/下面建立了dm.conf,写入了需要设置环境变量的路径,然后ldconfig加载使之生效,果然解决问题了。
13.通过php -m 测试,扩展包加载成功

页面显示驱动加载成功

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/830871.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号