编译php5.4及安装后增添扩展

Jun 13, 2016 am 11:49 AM
enable mysql php with

编译php5.4及安装后添加扩展

今天因为研发需要php5.4 没有相应的RPM包,所以只能下载源码包编译了

下载php5.4包:wget http://cn2.php.net/get/php-5.4.8.tar.gz/from/this/mirror

tar zxvf php-5.4.8.tar.gz

php模块最好不要在编译的时候安装进去,以免日后升级麻烦,

./configure --prefix=/usr/local/webserver/php \
??????? --with-zlib \
??????? --with-mysql=/data/mysql \
??????? --with-jpeg-dir=/usr/local/jpeg \
??????? --with-png-dir=/usr/local/libpng \
??????? --with-freetype-dir=/usr/local/freetype \
??????? --with-libexpat-dir \
??????? --with-iconv \
??????? --with-ttf \
??????? --with-curl \
??????? --with-curlwrappers \
??? --disable-sqlite \
??????? --enable-gd-native-ttf \
??????? --enable-mbstring \
??????? --enable-sockets \
??????? --enable-fastcgi \
??????? --enable-force-cgi-redirect \
??????? --enable-discard-path \
??????? --enable-safe-mode \
??????? --enable-sysvsem \
??????? --enable-sysvshm \
??????? --enable-sysvmsg \
??????? --enable-inline-optimization \
??????? --disable-xmlreader \
??????? --disable-debug \
??????? --disable-rpath \
??? --disable-libxml \
??? --disable-dom \
??? --disable-pdo \
??? --disable-simplexml \
??? --disable-xml \
??? --disable-xmlwriter \
??????? --without-pear \
??????? --enable-fpm \
??????? --with-fpm-user=nobody \
??????? --with-fpm-group=nobody \
??????? --with-fpm-log=/var/log/php-fpm.log \
??????? --with-fpm-pid=/var/run/php-fpm/php-fpm.pid

途中遇到configure: error: Cannot find libz 解决办法

yum install zlib.x86_64

yum install zlib-devel.x86_64

再次编译遇到:configure: error: Please reinstall the libcurl distribution - easy.h should 解决办法

yum -y install curl-devel

这次编译总算是成功了

make &&make install

当你对./configurg 后面的参数不太了解的时候,可以用./configurg --help看看,里面有比较详细的说明

拷贝php.ini-production 到php目录:cp php.ini-production? /usr/local/webserve/php/lib/php.ini

修改php/etc/php-fpm配置文件:mv php-fpm.conf.default php-fpm.conf

安装扩展pdo_mysql

这个一般在PHP源码包里面会有这个扩展:一般在./ext/pdo_mysql/目录下

cd /php5.4/ext/pdo_mysql/

/usr/local/webserver/php/bin/phpize

提示Cannot find autoconf. Please check your autoconf installation and the
$PHP_AUTOCONF environment variable. Then, rerun this script.

缺少autoconf

这个包是用来自动配置源码的 GNU 工具。要不然pdo_mysql目录下不会生成configure文件

再次使用一切正常:/usr/local/webserver/php/bin/phpize

./configure --with-php-config=/usr/local/webserver/php/bin/php-config --with-pdo-config=/data/mysql/bin/mysql_config

又遇到错误了:configure: error: Cannot find php_pdo_driver.h.

找了一下资料,没发现有人遇到过这种问题,用locate php_pdo_driver.h 发现在pdo模块目录上有,查了一下资料发现,要安装pdo_mysql必须先安装pdo模块,好吧,先装pdo模块吧

cd? php5.4/ext/pdo/

/usr/local/webserver/php/bin/phpize

./configure --with-php-config=/usr/local/webserver/php/bin/php-config? --enable-pdo=shared

make &&make install

cd php5.4/ext/pdo_mysql/

/usr/local/webserver/php/bin/phpize

./configure --with-php-config=/usr/local/webserver/php/bin/php-config --with-pdo-mysql=/data/mysql/bin/mysql_config

make &&make install

编译成功后会看到php安装目录下出现了扩展模块的目录

交以下几行添加至php/lib/php.ini 文件上

extension_dir = "/usr/local/webserver/php/lib/php/extensions/no-debug-non-zts-20100525/"
extension=pdo.so
extension=pdo_mysql.so
extension=memcache.so

[[email protected] yum.repos.d]# php -m
[PHP Modules]
Core
ctype
curl
date
ereg
fileinfo
filter
hash
iconv
json
mbstring
memcache
mysql
pcre
PDO
pdo_mysql
Phar
posix
Reflection
session
sockets
SPL
sqlite3
standard
sysvmsg
sysvsem
sysvshm
tokenizer
zlib

[Zend Modules]

或者:/usr/local/webserver/php/bin/php -r "phpinfo();"|grep -i pdo_mysql

终于成功了

?

转?http://198555.blog.51cto.com/188555/1063199

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

Video Face Swap

Video Face Swap

完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

MySQLおよびPHPMYADMIN:コア機能と関数 MySQLおよびPHPMYADMIN:コア機能と関数 Apr 22, 2025 am 12:12 AM

MySQLとPHPMyAdminは、強力なデータベース管理ツールです。 1)MySQLは、データベースとテーブルを作成し、DMLおよびSQLクエリを実行するために使用されます。 2)PHPMyAdminは、データベース管理、テーブル構造管理、データ操作、ユーザー許可管理のための直感的なインターフェイスを提供します。

IISとPHPの互換性:ディープダイビング IISとPHPの互換性:ディープダイビング Apr 22, 2025 am 12:01 AM

IISとPHPは互換性があり、FastCGIを通じて実装されています。 1..phpファイル要求を構成ファイルを介してFastCGIモジュールに転送します。 2. FASTCGIモジュールは、PHPプロセスを開始して、パフォーマンスと安定性を改善するための要求を処理します。 3。実際のアプリケーションでは、構成の詳細、エラーデバッグ、パフォーマンスの最適化に注意する必要があります。

MySQLの外国キーの目的を説明してください。 MySQLの外国キーの目的を説明してください。 Apr 25, 2025 am 12:17 AM

MySQLでは、外部キーの機能は、テーブル間の関係を確立し、データの一貫性と整合性を確保することです。外部キーは、参照整合性チェックとカスケード操作を通じてデータの有効性を維持します。パフォーマンスの最適化に注意し、それらを使用するときに一般的なエラーを避けてください。

mysqlとmariadbを比較対照します。 mysqlとmariadbを比較対照します。 Apr 26, 2025 am 12:08 AM

MySQLとMariaDBの主な違いは、パフォーマンス、機能、ライセンスです。1。MySQLはOracleによって開発され、Mariadbはフォークです。 2. Mariadbは、高負荷環境でパフォーマンスを向上させる可能性があります。 3.MariaDBは、より多くのストレージエンジンと機能を提供します。 4.MySQLは二重ライセンスを採用し、MariaDBは完全にオープンソースです。既存のインフラストラクチャ、パフォーマンス要件、機能要件、およびライセンスコストを選択する際に考慮する必要があります。

SQL対MySQL:2つの関係を明確にします SQL対MySQL:2つの関係を明確にします Apr 24, 2025 am 12:02 AM

SQLはリレーショナルデータベースを管理するための標準言語であり、MySQLはSQLを使用するデータベース管理システムです。 SQLは、CRUD操作を含むデータベースと対話する方法を定義しますが、MySQLはSQL標準を実装し、ストアドプロシージャやトリガーなどの追加機能を提供します。

関数と正規表現を含むJavaScriptオブジェクトをデータベースに安全に保存して復元するにはどうすればよいですか? 関数と正規表現を含むJavaScriptオブジェクトをデータベースに安全に保存して復元するにはどうすればよいですか? Apr 19, 2025 pm 11:09 PM

フロントエンド開発においてJSONで機能と正規表現を安全に処理することができますが、JavaScriptが必要です...

session_start()が複数回呼び出されるとどうなりますか? session_start()が複数回呼び出されるとどうなりますか? Apr 25, 2025 am 12:06 AM

session_start()への複数の呼び出しにより、警告メッセージと可能なデータ上書きが行われます。 1)PHPは警告を発し、セッションが開始されたことを促します。 2)セッションデータの予期しない上書きを引き起こす可能性があります。 3)session_status()を使用してセッションステータスを確認して、繰り返しの呼び出しを避けます。

MySQLはOracleとどのように違いますか? MySQLはOracleとどのように違いますか? Apr 22, 2025 pm 05:57 PM

MySQLは、迅速な開発や中小規模のアプリケーションに適していますが、Oracleは大規模な企業や高可用性のニーズに適しています。 1)MySQLはオープンソースで使いやすく、Webアプリケーションや中小企業に適しています。 2)Oracleは強力で、大企業や政府機関に適しています。 3)MySQLはさまざまなストレージエンジンをサポートし、Oracleは豊富なエンタープライズレベルの機能を提供します。

See all articles