剛開始才接觸php才發現macos還是比較強大了,macbook不僅是時尚達品還很實用哦。
--------------他山之石--------------------------
http://dancewithnet.com/2010/05/09/run-apache-php-mysql-in-mac-os-x/#php
啟動Apache
有兩種方法:
- 打開“系統設置偏好(System Preferences)” -> “共享(Sharing)” -> “Web共享(Web Sharing)”。注意,從Mac OS X從10.8開始取消了 “Web共享(Web Sharing)”。
- 打開“終端(terminal)”,然后(注意,sudo需要的密碼就是系統的root帳號密碼)
- 運行“
sudo apachectl start
”,再輸入帳號密碼,這樣Apache就運行了。 - 運行“
sudo apachectl -v
”,你會看到Mac OS X的Apache版本信息,如10.8.1中:Server version: Apache/2.2.22 (Unix) Server built: Jun 20 2012 13:57:09
- 運行“
如此在瀏覽器中輸入“http://localhost”,就可以看到一個內容為“It works!”的頁面,其位於“/Library(資源庫)/WebServer/Documents/”下,這就是Apache的默認根目錄。
運行PHP
- 在終端中運行“
sudo vi /etc/apache2/httpd.conf
”,打開Apache的配置文件。(如果不習慣操作終端和vi,可以設置在Finder中顯示所有系統隱藏文件,記得設置完畢后需要重啟Finder,然后就可以找到對應文件,隨心所欲編輯了,需要注意的是某些文件的修改還是需要開啟root帳號,但整體上還是在終端上使用sudo
來臨時獲取root權限比較安全。) - 找到“
#LoadModule php5_module libexec/apache2/libphp5.so
”,把前面的#號去掉,保存(在命令行輸入:w
)並退出vi(在命令行輸入:q
)。 - 運行“
sudo cp /etc/php.ini.default /etc/php.ini
”,這樣就可以運行sudo vi /etc/php.ini
來編輯php.ini配置各種功能了。比如:;通過下面兩項來調整PHP提交文件的最大值,如phpMyAdmin中導入數據的最大值 upload_max_filesize = 2M post_max_size = 8M ;通過display_errors來控制是否顯示PHP程序的報錯信息,這在調試PHP程序時非常有用 display_errors = Off
- 運行“
sudo apachectl restart
”,重啟Apache,這樣PHP就可以用了。 - 運行“
sudo cp /Library/WebServer/Documents/index.html.en /Library/WebServer/Documents/info.php
”,即在Apache的根目錄下復制index.html.en文件並重命名為info.php。 - 在終端中運行“
sudo vi /Library/WebServer/Document/info.php
”,這樣就可以在vi中編輯info.php文件了。在“It’s works!”后面加上“<?php phpinfo(); ?>
”,然后保存之。如此就可以在http://localhost/info.php中看到有關PHP的信息,比如10.8中內置PHP版本號是5.3.13。 - 對於不熟悉vi這種編輯器的人來說,實在是太惱火了。我決定下個eclipse。vi有兩種模式,命令模式和文本編輯模式。esc鍵就是回到命令模式,冒號:i就是插入模式。可以改寫文檔。:w就是保存,:q退出。
安裝MySQL
Mac OS X沒有內置MySQL,所以需要自己手動安裝,目前MySQL的最穩定版本是5.5。MySQL提供了Mac OS X下的安裝說明。
- 下載MySQL 5.5。選擇合適版本,如這里選擇了mysql-5.5.27-osx10.6-x86_64.dmg。
- 運行dmg,會發現里面有4個文件。首先點擊安裝mysql-5.5.27-osx10.6-x86_64.pkg,這是MySQL主安裝包。一般情況下,安裝文件會自動把MySQL安裝到
/usr/local
下的同名文件夾下。如運行“mysql-5.5.27-osx10.6-x86_64.dmg
”會把MySQL安裝到“/usr/local/mysql-5.5.27-osx10.6-x86_64
” 中,一路默認安裝完畢。(注意,從10.8開始Mac OS X的權限更加嚴格,直接點擊會提示“mysql-5.5.27-osx10.6-x86_64.pkg can’t be opened because it is from an unidentified developer. Your security preferences allow installation of only apps from the Mac App Store and identified developers.”阻止了安裝,你可以使用雙指單擊該安裝文件,在彈出菜單中選擇“用…打開(open with)”,再選擇“安裝(Installer)”就可以接着安裝了。) - 安裝第2個文件MySQLStartupItem.pkg,MySQL就會自動在開機時啟動了。(注意,10.8的安裝方法同上。)
- 安裝第3個文件MySQL.prefPane,就會在“系統設置偏好”中看到“MySQL”的ICON,通過它就可以控制MySQL是否開啟,以 及開機時是否自動運行。到這里MySQL就基本安裝完畢了。(注意,10.8中用雙指單擊該安裝文件,在彈出的菜單中選擇“用…打開(open with)”,然后選擇“系統偏好(System Perference)”就可以接着安裝了。)
- 通過運行“
sudo vi /etc/bashrc
”,在bash配置文件中加入mysqlstart
、mysql
和mysqladmin
的別名(注意:修改完畢之后需要退出“終端(Terminal)”之后重新進入,這些命令才會生效):#mysql alias mysqlstart='sudo /Library/StartupItems/MySQLCOM/MySQLCOM restart' alias mysql='/usr/local/mysql/bin/mysql' alias mysqladmin='/usr/local/mysql/bin/mysqladmin'
這樣就可以在終端中比較簡單地通過命令進行相應的操作。由於開始安裝MySQLStartupItem.pkg到“
/Library/StartupItems/MySQLCOM/
”來控制MySQL的運行、自動運行、停止、關閉之類。在MySQL沒有啟動時,直接運行mysql
或mysqladmin
命令會提示“Can't connect to local MySQL server through socket '/tmp/mysql.sock' (2)
”,所以我們可以通過控制面板或者直接運行mysqlstart
命令來啟動MySQL,之后再運行mysql
或mysqladmin
命令就正常了。比如安裝完畢后MySQL的root
默認密碼為空,如果要設置密碼可以在終端運行“mysqladmin -u root password "mysqlpassword"
”來設置,其中mysqlpassword即root的密碼。更多相關內容可以參考B.5.4.1. How to Reset the Root Password。
注意:Mac OS X的升級或其他原因可能會導致MySQL啟動或開機自動運行時,在MySQL操作面板上會提示“Warning:The /usr/local/mysql/data directory is not owned by the 'mysql' or '_mysql'
”,這應該是某種情況下導致/usr/local/mysql/data
的宿主發生了改變,只需要運行“sudo chown -R mysql /usr/local/mysql/data
”即可。
另外,使用PHP連接MySQL可能會報錯“Can’t connect to local MySQL server through socket ‘/var/mysql/mysql.sock’”,或使用localhost無法連接MySQL而需要127.0.0.1,原因是連接時php默認去找/var/mysql/mysql.sock
了,但MAC版的MYSQL改動了文件位置,放在/tmp下了。處理辦法是按如下修改php.ini:
mysql.default_socket = /tmp/mysql.sock
使用phpMyAdmin
phpMyAdmin是用PHP開發的管理MySQL的程序,非常的流行和實用。能夠使用phpMyAdmin管理MySQL是檢驗前面幾步效果的非常有效方式。
- 下載phpMyAdmin。選擇合適的版本,比如這里選擇phpMyAdmin-3.5.22-all-languages.tar.bz2這個版本。
- 把“下載(downloads)”中phpMyAdmin-3.5.22-all-languages.tar.bz2文件解壓到“
/Library/WebServer/Documents/
”中,並改名為phpmyadmin。sudo tar -xf ~/Downloads/phpMyAdmin-3.5.2.2-all-languages.tar.bz2 -C /Library/WebServer/Documents/ sudo mv /Library/WebServer/Documents/phpMyAdmin-3.5.2.2-all-languages /Library/WebServer/Documents/phpmyadmin
- 復制“
/Library/WebServer/Documents/phpmyadmin/
”中的config.sample.inc.php,並命名為config.inc.php - 編輯config.inc.php,修改如下:
用於Cookie加密,隨意的長字符串 $cfg['blowfish_secret'] = 'a8b7c6d'; 當phpMyAdmin中出現“#2002 無法登錄 MySQL 服務器(#2002 Cannot log in to the MySQL server)”時, 請把localhost改成127.0.0.1就ok了, 這是因為MySQL守護程序做了IP綁定(bind-address =127.0.0.1)造成的 $cfg['Servers'][$i]['host'] = 'localhost'; 把false改成true,這樣就可以訪問無密碼的MySQL了, 即使MySQL設置了密碼也可以這樣設置,然后登錄phpMyAdmin時輸入密碼 $cfg['Servers'][$i]['AllowNoPassword'] = false;
- 這樣就可以通過
http://localhost/phpmyadmin
訪問phpMyAdmin了。此時會看到一個 提示“無法加載 mcrypt 擴展,請檢查您的 PHP 配置。(The mcrypt extension is missing. Please check your PHP configuration.)”,這會涉及到下一節安裝MCrypt擴展了。 - 登錄名:root 密碼: (空)
關於錯誤處理:
解決 .#2002 無法登錄 MySQL 服務器
將config.sample.inc.php復制成config.inc.php
--------------------------------------------------
或者修改 php.ini : mysql.default_socket = /tmp/mysql.sock
#1045 無法登錄 MySQL 服務器。Access denied for user ‘root’@'localhost’ (using password: YES)
問題原因:這有可能是由於前面設置mysql密碼沒有成功,所以導致了我們使用設置的mysql root密碼無法登陸服務器。
解決方法:這時可以嘗試使用mysql 默認的root賬號的空密碼登陸數據庫。
如果使用空密碼登陸時又出現:空密碼登錄被禁止 (參見 允許空密碼) 的錯誤。則要修改/phpmyadmin/config.inc.php 文件,找到下面兩行
$cfg['Servers'][$i]['nopassword'] = false;
$cfg['Servers'][$i]['AllowNoPassword'] = false;
將兩個false改為true,同時設置 $cfg['Servers'][$i]['password'] = '';通過這樣設置配置文件后phpmyadmin 就會允許以空密碼方式登錄mysql數據庫了。
若重新以空密碼方式登錄phpmyadmin有時仍無法登陸,請清除cookie或關閉原來的phpmyadmin 登錄窗口,重新使用空密碼登錄。
若這時候仍然顯示空密碼登陸被禁止,試試隨便輸入幾個字符當作密碼看是否能夠登陸成功。
登陸mysql服務器之后盡快將mysql密碼在phpmyadmin中修改過來。