首页 > 编程知识 正文

包含mysqlnd源码细节角度认识的词条

时间:2023-12-22 19:14:03 阅读:319011 作者:KGSW

本文目录一览:

linux配置源代码包时出现下面错误

"exact error that occured. This usually means GLIB is incorrectly installed"

是不是由于GLIB的版本太低了?查看你的软件的readme啊,确认你的系统是否满足所有依赖关系。

Linux 源代码包配置PHP时出错:configure: error: GD build test failed. Please check the config.log

./configure --prefix=/usr/local/php/ --with-apxs2=/usr/local/apache2/bin/apxs --with-config-file-path=/usr/local/php/lib/ --with-config-file-scan-dir=/usr/local/etc/ --with-zlib --with-curl --enable-bcmath --with-jpeg-dir --with-png-dir --with-xpm-dir --with-freetype-dir --with-gd --with-mhash --enable-mbstring --with-mcrypt --with-libxml-dir --with-iconv-dir --with-pcre-dir --enable-mysqlnd --with-mysql=mysqlnd --with-mysqli=mysqlnd

看一下是不是有库不全?

ubuntu16.04 安装 php 5.6.30 对应的 mysqlnd 版本是多少

如果你用的是apt-get安装的话,php的版本就是软件中心配置好了的,这个你就没法决定安装版本。如果你想安装指定版本的话,就只有到官网去下载源码,然后自己编译安装了

求mysql_query 内部源码

Sends an SQL query to MySQL */

PHP_FUNCTION(mysql_query)

{

    php_mysql_do_query(INTERNAL_FUNCTION_PARAM_PASSTHRU, MYSQL_STORE_RESULT);

}

static void php_mysql_do_query(INTERNAL_FUNCTION_PARAMETERS, int use_store)

{

    char *query;

    size_t query_len;

    zval *mysql_link = NULL;

    php_mysql_conn *mysql;

if (zend_parse_parameters(ZEND_NUM_ARGS(), "s|r", query, query_len, mysql_link) == FAILURE) {

    return;

}

if (!mysql_link) {

    zend_resource *res = php_mysql_get_default_link(INTERNAL_FUNCTION_PARAM_PASSTHRU);

    CHECK_LINK(res);

    mysql = (php_mysql_conn*)res-ptr;

} else {

    if (!(mysql = (php_mysql_conn *)zend_fetch_resource2(Z_RES_P(mysql_link), "MySQL-Link", le_link, le_plink))) {

        RETURN_FALSE;

    }

}

php_mysql_do_query_general(mysql, query, query_len, NULL, use_store, return_value);

}

/* {{{ php_mysql_do_query_general

  */

 static void php_mysql_do_query_general(php_mysql_conn *mysql, char *query, int query_len, char *db, int use_store, zval *return_value)

 {

         MYSQL_RES *mysql_result;

 

         if (db) {

                 if (!php_mysql_select_db(mysql, db)) {

                         RETURN_FALSE;

                 }

         }

 

         PHPMY_UNBUFFERED_QUERY_CHECK();

 

         MYSQL_DISABLE_MQ;

 

 #ifndef MYSQL_USE_MYSQLND

         /* check explain */

         if (MySG(trace_mode)) {

                 if (!strncasecmp("select", query, 6)){

                         MYSQL_ROW       row;

 

                         char *newquery;

                         int newql = spprintf(newquery, 0, "EXPLAIN %s", query);

                         mysql_real_query(mysql-conn, newquery, newql);

                         efree (newquery);

                         if (mysql_errno(mysql-conn)) {

                                 php_error_docref("", E_WARNING, "%s", mysql_error(mysql-conn));

                                 RETURN_FALSE;

                         }

                         else {

                         mysql_result = mysql_use_result(mysql-conn);

                                 while ((row = mysql_fetch_row(mysql_result))) {

                                         if (!strcmp("ALL", row[1])) {

                                                 php_error_docref("", E_WARNING, "Your query requires a full tablescan (table %s, %s rows affected). Use EXPLAIN to optimize your query.", row[0], row[6]);

                                         } else if (!strcmp("INDEX", row[1])) {

                                                 php_error_docref("", E_WARNING, "Your query requires a full indexscan (table %s, %s rows affected). Use EXPLAIN to optimize your query.", row[0], row[6]);

                                         }

                                 }

                                 mysql_free_result(mysql_result);

                         }

                 }

         } /* end explain */

 #endif

 

         /* mysql_query is binary unsafe, use mysql_real_query */

 #if MYSQL_VERSION_ID  32199

         if (mysql_real_query(mysql-conn, query, query_len)!=0) {

                 /* check possible error */

                 if (MySG(trace_mode)){

                         if (mysql_errno(mysql-conn)){

                                 php_error_docref("", E_WARNING, "%s", mysql_error(mysql-conn));

                         }

                 }

                 RETURN_FALSE;

         }

 #else

         if (mysql_query(mysql-conn, query)!=0) {

                 /* check possible error */

                 if (MySG(trace_mode)){

                         if (mysql_errno(mysql-conn)){

                                 php_error_docref("", E_WARNING, "%s", mysql_error(mysql-conn));

                         }

                 }

                 RETURN_FALSE;

         }

 #endif

         if(use_store == MYSQL_USE_RESULT) {

                 mysql_result = mysql_use_result(mysql-conn);

         } else {

                 mysql_result = mysql_store_result(mysql-conn);

         }

         if (!mysql_result) {

                 if (PHP_MYSQL_VALID_RESULT(mysql-conn)) { /* query should have returned rows */

                         php_error_docref(NULL, E_WARNING, "Unable to save result set");

                         RETURN_FALSE;

                 } else {

                         RETURN_TRUE;

                 }

         }

         MySG(result_allocated)++;

         ZVAL_RES(return_value, zend_register_resource(mysql_result, le_result));

         

         if (use_store == MYSQL_USE_RESULT) {

                 mysql-active_result_res = Z_RES_P(return_value);

                 Z_ADDREF_P(return_value);

         }

 }

 /* }}} */

时时教大家搭建PHP环境 怎么用PHP源码安装

[Raykaeso@LAMP httpd-2.4.17]# cd /LAMP

[Raykaeso@LAMP LAMP]# yum -y install libxml2-devel #不装这个编译不了PHP5.6

[Raykaeso@LAMP LAMP]# yum -y install libjpeg libjpeg-devel libpng libpng-devel freetype freetype-devel png jpeg gd #开启GD库需要的依赖

[Raykaeso@LAMP LAMP]# yum -y install curl curl-devel #开启CURL库需要的依赖

[Raykaeso@LAMP LAMP]# tar -zvxf php-5.6.16.tar.gz

[Raykaeso@LAMP LAMP]# cd php-5.6.16

[Raykaeso@LAMP php-5.6.16]# ./configure --prefix=/usr/local/php --with-config-file-path=/usr/local/php/etc --enable-fpm --enable-sysvsem --enable-sockets --enable-pcntl --enable-mbstring --enable-mysqlnd --enable-pdo --with-pdo-mysql --enable-opcache --enable-shmop --enable-zip --enable-ftp --enable-gd-native-ttf --enable-wddx --enable-soap --with-png-dir --with-freetype-dir --with-jpeg-dir --with-gd --with-mysqli

[Raykaeso@LAMP php-5.6.16]# make make install

拷贝一份正式的php-fpm.conf和php.ini配置文件

[Raykaeso@LAMP php-5.6.16]# cp /usr/local/php/etc/php-fpm.conf.default /usr/local/php/etc/php-fpm.conf

[Raykaeso@LAMP php-5.6.16]# cp ./php.ini-production /usr/local/php/etc/php.ini

PHP7.0打开扩展功能要怎样才能和mysql相连?

第一步:进入php源码中的"ext/mysql"目录下

第二步:在当前目录下运行phpize命令:/usr/local/php524/bin/phpize

phpize的规则:去哪个目录下运行phpize文件,那么就会在该目录下生成一个configure文件。

第三步:运行刚才生成的configure文件

命令: ./configure --with-php-config=/usr/local/php524/bin/php-config --with-mysql=/usr/local/mysql/

这里最关键的是通过--with-mysql参数告诉mysql客户端的位置。这样才能生成mysql.so。

实验的时候,没有加这个参数,结果错误:

./configure --with-php-config=/usr/local/php524/bin/php-config

第四步:编译生成.so文件

第五步:配置php引擎加载该扩展。

补充一下:就是去php.ini文件中修改一下配置,加载mysql.so这个扩展(这个扩展文件要放到php指定的扩展目录下面去)

第六步:测试php引擎是否成功加载该扩展编写文件phpinfo.php,内容是:?php ehco phpinfo(); ?

运行后,可以看到有如下信息显示:mysqlMySQLSupport    enabledActive PersistentLinks     0

Active Links     0

Client API version     5.1.55

MYSQL_MODULE_TYPE     no value

MYSQL_SOCKET     /tmp/mysql.sock

MYSQL_INCLUDE     no value

MYSQL_LIBS     no value

通过这样的方式可以确认,php引擎已经成功加载了mysql.so扩展。

第七步:已经生成的mysql.so。编写php代码测试是否能连接mysql。

一、为什么书中一般是常常是这样的顺序安装。

先安装mysql,然后再安装php,很少看到先安装php,后安装mysql?

这样做。是基于下面原因:安装好mysql后。mysql.so这个模块才能生成。记得一个细节:在安装php的时候,需要提供mysql的路径。由php帮助编译生成mysql.so模块。mysql.so这个模块是在安装好php的时候生成的。

生成这个模块需要用到一个东西:mysql客户端。如果先安装php,后安装mysql。那么无法按照原来的方式(由php帮助生成mysql.so模块)挂接mysql.so。通过实践,发现使用phpize工具生成mysql.so可以解决这个问题。

二、实践生成mysql.so的过程。

大体思路:需要用到php的源码包才行。通过源码包中提供的phpize文件(一个专门挂接php扩展的工具)

版权声明:该文观点仅代表作者本人。处理文章:请发送邮件至 三1五14八八95#扣扣.com 举报,一经查实,本站将立刻删除。