开业于2004年,诚信服务几万客户
翔意数码淘宝店:xynbnb.taobao.com
全国客服电话:010-59000667
地址:北京东城区东兴隆街56号北京商界A座512
ThinkPad产品专业客服 苹果产品专业客服
查看: 5252|回复: 3

[原创]Mac OS X 系统配置 Apache+MySql+PHP 详细教程

[复制链接]
发表于 2013-12-20 13:37 | 显示全部楼层 |阅读模式
如果你是一名 Web 开发者,很多时候都需要在本地搭建服务器测试环境,比如 Apache+MySql+PHP 这样的环境。

事实上 Mac OS X 中想要搭建这样的环境很简单,接下来就会将详细的教程分享给大家。

首先需要说明的是,Mac OS X 系统其实已经集成了 Apache + PHP 环境,用户手动开启即可。不过在最近的的 10.8/10.9 中苹果取消了这个共享功能的图形界面,只能从命令行开启。

1.启用 Apache/Web 共享

打开终端,运行启动 Apache 命令:
sudo apachectl start

随后要求输入系统密码,这个密码输入的过程中是看到不显示的,输入完成后直接回车即可

20f88d13632762d089d58ccfa2ec08fa503dc6ef.jpg.png



关闭命令:
sudo apachectl stop
重启命令:
sudo apachectl restart
查看 Apache 版本命令:
httpd -v

10.9中集成了如下 Apache 版本
Server version: Apache/2.2.24 (Unix)
Server built: Aug 24 2013 21:10:43


b006b41bb051f819dbfd2b3ad8b44aed2f73e7fe.jpg.png



启用 Apache 之后,你可以直接在浏览器中访问 http://localhost,如果出现”It works!”就表示运行正常。

1a07b77eca806538b6388c6395dda144ac348280.jpg.png



2.Root 目录

启用 Apache 之后,你首先得知道网页文件应该放到哪个目录才能正常运行,相信有过 Linux 服务器配置经验的对此不会陌生。Mac OS X 中默认有两个目录可以直接运行你的 Web 程序,一个是系统级的 Web 根目录,一个是用户级的根目录,大家记下即可。

系统级的根目录是:
/Library/WebServer/Documents/
它对应的网址是:
http://localhost

用户级的根目录是:
~/Sites

这里需要注意的~/Sites 也就是你用户目录下面的”站点”目录,在 OS X 10.8/10.9 中,这个目录可能没有,所以你需要手动建立一个同名目录。建立方式很简单,直接在终端中运行:

sudo mkdir ~/Sites

1e1e374e251f95cad69187c6cb177f3e67095269.jpg.png





245fd61373f082026405844f49fbfbedab641b3a.jpg.png


建立”站点”文件夹之后,检查下面这个文件夹下面是不是有”你的用户名.conf”这个文件。

/etc/apache2/users/
如果没有,那么你需要创建一个,取名为”你的用户名.conf”,你可以使用 vi 或者 nano 这两种编辑器之一来创建。

sudo nano /etc/apache2/users/你的用户名.conf

b33d2af5e0fe992554817c2036a85edf8cb171c1.jpg.png


创建之后将下面的这几行内容写到上面的 conf 文件中:

<Directory "/Users/username/Sites/">
Options Indexes MultiViews
AllowOverride All
Order allow,deny
Allow from all
</Directory>

(请将username改成你的用户名)

0e15a68b87d6277ffbd827482a381f30e824fc88.jpg.png


文件保存之后,给它赋予相应的权限:

sudo chmod 755 /etc/apache2/users/你的用户名.conf

最后运行

sudo chown root:wheel /etc/apache2/users/你的用户名.conf

完成后重启 Apache

0e80a3c27d1ed21b2fc23a95af6eddc451da3f4e.jpg.png



此时CMD+SHIFT+A,找到你的用户名下的Sites,CMD+I,修改权限




最后将 /Library/WebServer/Documents/index.html.en 复制到 Sites 下面
接下来重启 Apache,以使该配置文件生效:
sudo apachectl restart

之后你就可以通过浏览器访问你的用户级目录网页了,你可以随便防个网页进去测试一下。根目录地址为:
http://localhost/~username/

(请将username改成你的用户名)

311a7cec54e736d1e1219b7899504fc2d56269a0.jpg.png


3.启用 PHP
Mac OS 中已经集成了 PHP 5.3.13 版本,也需要手动开启。你可以用 vi 或者 nano 编辑器打开下面这个文件:
sudo nano /etc/apache2/httpd.conf

然后搜索”php”,第一条匹配的应该是下面这句代码:
LoadModule php5_module libexec/apache2/libphp5.so

8341b419ebc4b74509eaa066cdfc1e178a821553.jpg.png



请将这句代码前面的#去掉,然后保存文件。
接下来再一次重启 Apache:
sudo apachectl restart

现在 PHP 应该已经开始工作了,你可以在用户级根目录下(~/Sites/)放一个PHP测试文件,代码如下:
<?php phpinfo(); ?>

4.安装 MySQL
Mac OS 中并没有集成 MySql,需要手动安装。点击这个链接下载 MySQL 的安装包

http://pan.baidu.com/s/1krElO 密码i0ls

下载完DMG之后,双击你会提取出三个文件和一个 RedMe.txt 文档。这三个文件分别是:
a.mysql5.5.xxx.pkg
b.MySQLstartupitem.pkg
c.MySQLPrefPane

fb1a0bf3d7ca7bcb85c6d05fbc096b63f624a811.jpg.png



bfc7d239b6003af39213ca10372ac65c1038b62d.jpg.png



75179545d688d43f9c0387827f1ed21b0ef43b2f.jpg.png



bc3ec15c10385343550d91519113b07ecb808890.jpg.png



现在去设置系统偏好设置——安全性与隐私——通用中改成可打开”任何来源”的应用程序

随后逐一安装这三个文件

三个文件都安装完成之后,进入「系统偏好设置」,在面板的最下面你会看到一个 MySQL 的设置项,点击它之后就可以启动MySQL,或者你也可以通过下面的命令开启:

e436484a20a446238ff4b4129a22720e0cf3d79c.jpg.png


sudo /usr/local/mysql/support-files/mysql.server start

如果你想查看 MySQL 的版本,可以用下面这个命令:
/usr/local/mysql/bin/mysql -v

运行上面这个命令之后,会直接从命令行中登录到 MySQL,输入命令 \q 即可退出。

到这里 MySQL 已经配置完成,并且可以运行。但为了更加方便使用,你最好再设置一下系统环境变量,也就是让 mysql 这个命令在任何路径都可以直接启动(不需要输入一长串的准确路径)。

设置环境变量也很方便,直接用命令(这里笔者用 nano 编辑器举例):
cd ; nano .bash_profile

0c21e2dde71190efa3c183afcc1b9d16fdfa6098.jpg.png



将下面的这句代码贴进去:
export PATH="/usr/local/mysql/bin:$PATH"


e94d222dd42a2834aa0d277b59b5c9ea15cebf2f.jpg.png



然后按 Ctrl+O 回车保存,Ctrl+X 退出编辑器。当然你如果使用 vi 或者别的编辑器的话,操作方式跟这个可能不一样,反正意思就是将上面那句话写入到 .bash_profile 文件中。
接下来还要重新加载一下 Shell 以让上面的环境变量生效:
source ~/.bash_profile

f0250d55b319ebc4f0dc67e98026cffc1e171629.jpg.png



之后你就可以在终端的任意目录使用 MySql 命令了,你可以运行 mysql -v 试试。

b8b9ccef76094b3613ba0b9da1cc7cd98d109dae.jpg.png



最后一步,你还应该给你的 MySQL 设置一个 root 用户密码,命令如下:
mysqladmin -u root password '这里填你要设置的密码'
(请记住密码一定要用半角单引号包起来)

上面的 mysqladmin 命令,我没有写完整路径。因为上面我们已经设置了环境变量,如果你没有设置环境变量的话,就需要用/usr/local/mysql/bin/mysqladmin ******** 来运行。

5.安装 phpMyAdmin

在安装 phpMyAdmin 之前,请首先修复 2002 socket 错误:
sudo mkdir /var/mysql
sudo ln -s /tmp/mysql.sock /var/mysql/mysql.sock

580774f082025aaf9e156ebbf9edab64034f1aaa.jpg.png



然后去 phpMyAdmin 网站下载安装包,链接如下
http://pan.baidu.com/s/1mt4EV 密码:8enq

7bc7502c11dfa9ecf939466760d0f703918fc1bb.jpg.png



解压之后,将解压出来的文件夹改名为”phpMyAdmin”,并放到上面建立的”站点”目录下(~/Sites)。

59b60bf431adcbefcb726e76aeaf2edda3cc9f14.jpg.png



然后在 phpmyadmin 下建立一个 config 文件夹:
mkdir ~/Sites/phpmyadmin/config

183790dda144ad34ee7597f7d2a20cf430ad8588.jpg.png


修改权限:
chmod o+w ~/Sites/phpmyadmin/config

091e1ed8bc3eb135c53aa5cba41ea8d3fc1f44d1.jpg.png


之后就可以从浏览器中访问phpmyadmin的初始设置页面了:
http://localhost/~username/phpmyadmin/setup/
(请将 username 修改成你的用户名)

20f88d13632762d0843ab9cfa2ec08fa513dc64a.jpg.png


打开页面之后,基本上不需要配置。
进去之后点击”New server”,在 Basic settings 页面确保 Serverhostnamelocalhost,在 Authentication 配置好登陆用户名和密码(之前设置的 root 密码),点击保存就可以了。

3ba3d7a20cf431ad7cfb5c494936acaf2edd98ad.jpg.png



phpMyAdmin配置完成之后,上面建立的 /config 目录中会出现一个 config.inc.php 文件,将这个文件移到 phpMyAdmin 根目录(上一级),然后删除这个空的 /config 目录。

到这里就算完成了,接下来你就可以访问
http://localhost/~username/phpmyadmin/ (将username替换成你的用户名)

来通过 phpMySql 管理你的数据库了。

d0fa3a6d55fbb2fb3fff44624d4a20a44723dcfa.jpg.png


1b51d188d43f8794b117575ed01b0ef41ad53aed.jpg.png


6e0597ef76c6a7ef1fceb756fffaaf51f2de66ee.jpg.png



以上便是在 Mac OS X 上配置 Apache+Mysql+Php 的完整教程。如果大家有任何不明白的地方,请在下面提问。

c820900a304e251f6ee1fa88a586c9177f3e5344.jpg.png
发表于 2014-6-9 08:13 | 显示全部楼层
开发教程了哇
发表于 2014-7-28 15:53 | 显示全部楼层
本帖最后由 wuxeek_slogan 于 2014-7-28 15:57 编辑

LZ说的   屏幕快照 2014-07-28 下午3.44.25.png
     运行   sudo chown root:wheel /etc/apache2/users/你的用户名.conf  之后出现了 屏幕快照 2014-07-28 下午3.49.47.png


cmd+shift+A没有反应唉    请问LZ应该怎么办  今天配置个环境头都晕了。。。。

点评

cmd+shift+A 是Finder下的操作,找到你的Site  发表于 2014-7-30 10:44
发表于 2015-5-23 12:34 | 显示全部楼层
真精神!!!!!!
您需要登录后才可以回帖 登录 | 加入

本版积分规则

返回顶部