mac中apache+mysql+php+phpMyAdmin配置备忘

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下的安装说明算法

  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 Passwordsql

注意: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”便可。macos

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

mysql.default_socket = /tmp/mysql.sock

使用phpMyAdmin

phpMyAdmin是用PHP开发的管理MySQL的程序,很是的流行和实用。可以使用phpMyAdmin管理MySQL是检验前面几步效果的很是有效方式。xcode

  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下的安装却不那么友善,具体以下:浏览器

  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这种第三方提供的集成方案来实现简单的安装和使用。

相关文章
相关标签/搜索