在Mac OS X中配置Apache + PHP + MySQL

在Mac OS X中配置Apache + PHP + MySQL

Mac OS X 內置Apache 和 PHP,使用起來很是方便。本文以Mac OS X 10.6.3和 10.8.1爲例。主要內容包括:php

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

啓動Apache

有兩種方法:html

  1. 打開「系統設置偏好(System Preferences)」 -> 「共享(Sharing)」 -> 「Web共享(Web Sharing)」。注意,從Mac OS X從10.8開始取消了 「Web共享(Web Sharing)」。
  2. 打開「終端(terminal)」,而後(注意,sudo須要的密碼就是系統的root賬號密碼)
    1. 運行「sudo apachectl start」,再輸入賬號密碼,這樣Apache就運行了。
    2. 運行「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的默認根目錄。mysql

 

注意:開啓了Apache就是開啓了「Web共享」,這時聯網用戶就會經過「http://[本地IP]/」來訪問「/Library(資源庫)/WebServer/Documents/」目錄,經過「http://[本地IP]/~[用戶名]」來訪問「/Users/[用戶名]/Sites/」目錄。值得注意的是,Mac OS X在10.8中取消」Web共享(Web Sharing)」時,也移除了「/Users/[用戶名]/Sites/」目錄,因此10.8中訪問「http://[本地IP]/~[用戶名]」會顯示「403 Forbidden」,但http://[本地IP]/依舊能夠訪問。能夠到「系統偏好設置」 -> 「安全(Security)」 -> 「防火牆(Firewall)」,開啓防火牆,而後在「防火牆選項(Firewall Options)」中勾上「組織全部進入鏈接(block all incoming connections)」便可。也能夠經過設置httpd.conf來只容許localhost和127.0.0.1訪問「/Library(資源庫)/WebServer/Documents/」。web

<Directory "/Library/WebServer/Documents">
    ......
    #
    # Controls who can get stuff from this server.
    #
    Order allow,deny
    #Allow from all
    Allow from 127.0.0.1
    Allow from localhost 

</Directory>

運行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」,這樣就能夠運行sudo vi /etc/php.ini來編輯php.ini配置各類功能了。好比:
    ;經過下面兩項來調整PHP提交文件的最大值,如phpMyAdmin中導入數據的最大值
    upload_max_filesize = 2M
    post_max_size = 8M
    ;經過display_errors來控制是否顯示PHP程序的報錯信息,這在調試PHP程序時很是有用
    display_errors = Off
  4. 運行「sudo apachectl restart」,重啓Apache,這樣PHP就能夠用了。
  5. 運行「sudo cp /Library/WebServer/Documents/index.html.en /Library/WebServer/Documents/info.php」,即在Apache的根目錄下複製index.html.en文件並重命名爲info.php。
  6. 在終端中運行「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。

安裝MySQL

Mac OS X沒有內置MySQL,因此須要本身手動安裝,目前MySQL的最穩定版本是5.5。MySQL提供了Mac OS X下的安裝說明ajax

  1. 下載MySQL 5.5。選擇合適版本,如這裏選擇了mysql-5.5.27-osx10.6-x86_64.dmg。
  2. 運行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)」就能夠接着安裝了。)
  3. 安裝第2個文件MySQLStartupItem.pkg,MySQL就會自動在開機時啓動了。(注意,10.8的安裝方法同上。)
  4. 安裝第3個文件MySQL.prefPane,就會在「系統設置偏好」中看到「MySQL」的ICON,經過它就能夠控制MySQL是否開啓,以及開機時是否自動運行。到這裏MySQL就基本安裝完畢了。(注意,10.8中用雙指單擊該安裝文件,在彈出的菜單中選擇「用…打開(open with)」,而後選擇「系統偏好(System Perference)」就能夠接着安裝了。)
  5. 經過運行「sudo vi /etc/bashrc」,在bash配置文件中加入mysqlstartmysqlmysqladmin的別名(注意:修改完畢以後須要退出「終端(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沒有啓動時,直接運行mysqlmysqladmin命令會提示「Can't connect to local MySQL server through socket '/tmp/mysql.sock' (2)」,因此咱們能夠經過控制面板或者直接運行mysqlstart命令來啓動MySQL,以後再運行mysqlmysqladmin命令就正常了。好比安裝完畢後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」便可。sql

另外,使用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:macos

mysql.default_socket = /tmp/mysql.sock

使用phpMyAdmin

phpMyAdmin是用PHP開發的管理MySQL的程序,很是的流行和實用。可以使用phpMyAdmin管理MySQL是檢驗前面幾步效果的很是有效方式。apache

  1. 下載phpMyAdmin。選擇合適的版本,好比這裏選擇phpMyAdmin-3.5.22-all-languages.tar.bz2這個版本。
  2. 把「下載(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
  3. 複製「/Library/WebServer/Documents/phpmyadmin/」中的config.sample.inc.php,並命名爲config.inc.php
  4. 編輯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;
  5. 這樣就能夠經過http://localhost/phpmyadmin訪問phpMyAdmin了。此時會看到一個提示「沒法加載 mcrypt 擴展,請檢查您的 PHP 配置。(The mcrypt extension is missing. Please check your PHP configuration.)」,這會涉及到下一節安裝MCrypt擴展了。

配置PHP的MCrypt擴展

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

  1. 下載libmcrypt-2.5.8.tar.gz
  2. 在終端執行以下命令(注意以下命令須要安裝Xcode支持,可直接去Mac App Store下載,安裝完畢後可能會發如今終端運行./configure --disable-posix-threads --enable-static會報錯,運行make會提示命令不存在,此時還須要打開Xcode,而後在Xcode的軟件「配置(Preference…)」)-> 「下載(Downloads)」 中安裝 「命令行工具(Command Line Tools)」:
    cd ~/Downloads
    tar -zxvf libmcrypt-2.5.8.tar.bz2
    cd libmcrypt-2.5.8
    ./configure --disable-posix-threads --enable-static
    make
    sudo make install
  3. 下載PHP源碼文件php-5.3.13.tar.bz2,記得選擇中國鏡像會比較快。Mac OS X 10.6.3中預裝的PHP版本是5.3.1,10.8的版本是5.3.13,而如今最新的PHP版本是5.4.6,因此須要依據本身的實際狀況選擇對應的版本,本文以10.8的PHP版本爲例。
  4. 在終端執行以下命令,把php-5.3.13.tar.bz2,並配置autoconf(在新的Mac OS X的Xcode中須要本身配置),而後才能運行phpize命令:
    cd ~/Downloads
    tar -zxvf php-5.3.13.tar.bz2
    
    cd php-5.3.13/ext/mcrypt
    curl -O http://ftp.gnu.org/gnu/autoconf/autoconf-latest.tar.gz
    tar -zxvf autoconf-latest.tar.gz
    cd autoconf-2.69
    ./configure
    make
    sudo make install
    
    cd ..
    phpize
    ./configure
    make
    sudo make install
  5. 打開php.ini
    sudo vi /etc/php.ini

    在php.ini中加入以下代碼,並保存後退出,而後重啓Apache

    extension=mcrypt.so

當你再訪問http://localhost/phpmyadmin時,會發現「沒法加載 mcrypt 擴展,請檢查您的 PHP 配置。」提示沒有了,這就表示MCrypt擴展庫安裝成功了。若是還不能加載,嘗試把php.ini中的加入的extension修改成:

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

Mac OS X下安裝MCrypt擴展的確比較複雜,並且稍微不當心會有各類小問題出現,你們還能夠參考How to Install mcrypt for php on Mac OSX Lion 10.8 & 10.7 Development ServerAdding MCRYPT to your OSX Lion PHP install

設置虛擬主機

  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,配置虛擬主機了。須要注意的是該文件默認開啓了兩個做爲例子的虛擬主機:
    <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>

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

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

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

  5. 增長以下配置
    <VirtualHost *:80>
        DocumentRoot "/Library/WebServer/Documents"
        ServerName localhost
        ErrorLog "/private/var/log/apache2/localhost-error_log"
        CustomLog "/private/var/log/apache2/localhost-access_log" common
    </VirtualHost> 
    
    <VirtualHost *:80>
        DocumentRoot "/Users/[用戶名]/Sites"
        ServerName sites
        ErrorLog "/private/var/log/apache2/sites-error_log"
        CustomLog "/private/var/log/apache2/sites-access_log" common
        <Directory />
                    Options Indexes FollowSymLinks MultiViews
                    AllowOverride None
                    Order deny,allow
                    Allow from all
          </Directory>
    </VirtualHost>

    保存退出,並重啓Apache。

  6. 運行「sudo vi /etc/hosts」,打開hosts配置文件,加入"127.0.0.1 sites",這樣就能夠配置完成sites虛擬主機了,能夠訪問「http://sites」了,在10.8以前Mac OS X版本其內容和「http://localhost/~[用戶名]」徹底一致。
  7. 注意,記錄log的「ErrorLog "/private/var/log/apache2/sites-error_log"」也能夠刪掉,但記錄日誌實際上是一個好習慣,在出現問題時能夠幫助咱們判斷。若是保留這些log代碼,必定log文件路徑都是存在的,若是隨便修改一個不存在的,會致使Apache沒法服務而沒有錯誤提示,這個比較噁心。

這裏利用Mac OS X 10.6.3和10.8.1中原生支持的方式來實現的配置,也能夠參考「Mac OS X Leopard: 配置Apache, PHP, SQLite, MySQL, and phpMyAdmin(一) 」和「Mac OS X Leopard: 配置Apache, PHP, SQLite, MySQL, and phpMyAdmin(二) 」。實際上,還可使用XAMPPMacPorts這種第三方提供的集成方案來實現簡單的安裝和使用。

您或許有興趣:

相關文章
相關標籤/搜索