在win10上安装Apache2.4+PHP7+MySQL5.7
由于想自己搭建一个网站,于是试着利用wordpress先实验一下。作为一个程序员,对wordpress的改造是必须的,在软件选择上,也采用了独立安装的方式,并没有采用WAMP
或者XAMPP
。
安装Apache
下载Apache
在Apache的官网下载Apache的 Windows 版本软件包
https://httpd.apache.org/download.cgi
Windows版本有独立的网页 https://httpd.apache.org/docs/current/platform/windows.html#down
Windows版本目前,有多个版本可以选择,我这里选择的是Apache Lounge
,大小大约10M
Apache Server是一个比较特殊的Windows软件,这个软件解压以后就可以运行。
Apache 目录配置Apache
在conf
目录下,有一个重要的配置文件: httpd.conf
其中默认指定的 Apache 安装目录在‘c:/Apache24’,将其改为实际的路径,我这里放在了D:\software\Apache24
,但是注意复制的路径的话,要把‘\’改为'/'。
测试配置文件:
在Win10操作系统中,默认使用的是Windows PowerShell
,它和之前经典的CMD操作指令不太一样。
可以在Apache的解压目录下,找到/bin/httpd.exe。
Shift+鼠标右键在/bin目录下,按下Shift+鼠标右键,可以快捷打开
Windows PowerShell
命令:
.\httpd -t
执行命令
.\httpd.exe -t
有相同的效果,但是前面的‘.\’不能省。
如果习惯用CMD命令行的话,需要切换目录并执行命令:
httpd -t
这里的
-t
是 testing,测试的意思,就是检查之前修改的配置文件httpd.conf
是否有问题。看到Syntax OK
,证明一切顺利。
运行Apache
运行Apache服务,执行命令:
httpd
执行以后,不会有任何反馈,光标在下一行闪动,然后最小化运行窗口。
访问浏览器http://localhost/
localhost注册Apache
在命令行窗口,输入命令(需要使用管理员账号):
httpd -k install
这里会有错误提示,暂时忽略。
在Apache的bin目录下,有一个可执行文件:
ApacheMonitor.exe
之后的操作就不用命令行了,用这个可视化的界面操作会方便很多。
能到这一步,已经完成了一小步。
虽说我很轻松地运行起来了Apache服务器,其实有些情况并没有那么顺利,Apache需要VC++运行库,而默认情况下,Win10并没有安装,可能会出现各种缺少dll文件,此时应该考虑安装微软常用运行库合集
。
比如说我下载的Apache安装包名称为httpd-2.4.41-win64-VS16.zip
,就先安装需要Microsoft Visual C++ 2015-2019
组件。
安装PHP7
下载PHP
先在PHP的下载首页找到自己需要的版本https://www.php.net/downloads.php
对于Window版本,也有特殊的地址:
Win在Windows版本下,也提供了两个选择:
VC15 x64 Non Thread Safe
非线程安全,在执行时不进行线程(thread)安全检查。这种是为了在单线程环境下,提升访问性能,是为在IIS环境下运行提供的一种方式,IIS是Windows自带的服务器解决方案。
VC15 x64 Thread Safe
线程安全,执行时会进行线程(thread)安全检查。采用Apache运行PHP时,选择该版本。
配置PHP
PHP是一个不需要安装的软件,直接解压开以后,就可以使用。
解压后,我将其重命名为php7.3
PHP
在PHP的解压后,可以看到有两个配置文件,php.ini-development
和php.ini-production
,很明显,一个是开发环境用,一个是生产环境用。
Apache加载PHP
现在需要把Apache和PHP关联起来,在之前解压的PHP中有一个文件php7apache2_4.dll
,用来绑定Apache和PHP。
在Apache的配置文件httpd.conf
中添加如下:
LoadModule php7_module 'D:/software/php7.3/php7apache2_4.dll'
然后还需要一步,让Apache识别PHP代码文件(通过.php文件名后缀识别):
AddType application/x-httpd-php .php
之后还需要将PHP的配置文件交给Apache管理:
PHPIniDir 'D:/software/php7.3'
PHP的配置文件为php.ini,这个文件默认是不存在的,在php的压缩包中,我复制一个php.ini-development
,并命名为php.ini
。
完整的配置项:
LoadModule php7_module 'D:/software/php7.3/php7apache2_4.dll'
AddType application/x-httpd-php .php
PHPIniDir 'D:/software/php7.3'
配置效果:
Config
还有一个小配置,可以简化之后再浏览器中输入的地址:
该配置指定了默认的页面,原来只有一个index.html,可以在其后追加index.php,这样在之后访问站点的时候,就可以把类似于
http://localhost:80/wp-admin/index.php
的地址,直接输入http://localhost/wp-admin访问。
PHP的配置文件已经被Apache接管,修改php.ini文件,需要重启Apache服务器。
再重启Apache后,用测试命令检查语法:
httpd -t
对于警告Set the 'ServerName' directive globally to suppress this message
,可以暂时不用管。
测试PHP代码
在Apache的htdocs目录下,新建文件index.php
:
用记事本打开文件,放入如下PHP代码:
<?php
echo 'hello world';
?>
在启动好Apahce后,访问http://localhost/index.php
:
启动Apache,只需要在Apache的bin目录下执行
httpd
如果看到的是PHP的源代码,那一定是之前的整合步骤出错了。
安装MySQL
在Win下,MySQL有两种安装方式,一种是软件安装,对应的安装包后缀名为.msi
,傻瓜安装方式,缺点是安装需要的步骤多,安装在Win中会作为服务,但是不需要什么命令,非程序员的首选。
我选择的是免安装版,在MySQL的下载页面https://dev.mysql.com/downloads/mysql/ 找到后缀名为.zip的包。
pic1001212314.png选择这个版本,需要一定的手工操作,初始化时需要执行一些命令,可以参照这个https://www.cnblogs.com/zhaoyanhaoBlog/p/11120467.html来实施。
大致分一下几部:
- 创建
my.ini
文件.
其中my.ini
文件内容:
[mysql]
default-character-set=utf8
[mysqld]
basedir = D:\\software\mysql5.7
datadir = D:\\software\mysql5.7\data
port = 3306
default-time-zone='+08:00'
上面的datadir文件默认是不存在的,请不要自己手动创建,否则可能无法启动。
- 初始化mysql,执行命令:
mysqld --initialize-insecure
init
需要等待一段时间,没有任何输出,代表一切正常。
- 注册MySQL服务,安装Mysql,执行命令:
mysqld --install mysql
执行该命令需要管理员权限,否则会报错:
Denied
执行成功后,显示‘Service successfully installed.’
install
3.1 如果要想卸载Mysql,需要执行如下命令:
mysqld --remove mysql
- 启动Mysql服务,执行如下命令:
net start mysql
start
看到 mysql服务已经启动成功,安装就完成了。
- 配置root密码:
先登录mysql服务器,使用命令:
mysql -uroot -p
pic1002185755.png
默认没有密码,直接回车。
切换一下数据库:use mysql;
修改root密码,使用命令:
update user set authentication_string=password('sa') where user='root';
- 退出MySQL,输入命令:
\q
退出
如果还在mysql的命令行中,可以使用这个命令退出,或者exit退出。当然,如果嫌麻烦,可以直接关闭窗口。
- 关闭MySQL,输入命令:
net stop mysql
stop
PHP整合MySQL数据库
PHP本身是无法处理数据库的,需要通过扩展来实现。
- 修改php.ini配置文件
在php.ini文件中将原来注释掉的如下片段释放(去掉最前面的分号即可):
extension=mysqli
添加MySQL - 配置路径
将extension_dir的值改为绝对路径(因为此时,PHP的配置文件被Apache接管,如果使用默认的ext,会找不到)
extension_dir = "D:/software/php7.3/ext"
extension_dir - 测试配置
在之前的index.php
代码中,添加一行phpinfo();
,完整代码:
<?php
echo 'hello world';
phpinfo();
?>
- 重启Apache服务后,访问http://localhost/index.php
MySQL组件
能看到上面的内容,说明一切顺利。
安装WordPress
在wordpress官网https://wordpress.org/download/下载安装包:
下载后得到的是一个压缩包,解压到之前Apache目录下的htdocs目录下,然后删除原来的index.html文件:
解压wordpress
在浏览器上访问http://localhost:80/index.php。
页面自动调转到http://localhost/wp-admin/install.php
选择对应的语言:
语言选择
在MySQL中新建一个数据库:
create database wordpress DEFAULT CHARSET utf8;
查看一下数据库:
show databases;
在数据库设置页,填用户名root,密码之前设置的也是root,其他信息默认。
简单填写后台网站信息:
网站信息
安装成功了:
成功 主页
wordpress 配置
- 固定链接
1.1 进入后管页面,设置 -> 固定链接。
1.2 设置Apache的配置文件,<Directory "${SRVROOT}/htdocs">
中的AllowOverride All
.
<Directory "${SRVROOT}/htdocs">
Options Indexes FollowSymLinks
AllowOverride All
Require all granted
</Directory>