溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

在Mac OS X中配置Apache+PHP+MySQL運(yùn)行環(huán)境的詳細(xì)步驟

發(fā)布時(shí)間:2020-10-04 05:04:49 來(lái)源:腳本之家 閱讀:459 作者:mdxy-dxy 欄目:服務(wù)器

這是一篇超級(jí)詳細(xì)的配置mac os下面php+mysql+apache的文章。非常詳細(xì)

我的大部分配置就是參考上面的內(nèi)容的,比如,PHP不能連接數(shù)據(jù)庫(kù),就是改一下默認(rèn)的php.ini中pdo_mysql.default_socket【因?yàn)楝F(xiàn)在都用PDO了嘛。不用mysql的連接庫(kù)了】

因?yàn)槲沂怯胣avicat的,所以對(duì)phpmyadmin那一塊的配置就不太關(guān)心了。不過(guò)MCrypt的安裝可以參考。

Mac OS X 內(nèi)置了Apache 和 PHP,這樣使用起來(lái)非常方便。本文以Mac OS X 10.6.3為例。主要內(nèi)容包括:

啟動(dòng)Apache
運(yùn)行PHP
安裝MySQL
使用phpMyAdmin
配置PHP的MCrypt擴(kuò)展庫(kù)
設(shè)置虛擬主機(jī)

啟動(dòng)Apache

有兩種方法:

打開(kāi)“系統(tǒng)設(shè)置偏好(System Preferences)” -> “共享(Sharing)” -> “Web共享(Web Sharing)”
打開(kāi)“終端(terminal)”,然后(注意:sudo需要的密碼就是系統(tǒng)的root帳號(hào)密碼)
運(yùn)行“sudo apachectl start”,再輸入帳號(hào)密碼,這樣Apache就運(yùn)行了。
運(yùn)行“sudo apachectl -v”,你會(huì)看到Mac OS X 10.6.3中的Apache版本號(hào):
Server version: Apache/2.2.14 (Unix) Server built: Feb 11 2010 14:40:31
這樣在瀏覽器中輸入“http://localhost”,就可以看到出現(xiàn)一個(gè)內(nèi)容為“It works!”的頁(yè)面,它位于“/Library(資源庫(kù))/WebServer/Documents/”下,這是Apache的默認(rèn)根目錄。

注意:開(kāi)啟了Apache就是開(kāi)啟了“Web共享”,這時(shí)聯(lián)網(wǎng)的用戶就會(huì)通過(guò)“http://[本地IP]/”來(lái)訪問(wèn)“/Library(資源庫(kù)) /WebServer/Documents/”目錄,通過(guò)“http://[本地IP]/~[用戶名]”來(lái)訪問(wèn)“/Users/[用戶名]/Sites /”目錄,可以通過(guò)設(shè)置“系統(tǒng)偏好設(shè)置”的“安全(Security)”中的“防火墻(Firewall)”來(lái)禁止這種訪問(wèn)。

運(yùn)行PHP

在終端中運(yùn)行“sudo vi /etc/apache2/httpd.conf”,打開(kāi)Apache的配置文件。(如果不習(xí)慣操作終端和vi的可以設(shè)置在Finder中顯示所有的系統(tǒng)隱藏文件,記得需要重啟Finder,這樣就可以找到對(duì)應(yīng)文件,隨心所欲編輯了,但需要注意的是某些文件的修改需要開(kāi)啟root帳號(hào),但整體上還是在終端上使用sudo來(lái)臨時(shí)獲取root權(quán)限比較安全。)
找到“#LoadModule php5_module libexec/apache2/libphp5.so”,把前面的#號(hào)去掉,保存(在命令行輸入:w)并退出vi(在命令行輸入:q)。
運(yùn)行“sudo cp /etc/php.ini.default /etc/php.ini”,這樣就可以通過(guò)php.ini來(lái)配置各種PHP功能了。比如:
;通過(guò)下面兩項(xiàng)來(lái)調(diào)整PHP提交文件的最大值,比如phpMyAdmin中導(dǎo)入數(shù)據(jù)的最大值 upload_max_filesize = 2M post_max_size = 8M ;比如通過(guò)display_errors來(lái)控制是否顯示PHP程序的報(bào)錯(cuò) display_errors = Off
運(yùn)行“sudo apachectl restart”,重啟Apache,這樣PHP就可以用了。
運(yùn)行“cp /Library/WebServer/Documents/index.html.en /Library/WebServer/Documents/info.php”,即在Apache的根目錄下復(fù)制index.html.en文件并重命名為info.php
在終端中運(yùn)行“vi /Library/WebServer/Document/info.php”,這樣就可以在vi中編輯info.php文件了。在“It's works!”后面加上“<?php phpinfo(); ?>”,然后保存之。這樣就可以在http://localhost/info.php中看到有關(guān)PHP的信息,比如版本號(hào)是5.3.1。

安裝MySQL

由于Mac OS X中并沒(méi)有預(yù)裝MySQL,所以需要自己手動(dòng)安裝,目前MySQL的最穩(wěn)定版本是5.1。MySQL提供了Mac OS X下的安裝說(shuō)明。

下載MySQL 5.1。選擇合適的版本,比如這里選擇的是mysql-5.1.46-osx10.6-x86_64.dmg。
運(yùn)行dmg,會(huì)發(fā)現(xiàn)里面有4個(gè)文件。首先點(diǎn)擊安裝mysql-5.1.46-osx10.6-x86_64.pkg,這是MySQL的主安裝包。 一般情況下,安裝文件會(huì)自動(dòng)把MySQL安裝到/usr/local下的同名文件夾下。比如點(diǎn)擊運(yùn)行“mysql-5.1.46-osx10.6- x86_64.dmg”會(huì)把MySQ安裝到“/usr/local/mysql-5.1.46-osx10.6-x86_64”中。一路默認(rèn)安裝完畢即可。
點(diǎn)擊安裝第2個(gè)文件MySQLStartupItem.pkg,這樣MySQL就會(huì)自動(dòng)在開(kāi)機(jī)時(shí)自動(dòng)啟動(dòng)了。
點(diǎn)擊安裝第3個(gè)文件MySQL.prefPane,這樣就會(huì)在“系統(tǒng)設(shè)置偏好”中看到名為“MySQL”的ICON,通過(guò)它就可以設(shè)置MySQL開(kāi)始還是停止,以及是否開(kāi)機(jī)時(shí)自動(dòng)運(yùn)行。到這里MySQL就基本安裝完畢了。
通過(guò)運(yùn)行“sudo vi /etc/bashrc”,在bash的配置文件中加入mysql和mysqladmin的別名
#mysql alias mysql='/usr/local/mysql/bin/mysql' alias mysqladmin='/usr/local/mysql/bin/mysqladmin'
這樣就可以在終端中比較簡(jiǎn)單地通過(guò)命令進(jìn)行相應(yīng)的操作,比如安裝完畢之后MySQL的root默認(rèn)密碼為空,如果要設(shè)置密碼可以在終端運(yùn)行“mysqladmin -u root password "mysqlpassword"”來(lái)設(shè)置,其中mysqlpassword即root的密碼。更多相關(guān)內(nèi)容可以參考B.5.4.1. How to Reset the Root Password。

注意:Mac OS X的升級(jí)或者其他原因可能會(huì)導(dǎo)致MySQL啟動(dòng)或者開(kāi)機(jī)自動(dòng)運(yùn)行,在MySQL的操作面板上會(huì)提示“Warning:The /usr/local/mysql/data directory is not owned by the 'mysql' or '_mysql' ”,或者在命令行下提示“Can't connect to local MySQL server through socket '/tmp/mysql.sock' (2)”,這應(yīng)該是某種情況下導(dǎo)致/usr/local/mysql/data的宿主發(fā)生了改變,只需要運(yùn)行“sudo chown -R mysql /usr/local/mysql/data”即可。

另外,使用PHP連接MySQL可能會(huì)報(bào)錯(cuò)“Can't connect to local MySQL server through socket ‘/var/mysql/mysql.sock'”,或者使用localhost無(wú)法連接MySQL而需要127.0.0.1,原因是連接時(shí)候php默認(rèn) 去找/var/mysql/mysql.sock了,但是MAC版本的MYSQL改動(dòng)了文件的位置,放在/tmp下了。處理辦法是按如下修改 php.ini:

mysql.default_socket = /tmp/mysql.sock

使用phpMyAdmin

phpMyAdmin是用PHP開(kāi)發(fā)的管理MySQL的程序,非常的流行和實(shí)用。能夠?qū)嵱胮hpMyAdmin管理MySQL是檢驗(yàn)前面幾步成果的非常有效方式。

下載phpMyAdmin。選擇合適的版本,比如我選擇的是phpMyAdmin-3.3.2-all-languages.tar.bz2這個(gè)版本。
把“下載(downloads)”中的phpMyAdmin-3.32-all-languages文件夾復(fù)制到“/Users/[用戶名]/Sites”中,名改名為phpmyadmin。
復(fù)制“/Users/[用戶名]/Sites/phpmyadmin/”中的config.sample.inc.php,并命名為config.inc.php
打開(kāi)config.inc.php,做如下修改:
用于Cookie加密,隨意的長(zhǎng)字符串 $cfg['blowfish_secret'] = ''; 當(dāng)phpMyAdmin中出現(xiàn)“#2002 無(wú)法登錄 MySQL 服務(wù)器”時(shí), 請(qǐng)把localhost改成127.0.0.1就ok了, 這是因?yàn)镸ySQL守護(hù)程序做了IP綁定(bind-address =127.0.0.1)造成的 $cfg['Servers'][$i]['host'] = 'localhost'; 把false改成true,這樣就可以訪問(wèn)無(wú)密碼的MySQL了, 即使MySQL設(shè)置了密碼也可以這樣設(shè)置,然后在登錄phpMyAdmin時(shí)輸入密碼 $cfg['Servers'][$i]['AllowNoPassword'] = false;
這樣就可以通過(guò)http://localhost/~[用戶名]/phpmyadmin訪問(wèn)phpMyAdmin了。這個(gè)時(shí)候就看到一個(gè)提示“無(wú)法加載 mcrypt 擴(kuò)展,請(qǐng)檢查您的 PHP 配置?!?,這就涉及到下一節(jié)安裝MCrypt擴(kuò)展了。
配置PHP的MCrypt擴(kuò)展

MCrypt是一個(gè)功能強(qiáng)大的加密算法擴(kuò)展庫(kù),它包括有22種算法,phpMyAdmin依賴這個(gè)PHP擴(kuò)展庫(kù)。但是它在Mac OS X下的安裝卻不那么友善,具體如下:

下載并解壓libmcrypt-2.5.8.tar.bz2。
在終端執(zhí)行如下命令(注意如下命令需要安裝xcode支持):

cd ~/Downloads/libmcrypt-2.5.8/ 
./configure --disable-posix-threads --enable-static 
make 
sudo make install 

下載并解壓PHP源碼文件php-5.3.1.tar.bz2。Mac OS X 10.6.3中預(yù)裝的PHP版本是5.3.1,而現(xiàn)在最新的PHP版本是5.3.2,你需要依據(jù)自己的實(shí)際情況選擇對(duì)應(yīng)的版本。
在終端執(zhí)行如下命令:

cd ~/Downloads/php-5.3.1/ext/mcrypt 
phpize 
./configure 
make 
cd modules 
sudo cp mcrypt.so /usr/lib/php/extensions/no-debug-non-zts-20090626/ 
打開(kāi)php.ini
sudo vi /etc/php.ini

在php.ini中加入如下代碼,并保存后退出,然后重啟Apache

extension=/usr/lib/php/extensions/no-debug-non-zts-20090626/mcrypt.so
當(dāng)你再訪問(wèn)http://localhost/~[用戶名]/phpmyadmin時(shí),你會(huì)發(fā)現(xiàn)“無(wú)法加載 mcrypt 擴(kuò)展,請(qǐng)檢查您的 PHP 配置。”的提示沒(méi)有了,這就表示MCrypt擴(kuò)展庫(kù)安裝成功了。

設(shè)置虛擬主機(jī)

在終端運(yùn)行“sudo vi /etc/apache2/httpd.conf”,打開(kāi)Apche的配置文件
在httpd.conf中找到“#Include /private/etc/apache2/extra/httpd-vhosts.conf”,去掉前面的“#”,保存并退出。
運(yùn)行“sudo apachectl restart”,重啟Apache后就開(kāi)啟了它的虛擬主機(jī)配置功能。
運(yùn)行“sudo vi /etc/apache2/extra/httpd-vhosts.conf”,這樣就打開(kāi)了配置虛擬主機(jī)的文件httpd-vhost.conf,配置你需要的虛擬主機(jī)了。需要注意的是該文件默認(rèn)開(kāi)啟了兩個(gè)作為例子的虛擬主機(jī):

<VirtualHost *:80> 
ServerAdmin webmaster@dummy-host.example.com 
DocumentRoot "/usr/docs/dummy-host.example.com" 
ServerName dummy-host.example.com 
ErrorLog "/private/var/log/apache2/dummy-host.example.com-error_log" 
CustomLog "/private/var/log/apache2/dummy-host.example.com-access_log" common 
</VirtualHost> 
<VirtualHost *:80> 
ServerAdmin webmaster@dummy-host2.example.com 
DocumentRoot "/usr/docs/dummy-host2.example.com" 
ServerName dummy-host2.example.com 
ErrorLog "/private/var/log/apache2/dummy-host2.example.com-error_log" 
CustomLog "/private/var/log/apache2/dummy-host2.example.com-access_log" common 
</VirtualHost> 

而實(shí)際上,這兩個(gè)虛擬主機(jī)是不存在的,在沒(méi)有配置任何其他虛擬主機(jī)時(shí),可能會(huì)導(dǎo)致訪問(wèn)localhost時(shí)出現(xiàn)如下提示:

Forbidden You don't have permission to access /index.php on this server

最簡(jiǎn)單的辦法就是在它們每行前面加上#,注釋掉就好了,這樣既能參考又不導(dǎo)致其他問(wèn)題。

增加如下配置

<VirtualHost *:80> 
DocumentRoot "/Users/[用戶名]/Sites" 
ServerName sites 
ErrorLog "/private/var/log/apache2/sites-error_log" 
CustomLog "/private/var/log/apache2/sites-access_log" common 
</VirtualHost> 

保存退出,并重啟Apache。

運(yùn)行“sudo vi /etc/hosts”,打開(kāi)hosts配置文件,加入”127.0.0.1 sites“,這樣就可以配置完成sites虛擬主機(jī)了,這樣就可以用“http://sites”訪問(wèn)了,其內(nèi)容和“http://localhost/~[用戶名]”完全一致。
這是利用Mac OS X 10.6.3中原生支持的方式來(lái)實(shí)現(xiàn)的配置,也可以參考“Mac OS X Leopard: 配置Apache, PHP, SQLite, MySQL, and phpMyAdmin(一) ”和“Mac OS X Leopard: 配置Apache, PHP, SQLite, MySQL, and phpMyAdmin(二) ”。實(shí)際上,你還可以使用XAMPP或MacPorts這種第三方提供的集成方案來(lái)實(shí)現(xiàn)簡(jiǎn)單的安裝和使用。

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

mac os x
AI