在Mac OS X中配置Apache+PHP+MySQL运行环境的详细步骤
这是一篇超级详细的配置macos下面php+mysql+apache的文章。非常详细
我的大部分配置就是参考上面的内容的,比如,PHP不能连接数据库,就是改一下默认的php.ini中pdo_mysql.default_socket【因为现在都用PDO了嘛。不用mysql的连接库了】
因为我是用navicat的,所以对phpmyadmin那一块的配置就不太关心了。不过MCrypt的安装可以参考。
MacOSX内置了Apache和PHP,这样使用起来非常方便。本文以MacOSX10.6.3为例。主要内容包括:
启动Apache
运行PHP
安装MySQL
使用phpMyAdmin
配置PHP的MCrypt扩展库
设置虚拟主机
启动Apache
有两种方法:
打开“系统设置偏好(SystemPreferences)”->“共享(Sharing)”->“Web共享(WebSharing)”
打开“终端(terminal)”,然后(注意:sudo需要的密码就是系统的root帐号密码)
运行“sudoapachectlstart”,再输入帐号密码,这样Apache就运行了。
运行“sudoapachectl-v”,你会看到MacOSX10.6.3中的Apache版本号:
Serverversion:Apache/2.2.14(Unix)Serverbuilt:Feb11201014:40:31
这样在浏览器中输入“http://localhost”,就可以看到出现一个内容为“Itworks!”的页面,它位于“/Library(资源库)/WebServer/Documents/”下,这是Apache的默认根目录。
注意:开启了Apache就是开启了“Web共享”,这时联网的用户就会通过“http://[本地IP]/”来访问“/Library(资源库)/WebServer/Documents/”目录,通过“http://[本地IP]/~[用户名]”来访问“/Users/[用户名]/Sites/”目录,可以通过设置“系统偏好设置”的“安全(Security)”中的“防火墙(Firewall)”来禁止这种访问。
运行PHP
在终端中运行“sudovi/etc/apache2/httpd.conf”,打开Apache的配置文件。(如果不习惯操作终端和vi的可以设置在Finder中显示所有的系统隐藏文件,记得需要重启Finder,这样就可以找到对应文件,随心所欲编辑了,但需要注意的是某些文件的修改需要开启root帐号,但整体上还是在终端上使用sudo来临时获取root权限比较安全。)
找到“#LoadModulephp5_modulelibexec/apache2/libphp5.so”,把前面的#号去掉,保存(在命令行输入:w)并退出vi(在命令行输入:q)。
运行“sudocp/etc/php.ini.default/etc/php.ini”,这样就可以通过php.ini来配置各种PHP功能了。比如:
;通过下面两项来调整PHP提交文件的最大值,比如phpMyAdmin中导入数据的最大值upload_max_filesize=2Mpost_max_size=8M;比如通过display_errors来控制是否显示PHP程序的报错display_errors=Off
运行“sudoapachectlrestart”,重启Apache,这样PHP就可以用了。
运行“cp/Library/WebServer/Documents/index.html.en/Library/WebServer/Documents/info.php”,即在Apache的根目录下复制index.html.en文件并重命名为info.php
在终端中运行“vi/Library/WebServer/Document/info.php”,这样就可以在vi中编辑info.php文件了。在“It'sworks!”后面加上“”,然后保存之。这样就可以在http://localhost/info.php中看到有关PHP的信息,比如版本号是5.3.1。
安装MySQL
由于MacOSX中并没有预装MySQL,所以需要自己手动安装,目前MySQL的最稳定版本是5.1。MySQL提供了MacOSX下的安装说明。
下载MySQL5.1。选择合适的版本,比如这里选择的是mysql-5.1.46-osx10.6-x86_64.dmg。
运行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”中。一路默认安装完毕即可。
点击安装第2个文件MySQLStartupItem.pkg,这样MySQL就会自动在开机时自动启动了。
点击安装第3个文件MySQL.prefPane,这样就会在“系统设置偏好”中看到名为“MySQL”的ICON,通过它就可以设置MySQL开始还是停止,以及是否开机时自动运行。到这里MySQL就基本安装完毕了。
通过运行“sudovi/etc/bashrc”,在bash的配置文件中加入mysql和mysqladmin的别名
#mysqlaliasmysql='/usr/local/mysql/bin/mysql'aliasmysqladmin='/usr/local/mysql/bin/mysqladmin'
这样就可以在终端中比较简单地通过命令进行相应的操作,比如安装完毕之后MySQL的root默认密码为空,如果要设置密码可以在终端运行“mysqladmin-urootpassword"mysqlpassword"”来设置,其中mysqlpassword即root的密码。更多相关内容可以参考B.5.4.1.HowtoResettheRootPassword。
注意:MacOSX的升级或者其他原因可能会导致MySQL启动或者开机自动运行,在MySQL的操作面板上会提示“Warning:The/usr/local/mysql/datadirectoryisnotownedbythe'mysql'or'_mysql'”,或者在命令行下提示“Can'tconnecttolocalMySQLserverthroughsocket'/tmp/mysql.sock'(2)”,这应该是某种情况下导致/usr/local/mysql/data的宿主发生了改变,只需要运行“sudochown-Rmysql/usr/local/mysql/data”即可。
另外,使用PHP连接MySQL可能会报错“Can'tconnecttolocalMySQLserverthroughsocket‘/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.3.2-all-languages.tar.bz2这个版本。
把“下载(downloads)”中的phpMyAdmin-3.32-all-languages文件夹复制到“/Users/[用户名]/Sites”中,名改名为phpmyadmin。
复制“/Users/[用户名]/Sites/phpmyadmin/”中的config.sample.inc.php,并命名为config.inc.php
打开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;
这样就可以通过http://localhost/~[用户名]/phpmyadmin访问phpMyAdmin了。这个时候就看到一个提示“无法加载mcrypt扩展,请检查您的PHP配置。”,这就涉及到下一节安装MCrypt扩展了。
配置PHP的MCrypt扩展
MCrypt是一个功能强大的加密算法扩展库,它包括有22种算法,phpMyAdmin依赖这个PHP扩展库。但是它在MacOSX下的安装却不那么友善,具体如下:
下载并解压libmcrypt-2.5.8.tar.bz2。
在终端执行如下命令(注意如下命令需要安装xcode支持):
cd~/Downloads/libmcrypt-2.5.8/ ./configure--disable-posix-threads--enable-static make sudomakeinstall
下载并解压PHP源码文件php-5.3.1.tar.bz2。MacOSX10.6.3中预装的PHP版本是5.3.1,而现在最新的PHP版本是5.3.2,你需要依据自己的实际情况选择对应的版本。
在终端执行如下命令:
cd~/Downloads/php-5.3.1/ext/mcrypt phpize ./configure make cdmodules sudocpmcrypt.so/usr/lib/php/extensions/no-debug-non-zts-20090626/ 打开php.ini sudovi/etc/php.ini
在php.ini中加入如下代码,并保存后退出,然后重启Apache
extension=/usr/lib/php/extensions/no-debug-non-zts-20090626/mcrypt.so
当你再访问http://localhost/~[用户名]/phpmyadmin时,你会发现“无法加载mcrypt扩展,请检查您的PHP配置。”的提示没有了,这就表示MCrypt扩展库安装成功了。
设置虚拟主机
在终端运行“sudovi/etc/apache2/httpd.conf”,打开Apche的配置文件
在httpd.conf中找到“#Include/private/etc/apache2/extra/httpd-vhosts.conf”,去掉前面的“#”,保存并退出。
运行“sudoapachectlrestart”,重启Apache后就开启了它的虚拟主机配置功能。
运行“sudovi/etc/apache2/extra/httpd-vhosts.conf”,这样就打开了配置虚拟主机的文件httpd-vhost.conf,配置你需要的虚拟主机了。需要注意的是该文件默认开启了两个作为例子的虚拟主机:
ServerAdminwebmaster@dummy-host.example.com DocumentRoot"/usr/docs/dummy-host.example.com" ServerNamedummy-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 ServerAdminwebmaster@dummy-host2.example.com DocumentRoot"/usr/docs/dummy-host2.example.com" ServerNamedummy-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
而实际上,这两个虚拟主机是不存在的,在没有配置任何其他虚拟主机时,可能会导致访问localhost时出现如下提示:
ForbiddenYoudon'thavepermissiontoaccess/index.phponthisserver
最简单的办法就是在它们每行前面加上#,注释掉就好了,这样既能参考又不导致其他问题。
增加如下配置
DocumentRoot"/Users/[用户名]/Sites" ServerNamesites ErrorLog"/private/var/log/apache2/sites-error_log" CustomLog"/private/var/log/apache2/sites-access_log"common
保存退出,并重启Apache。
运行“sudovi/etc/hosts”,打开hosts配置文件,加入”127.0.0.1sites“,这样就可以配置完成sites虚拟主机了,这样就可以用“http://sites”访问了,其内容和“http://localhost/~[用户名]”完全一致。
这是利用MacOSX10.6.3中原生支持的方式来实现的配置,也可以参考“MacOSXLeopard:配置Apache,PHP,SQLite,MySQL,andphpMyAdmin(一)”和“MacOSXLeopard:配置Apache,PHP,SQLite,MySQL,andphpMyAdmin(二)”。实际上,你还可以使用XAMPP或MacPorts这种第三方提供的集成方案来实现简单的安装和使用。