A. [配置] linux下自帶php不支持mysql,怎麼辦
apxs應該是有的,你可以以root用戶先updatedb下,然後再locate
apxs。一般這個文件在apache安裝目錄下的子目錄bin裡面。
B. php+mysql 用什麼linux系統好
就支持來說,幾乎所有的linux系統都支持php+mysql,好多linux系統都自帶mysql。
做伺服器的話
在下面這些版本里選擇吧(第1個和第3個如果需要商業支持的話
要付費)
RHEL
CentOS
Suse
Debian
Slackware
C. linux系統php頁面提示系統不支持mysql
伺服器監聽也已經配置好了,打開瀏覽器就這這樣了! 回答: 是什麼系統什麼平台(IIS/apache)呢?如果是linux,直接用yum安裝,很簡單,網上這種教材也很多. 如果你是windows系統.建議你參考安裝lamp平台,安裝方法網上很多的. 追問: apache!! 伺服器上有mysql啊! 回答: php.ini文件里有沒有打開mysql擴展.在php.ini里找到:extension=php_mysql.dll這行,把前面的分號去掉. 如果是linux下安裝的php不需要此步! 補充: 還有注意查看extension_dir = "C:\PHP\ext",看看擴展是否在你電腦對應的php目錄里.如果還不行建議你找個評價高的博客教程(教人安裝lamp平台).按照這個再一步一步安裝.
D. LINUX下如何編譯PHP才能支持RPM安裝的MYSQL
1.在php的原碼安裝包里,進入到etc/pdo_mysql里。假設你的php是安裝在/usr/local/php里的。執行/usr/local/php/bin/phpize
2. 進行編譯。./configure --with-php-config=/usr/local/php/bin/php-config --with-pdo-mysql=/usr/local/mysql (假設你的mysql是安裝在/usr/local/mysql)
3.編譯安裝。make,make install。
4.到了第3步的時候。在/usr/local/php/lib/php/extensions里就會多了個no-debug-non-zts-20050922文件夾,它裡面就生成了一個pdo_mysql.so
5.修改php.ini,加入擴展語句extension="/usr/local/php/lib/php/extensions/no-debug-non-zts-20050922/pdo_mysql.so"
6.重啟apache。OK擴展完成
7.安裝pdo的方法與pdo_mysql的方法一樣.但是要注意在這個安裝過程中如果系統沒有aclocal命令,那麼請先安裝這個命令,這個命令在autoconf包里。
E. linux下的php到底是怎麼載入mysqli模塊的
添加擴展的基本步驟:
1、進入PHP源代碼目錄:# cd /tmp/php-5.2.14/
2、再進入要添加的mysqli擴展源碼目錄:# cd ext/mysqli/
2、調用已經編譯好的php裡面的phpize:# /usr/local/php/bin/phpize
3、然後configure:# ./configure --with-php-config=/usr/local/php/bin/php-config --with-mysqli=/usr/local/MySQL/bin/mysql_config
(/usr/local/mysql 為mysql的安裝目錄)
4、make && make install
5、編譯之後,自動把mysqli.so放到了默認的php擴展目錄下,我的為 /usr/local/php/lib/php/extensions/no-debug-non-zts-20060613/
(phpinfo可查看或者執行命令/usr/local/php/bin/php-config --extension-dir )
再修改php.ini 找到extension_dir 默認路徑為 extension_dir="./" 我修改後才啟動載入的
在下面添加extension = "mysqli.so" 保存即可
extension_dir="/usr/local/php/lib/php/extensions/no-debug-non-zts-20060613/"
extension = "mysqli.so"
6、重啟apache:# service httpd restart
F. linux系統php不支持:mysql
你這個是windows下面開啟擴展的方法。linux下需要編譯成.so文件後,再在配置文件中載入。希望可以幫助你,參考:PHP程序員,雷雪松的個人博客--http://www.leixuesong.cn,裡面有PHP相關擴展的安裝,如有疑問,可以加網站底部的群,一起交流下!
G. linux下PHP7可以連接mysql,卻不能讀取/插入數據
不能讀取是mysql的許可權沒有打開,操作如下:
1.MySQL命令行新建用戶
//登錄MYSQL
@>mysql -u root -p
@>密碼
//創建用戶
mysql> insert into mysql.user(Host,User,Password) values('localhost','phplamp',password('1234'));
//刷新系統許可權表
mysql>flush privileges;
這樣就創建了一個名為:phplamp 密碼為:1234 的用戶。
//退出後登錄一下
mysql>exit;
@>mysql -u phplamp -p
@>輸入密碼
mysql>登錄成功
2.MySQL命令行為用戶授權
//登錄MYSQL(有ROOT許可權)。我里我以ROOT身份登錄.
@>mysql -u root -p
@>密碼
//首先為用戶創建一個資料庫(phplampDB)
mysql>create database phplampDB;
//授權phplamp用戶擁有phplamp資料庫的所有許可權
@>grant all privileges on phplampDB.* to phplamp@localhost identified by '1234'; //這里需要注意,如果發現找不到用戶,需要執行命令 flush privilieges;
//刷新系統許可權表
mysql>flush privileges;
mysql>其它操作
//如果想指定部分許可權給一用戶,可以這樣來寫:
mysql>grant select,update on phplampDB.* to phplamp@localhost identified by '1234';
//刷新系統許可權表。
mysql>flush privileges;
mysql> grant 許可權1,許可權2,…許可權n on 資料庫名稱.表名稱 to 用戶名@用戶地址 identified by 『連介面令』;
許可權1,許可權2,…許可權n代表select,insert,update,delete,create,drop,index,alter,grant,references,reload,shutdown,process,file等14個許可權。
H. linunx下怎麼設置php資料庫支持已安裝的mysql
到官網下載 http://httpd.apache.org/download.cgi
2
解壓 tar -zxvf httpd-2.2.22.tar.gz
3
建立目標文件夾(注意以下所有操作都時在root用戶下執行的) mkdir /usr/local/apache2 也就是說等下安裝的apache2要安裝到這個文件夾裡面
4
配置 回到原來解壓之後產生的文件夾 ./configure --prefix=/usr/local/apache2 --enable-mole=shared 要加上後面的參數,否則無法使用php,-enable-mole=shared表示Apache可以動態的載入模塊
這一步,出現了很多問題:
第一個錯誤為:
checking for APR... no configure: error: APR not found. Please read the documentation.解決方法:download the latest versions of both APR and APR-Util from Apache APR, unpack them into ./srclib/apr and ./srclib/apr-util (be sure the domain names do not have version numbers; for example, the APR distribution must be under ./srclib/apr/)
then do
./configure --with-included-apr
另外一種解決方法為:分別安裝APR和APR-util,安裝方法為:首先下載這兩個文件,然後解壓,進入解壓後目錄,然後把APR和APR-util分別安裝到/usr/local/文件夾的apr和apr-util文件夾下。APR的具體安裝方法為:[root@localhost 52lamp]# tar -zxvf apr-1.4.2.tar.gz //unzip -o apr-1.4.2.zip[root@localhost 52lamp]# cd apr-1.4.2[root@localhost apr-1.4.2]# ./configure --prefix=/usr/local/apr[root@localhost apr-1.4.2]# make[root@localhost apr-1.4.2]# make install安裝Apr-util 在./confiure --prefix=/usr/local/apr-util --with-apr=/usr/local/apr其他步驟類似。
5
第二個錯誤為:no acceptable C compiler found in $Path直接運行 yum install gcc,安裝Gcc即可第三個問題為:pcre-config for libpcre not found解決方法就是 下載prce安裝包,和APR類似,安裝到/usr/local/pcre文件夾下面即可。PS:fedora下安裝c++編譯器g++的命令為:yum install gcc-c++ 。
6
編譯 make
安裝 make install
啟動,重啟和停止 ,先切換到安裝完成後的目錄/usr/local/apache2/bin ./apachectl -k start ./apachectl -k restart ./apachectl -k stop
配置文件(滿足最基本的配置) 編輯 /usr/local/apache2/conf/httpd.conf 文件 找到: AddType application/x-compress .Z AddType application/x-gzip .gz .tgz 在後面添加: AddType application/x-httpd-php .php(使Apcche支持PHP) AddType application/x-httpd-php-source .php5 找到: <IfMole dir_mole> DirectoryIndex index.html </IfMole> 添加: <IfMole dir_mole> DirectoryIndex index.html index.php </IfMole> 找到: #ServerName www.example.com:80 修改為: ServerName 127.0.0.1:80或者ServerName localhost:80 記得要去掉前面的「#」
7
測試 在瀏覽器里輸入http://127.0.0.1 如果出現It Works!說明成功。
8
修改默認的Web站點目錄
默認的目錄為 "/usr/local/apache2/htdocs",修改apache的配置文件httpd.conf,比如在新建一個 /home/gyw/WebSite的目錄作為apache的站點目錄
找到DocumentRoot這一行修改為:DocumentRoot "/home/gyw/WebSite"
找到 <Directory> 這一行修改為:<Directory "/home/gyw/WebSite">
測試:修改到文件夾出現錯誤:
「You don't have permission to access /index.html on this server.」
解決方法:
更改文件許可權;chmod 755 index.html
打開apache配置文件httpd.conf,找到這么一段:<Directory /> Options FollowSymLinks AllowOverride None Order deny,allow deny from all Satisfy all</Directory>
測試結果如下:
END
安裝PHP
1
下載 http://www.php.net/downloads.php解壓 tar -zxvf php-5.3.16.tar.gz建立目標文件夾 mkdir /usr/local/php 也就是說等下安裝的php要安裝到這個文件夾裡面
2
配置 回到原來解壓後的文件夾 ./configure --prefix=/usr/local/php --with-apxs2=/usr/local/apache/bin/apxs
注意這里有一個-with-apxs2=/usr/local/apache/bin/apxs選項,其中apxs是在安裝Apache時產生的,apxs是一個為Apache HTTP伺服器編譯和安裝擴展模塊的工具,使之可以用由mod_so提供的LoadMole指令在運行時載入到Apache伺服器中。我的理解是通過這個工具把PHP模塊動態載入到Apache中
出現錯誤:configure: error: xml2-config not found. Please check your libxml2 installation.
運行yum install libxml2,然後再運行yum install libxml2-devel安裝完畢後,重新運行上面的./configure命令。
3
編譯 make 測試編譯 make test 安裝 make install
4
、配置文件
cp /usr/local/src/php-5.3.16/php.ini-development /usr/local/php/lib/php.in
把原來位於源代碼裡面的php.ini-development拷貝到/usr/local/php/lib/php.ini下,並且重命名為php.ini
重啟apache
5
測試 在apache的htdocs下建立一個php文件test.php,裡面的內容如下: <?php phpinfo(); ?> 然後在瀏覽器里輸入http://127.0.0.1/test.php 如果出現php的相關配置,成功,如果什麼都沒有輸入,說明失敗,重新以上步驟或者查找原因
如果決定在安裝後改變配置選項,只需重復最後的三步configure, make, 以及 make install,然後需要重新啟動 Apache 使新模塊生效。Apache不需要重新編譯。
測試結果如下圖:
END
安裝MySql
1
下載 到官網下載mysql-5.1.65.tar.gz(注意是源碼包)解壓 tar -zxvf mysql-5.1.65.tar.gz建立目標文件夾 mkdir /usr/local/mysql 也就是說等下安裝的mysql要安裝到這個文件夾裡面
2
配置 ./configure --prefix=/usr/local/mysql/
在./configure時出現錯誤:error: No curses/termcap library found
下載安裝相應軟體包
yum list|grep ncurses
yum -y install ncurses-devel
yum install ncurses-devel
3
編譯 make安裝 make install
4
啟動 MySQL服務並不會自動啟動,還需要先初始化MySQL資料庫,操作如下: cd /usr/local/mysql/bin sudo ./mysql_install_db --user=root 注意,這里最後的root是指可以操作資料庫的用戶,可以是當前用戶,也可以新建用戶,與linux上的root用戶是兩回事,可以自己取一個名字 ./mysqld_safe --user=root & 這條命令負責啟動mysql服務的守護進程,此外最後的&時必須的,因為希望守護進程在後台運行 這里的root就是剛才的那個
5
為根用戶創建密碼 ./mysqladmin -u root password 『123456』 如果root已經設置過密碼,採用如下方法 ./mysqladmin -u root password oldpass 『123456』
6
測試 mysql -u root -p 會提示輸入密碼,就用剛才設置的密碼 123456 如果出現mysql>,說明連接成功了,下面通過命令 創建一個資料庫、建一個表,增加一條記錄,為後面的測試准備
mysql> create database gywtest; mysql> use gywtest;
mysql> create table student(id int(4) not null primary key auto_increment,stuname char(20));
mysql> insert into student(stuname) values('Tom');
注意每條命令後面有個分號,如果上面的都成功,後面就可以用這個測試。
END
將PHP與MySql結合起來
重新配置PHP,改變配置選項,只需重復PHP安裝時的最後的三步configure, make, 以及 make install,然後需要重新啟動 Apache 使新模塊生效,Apache不需要重新編譯。
配置
./configure --prefix=/usr/local/php --with-apxs2=/usr/local/apache2/bin/apxs --with-mysqli=/usr/local/mysql/bin/mysql_config 注意mysql_config 的路徑編譯 make
安裝 make installe
測試 寫一個頁面test.php,放在apache的web目錄下,測試上面用命令創建的資料庫
<?php $mysqli=new mysqli(); $mysqli->connect('localhost','root','123456','gywtest'); // 創建查詢 $sqlstr='select * from student'; //發送查詢給MySql $result=$mysqli->query($sqlstr); while($row=$result->fetch_object()) { $name=$row->stuname; echo $name; }?>
Fatal error: Class 'mysqli' not found in /home/lufangtao/Project/DB.php on line 3
解決方法:
/usr/local/php/bin/phpize 這里回車運行
出錯:
Cannot find config.m4. Make sure that you run './phpize' in the top level source directory of the mole
解決方法:
PHP源碼包文件夾下的EXT文件夾就是放置著目前版本的可用擴展,CD進去看看都有哪些你需要的?應該看到mysqli文件夾了吧~~~
在當前目錄下執行phpize
[root@localhost mysqli]#/usr/local/php/bin/phpize
Configuring for:
PHP Api Version: 20090626
Zend Modeule Api No: 20090626
Zend Extension Api No: 220090626
Cannot find autoconf. Please check your autoconf installation and the$PHP_AUTOCONF environment variable. Then, rerun this script.
解決方法:
yum install autoconf再次運行上面的命令即可。
[root@localhost mysqli]#./configure –prefix=/opt/mysqli –with-php-config=/opt/php/bin/php-config –with-mysqli=/opt/mysql/bin/mysql_config
[root@localhost mysqli]#make
[root@localhost mysqli]#make install
安裝完成後會有提示擴展所在目錄路徑,如:
/opt/php/lib/php/extensions/no-debug-zts-20090626php
所需的mysqli.so便會在此目錄下,接下來修改/opt/php/etc/下的php.ini文件,加入mysqli擴展,即加入如下一行:
extension=/opt/php/lib/php/extensions/no-debug-zts-20090626/mysqli.so
4
安裝完成!
I. linux上php怎麼添加mysql的擴展
不需要進行資料庫操作,不需要安裝mysql。 php的mysql擴展是php用於操作mysql資料庫的函數庫,如果需要進行資料庫操作,不僅要有函數庫,還需要安裝資料庫。
J. linux下,php連接遠程mysql的問題
在PHP的機器上需要安裝MYSQL的客戶端,否則沒有相應的頭文具,PHP就無法編譯通過,除非你的PHP是編譯好的。