在Mac OS X中配置Apache + PHP + MySQL 很詳細

來源:互聯網
上載者:User

標籤:

這是一篇超級詳細的配置mac os下面php+mysql+apache的文章。非常詳細
我的大部分配置就是參考上面的內容的,比如,PHP不能串連資料庫,就是改一下預設的php.ini中pdo_mysql.default_socket【因為現在都用PDO了嘛。不用mysql的串連庫了】
因為我是用navicat的,所以對phpmyadmin那一塊的配置就不太關心了。不過MCrypt的安裝可以參考。
原文來自:在Mac OS X中配置Apache + PHP + MySQL
內容如下:

Mac OS X 內建了Apache 和 PHP,這樣使用起來非常方便。本文以Mac OS X 10.6.3為例。主要內容包括:

  1. 啟動Apache
  2. 運行PHP
  3. 安裝MySQL
  4. 使用phpMyAdmin
  5. 配置PHP的MCrypt擴充庫
  6. 設定虛擬機器主機
啟動Apache

有兩種方法:

  1. 開啟“系統設定偏好(System Preferences)” -> “共用(Sharing)” -> “Web共用(Web Sharing)”
  2. 開啟“終端(terminal)”,然後(注意:sudo需要的密碼就是系統的root帳號密碼)
    1. 運行“sudo apachectl start”,再輸入帳號密碼,這樣Apache就運行了。
    2. 運行“sudo apachectl -v”,你會看到Mac OS X 10.6.3中的Apache版本號碼:
      Server version: Apache/2.2.14 (Unix) Server built:   Feb 11 2010 14:40:31

這樣在瀏覽器中輸入“http://localhost”,就可以看到出現一個內容為“It works!”的頁面,它位於“/Library(資產庫)/WebServer/Documents/”下,這是Apache的預設根目錄。

 

注意:開啟了Apache就是開啟了“Web共用”,這時連網的使用者就會通過“http://[本地IP]/”來訪問“/Library(資產庫) /WebServer/Documents/”目錄,通過“http://[本地IP]/~[使用者名稱]”來訪問“/Users/[使用者名稱]/Sites /”目錄,可以通過設定“系統喜好設定”的“安全(Security)”中的“防火牆(Firewall)”來禁止這種訪問。

運行PHP
  1. 在終端中運行“sudo vi /etc/apache2/httpd.conf”,開啟Apache的設定檔。(如果不習慣操作終端和vi的可以設定在Finder中顯示所有的系統隱藏檔案,記得需要重啟Finder,這樣就可以找到對應檔案,隨心所欲編輯了,但需要注意的是某些檔案的修改需要開啟root帳號,但整體上還是在終端上使用sudo來臨時擷取root許可權比較安全。)
  2. 找到“#LoadModule php5_module libexec/apache2/libphp5.so”,把前面的#號去掉,儲存(在命令列輸入:w)並退出vi(在命令列輸入:q)。
  3. 運行“sudo cp /etc/php.ini.default /etc/php.ini”,這樣就可以通過php.ini來配置各種PHP功能了。比如:
    ;通過下面兩項來調整PHP提交檔案的最大值,比如phpMyAdmin中匯入資料的最大值 upload_max_filesize = 2M post_max_size = 8M ;比如通過display_errors來控制是否顯示PHP程式的報錯 display_errors = Off
  4. 運行“sudo apachectl restart”,重啟Apache,這樣PHP就可以用了。
  5. 運行“cp /Library/WebServer/Documents/index.html.en /Library/WebServer/Documents/info.php”,即在Apache的根目錄下複製index.html.en檔案並重新命名為info.php
  6. 在終端中運行“vi /Library/WebServer/Document/info.php”,這樣就可以在vi中編輯info.php檔案了。在“It’s works!”後面加上“<?php phpinfo(); ?>”,然後儲存之。這樣就可以在http://localhost/info.php中看到有關PHP的資訊,比如版本號碼是5.3.1。
安裝MySQL

由於Mac OS X中並沒有預裝MySQL,所以需要自己手動安裝,目前MySQL的最穩定版本是5.1。MySQL提供了Mac OS X下的安裝說明。

  1. 下載MySQL 5.1。選擇合適的版本,比如這裡選擇的是mysql-5.1.46-osx10.6-x86_64.dmg。
  2. 運行dmg,會發現裡面有4個檔案。首先點擊安裝mysql-5.1.46-osx10.6-x86_64.pkg,這是MySQL的主安裝包。 一般情況下,安裝檔案會自動把MySQL安裝到/usr/local下的同名檔案夾下。比如點擊運行“mysql-5.1.46-osx10.6- x86_64.dmg”會把MySQ安裝到“/usr/local/mysql-5.1.46-osx10.6-x86_64”中。一路預設安裝完畢即可。
  3. 點擊安裝第2個檔案MySQLStartupItem.pkg,這樣MySQL就會自動在開機時自動啟動了。
  4. 點擊安裝第3個檔案MySQL.prefPane,這樣就會在“系統設定偏好”中看到名為“MySQL”的ICON,通過它就可以設定MySQL開始還是停止,以及是否開機時自動運行。到這裡MySQL就基本安裝完畢了。
  5. 通過運行“sudo vi /etc/bashrc”,在bash的設定檔中加入mysql和mysqladmin的別名
    #mysql alias mysql=‘/usr/local/mysql/bin/mysql‘ alias mysqladmin=‘/usr/local/mysql/bin/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‘ ”,或者在命令列下提示“Can‘t connect to local MySQL server through socket ‘/tmp/mysql.sock‘ (2)”,這應該是某種情況下導致/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是檢驗前面幾步成果的非常有效方式。

  1. 下載phpMyAdmin。選擇合適的版本,比如我選擇的是phpMyAdmin-3.3.2-all-languages.tar.bz2這個版本。
  2. 把“下載(downloads)”中的phpMyAdmin-3.32-all-languages檔案夾複製到“/Users/[使用者名稱]/Sites”中,名改名為phpmyadmin。
  3. 複製“/Users/[使用者名稱]/Sites/phpmyadmin/”中的config.sample.inc.php,並命名為config.inc.php
  4. 開啟config.inc.php,做如下修改:
    用於Cookie加密,隨意的長字串 $cfg[‘blowfish_secret‘] = ‘‘;   當phpMyAdmin中出現“#2002 無法登入 MySQL 伺服器”時, 請把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;
  5. 這樣就可以通過http://localhost/~[使用者名稱]/phpmyadmin訪問phpMyAdmin了。這個時候就看到一個提示“無法載入 mcrypt 擴充,請檢查您的 PHP 配置。”,這就涉及到下一節安裝MCrypt擴充了。
配置PHP的MCrypt擴充

MCrypt是一個功能強大的密碼編譯演算法擴充庫,它包括有22種演算法,phpMyAdmin依賴這個PHP擴充庫。但是它在Mac OS X下的安裝卻不那麼友善,具體如下:

  1. 下載並解壓libmcrypt-2.5.8.tar.bz2。
  2. 在終端執行如下命令(注意如下命令需要安裝xcode支援):XML/HTML代碼
    1. cd ~/Downloads/libmcrypt-2.5.8/   
    2. ./configure --disable-posix-threads --enable-static   
    3. make   
    4. sudo make install  
  3. 下載並解壓PHP源碼檔案php-5.3.1.tar.bz2。Mac OS X 10.6.3中預裝的PHP版本是5.3.1,而現在最新的PHP版本是5.3.2,你需要依據自己的實際情況選擇對應的版本。
  4. 在終端執行如下命令:XML/HTML代碼
    1. cd ~/Downloads/php-5.3.1/ext/mcrypt   
    2. phpize   
    3. ./configure   
    4. make   
    5. cd modules   
    6. sudo cp mcrypt.so /usr/lib/php/extensions/no-debug-non-zts-20090626/ 
  5. 開啟php.ini
    sudo vi /etc/php.ini

    在php.ini中加入如下代碼,並儲存後退出,然後重啟Apache

    extension=/usr/lib/php/extensions/no-debug-non-zts-20090626/mcrypt.so

當你再訪問http://localhost/~[使用者名稱]/phpmyadmin時,你會發現“無法載入 mcrypt 擴充,請檢查您的 PHP 配置。”的提示沒有了,這就表示MCrypt擴充庫安裝成功了。

設定虛擬機器主機
  1. 在終端運行“sudo vi /etc/apache2/httpd.conf”,開啟Apche的設定檔
  2. 在httpd.conf中找到“#Include /private/etc/apache2/extra/httpd-vhosts.conf”,去掉前面的“#”,儲存並退出。
  3. 運行“sudo apachectl restart”,重啟Apache後就開啟了它的虛擬機器主機配置功能。
  4. 運行“sudo vi /etc/apache2/extra/httpd-vhosts.conf”,這樣就開啟了配置虛擬機器主機的檔案httpd-vhost.conf,配置你需要的虛擬機器主機了。需要注意的是該檔案預設開啟了兩個作為例子的虛擬機器主機:XML/HTML代碼
    1. <VirtualHost *:80>  
    2.     ServerAdmin [email protected]  
    3.     DocumentRoot "/usr/docs/dummy-host.example.com"  
    4.     ServerName dummy-host.example.com  
    5.     ErrorLog "/private/var/log/apache2/dummy-host.example.com-error_log"  
    6.     CustomLog "/private/var/log/apache2/dummy-host.example.com-access_log" common  
    7. </VirtualHost>  
    8. <VirtualHost *:80>  
    9.     ServerAdmin [email protected]  
    10.     DocumentRoot "/usr/docs/dummy-host2.example.com"  
    11.     ServerName dummy-host2.example.com  
    12.     ErrorLog "/private/var/log/apache2/dummy-host2.example.com-error_log"  
    13.     CustomLog "/private/var/log/apache2/dummy-host2.example.com-access_log" common  
    14. </VirtualHost>   

    而實際上,這兩個虛擬機器主機是不存在的,在沒有配置任何其他虛擬機器主機時,可能會導致訪問localhost時出現如下提示:

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

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

  5. 增加如下配置XML/HTML代碼
    1. <VirtualHost *:80>  
    2.     DocumentRoot "/Users/[使用者名稱]/Sites"  
    3.     ServerName sites  
    4.     ErrorLog "/private/var/log/apache2/sites-error_log"  
    5.     CustomLog "/private/var/log/apache2/sites-access_log" common  
    6. </VirtualHost>  

    儲存退出,並重啟Apache。

  6. 運行“sudo vi /etc/hosts”,開啟hosts設定檔,加入”127.0.0.1 sites“,這樣就可以配置完成sites虛擬機器主機了,這樣就可以用“http://sites”訪問了,其內容和“http://localhost/~[使用者名稱]”完全一致。

這是利用Mac OS X 10.6.3中原生支援的方式來實現的配置,也可以參考“Mac OS X Leopard: 配置Apache, PHP, SQLite, MySQL, and phpMyAdmin(一) ”和“Mac OS X Leopard: 配置Apache, PHP, SQLite, MySQL, and phpMyAdmin(二) ”。實際上,你還可以使用XAMPP或MacPorts這種第三方提供的整合方案來實現簡單的安裝和使用。

--------
值得一觀

原文連結:膘叔

在Mac OS X中配置Apache + PHP + MySQL 很詳細

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.