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

本文目录一览:

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扩展的工具)

原创文章,作者:小蓝,如若转载,请注明出处:https://www.506064.com/n/150525.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
小蓝小蓝
上一篇 2024-11-08 14:54
下一篇 2024-11-08 14:54

相关推荐

  • int类型变量的细节与注意事项

    本文将从 int 类型变量的定义、声明、初始化、范围、运算和类型转换等方面,对 int 类型变量进行详细阐述和讲解,帮助读者更好地掌握和应用 int 变量。 一、定义与声明 int…

    编程 2025-04-29
  • 云智直聘 源码分析

    本文将会对云智直聘的源码进行分析,包括前端页面和后端代码,帮助读者了解其架构、技术实现以及对一些常见的问题进行解决。通过本文的阅读,读者将会了解到云智直聘的特点、优势以及不足之处,…

    编程 2025-04-29
  • 从ga角度解读springboot

    springboot作为目前广受欢迎的Java开发框架,其中的ga机制在整个开发过程中起着至关重要的作用。 一、ga是什么 ga即Group Artifacts的缩写,它是Mave…

    编程 2025-04-29
  • Python中角度变弧度

    本文将从以下几个方面详细阐述Python中角度变弧度的实现方法和应用场景。 一、角度和弧度的概念 在Python中,角度和弧度这两个概念是经常用到的。角度是指单位圆上的作用角度,其…

    编程 2025-04-28
  • Python网站源码解析

    本文将从多个方面对Python网站源码进行详细解析,包括搭建网站、数据处理、安全性等内容。 一、搭建网站 Python是一种高级编程语言,适用于多种领域。它也可以用于搭建网站。最常…

    编程 2025-04-28
  • 源码是什么

    源码是一段计算机程序的原始代码,它是程序员所编写的可读性高、理解性强的文本。在计算机中,源码是指编写的程序代码,这些代码按照一定规则排列,被计算机识别并执行。 一、源码的组成 源码…

    编程 2025-04-27
  • 从多个角度用法介绍lower down

    lower down是一个常用于编程开发中的操作。它可以对某个值或变量进行降低精度的处理,非常适合于一些需要精度不高但速度快的场景。那么,在本文中,我们将从多个角度解析lower …

    编程 2025-04-27
  • Go源码阅读

    Go语言是Google推出的一门静态类型、编译型、并发型、语法简单的编程语言。它因具有简洁高效,内置GC等优秀特性,被越来越多的开发者所钟爱。在这篇文章中,我们将介绍如何从多个方面…

    编程 2025-04-27
  • 数学符号角度的读法

    数学符号是用来表示数学概念、关系和运算的工具。正确理解数学符号的意义对于学习数学、应用数学至关重要。本文将从多个方面介绍数学符号角度的读法。 一、基础符号 1、数学符号:&#822…

    编程 2025-04-27
  • 从初学者角度出发,noc Python比赛

    本文将从初学者的角度出发,深入探讨noc Python比赛。包括如何准备比赛,比赛难度分析,以及必备的编程技能等。我们将一步一步带领大家进入Python编程的世界。 一、比赛准备 …

    编程 2025-04-27

发表回复

登录后才能评论