本文目录一览:
- 1、linux配置源代码包时出现下面错误
- 2、Linux 源代码包配置PHP时出错:configure: error: GD build test failed. Please check the config.log
- 3、ubuntu16.04 安装 php 5.6.30 对应的 mysqlnd 版本是多少
- 4、求mysql_query 内部源码
- 5、时时教大家搭建PHP环境 怎么用PHP源码安装
- 6、PHP7.0打开扩展功能要怎样才能和mysql相连?
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扩展的工具)