在win10上安装Apache2.4+PHP7+MySQL5.7

2019-10-02  本文已影响0人  随忆CJ

由于想自己搭建一个网站,于是试着利用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 2.4

Apache Server是一个比较特殊的Windows软件,这个软件解压以后就可以运行。

Apache 目录

配置Apache

conf目录下,有一个重要的配置文件: httpd.conf
其中默认指定的 Apache 安装目录在‘c:/Apache24’,将其改为实际的路径,我这里放在了D:\software\Apache24,但是注意复制的路径的话,要把‘\’改为'/'。

pic0929222924.png

测试配置文件:
在Win10操作系统中,默认使用的是Windows PowerShell,它和之前经典的CMD操作指令不太一样。
可以在Apache的解压目录下,找到/bin/httpd.exe。

在/bin目录下,按下Shift+鼠标右键,可以快捷打开Windows PowerShell

Shift+鼠标右键

命令:
.\httpd -t

httpd -t

执行命令.\httpd.exe -t有相同的效果,但是前面的‘.\’不能省。

如果习惯用CMD命令行的话,需要切换目录并执行命令:
httpd -t

CMD

这里的-t是 testing,测试的意思,就是检查之前修改的配置文件httpd.conf是否有问题。看到Syntax OK,证明一切顺利。

运行Apache

运行Apache服务,执行命令:
httpd

httpd

执行以后,不会有任何反馈,光标在下一行闪动,然后最小化运行窗口。

访问浏览器http://localhost/

localhost

注册Apache

在命令行窗口,输入命令(需要使用管理员账号):
httpd -k install

注册

这里会有错误提示,暂时忽略。

在Apache的bin目录下,有一个可执行文件:
ApacheMonitor.exe

ApacheMonitor

之后的操作就不用命令行了,用这个可视化的界面操作会方便很多。

能到这一步,已经完成了一小步。

虽说我很轻松地运行起来了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-developmentphp.ini-production,很明显,一个是开发环境用,一个是生产环境用。

PHP

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

还有一个小配置,可以简化之后再浏览器中输入的地址:

DirectoryIndex
该配置指定了默认的页面,原来只有一个index.html,可以在其后追加index.php,这样在之后访问站点的时候,就可以把类似于http://localhost:80/wp-admin/index.php的地址,直接输入http://localhost/wp-admin访问。

PHP的配置文件已经被Apache接管,修改php.ini文件,需要重启Apache服务器。

再重启Apache后,用测试命令检查语法:
httpd -t

testing

对于警告Set the 'ServerName' directive globally to suppress this message,可以暂时不用管。

测试PHP代码

在Apache的htdocs目录下,新建文件index.php

inde

用记事本打开文件,放入如下PHP代码:

<?php
    echo 'hello world';
?>

在启动好Apahce后,访问http://localhost/index.php

pic1001211209.png

启动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来实施。

大致分一下几部:

  1. 创建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文件默认是不存在的,请不要自己手动创建,否则可能无法启动。

  1. 初始化mysql,执行命令:
    mysqld --initialize-insecure
    init

需要等待一段时间,没有任何输出,代表一切正常。

  1. 注册MySQL服务,安装Mysql,执行命令:
    mysqld --install mysql
    执行该命令需要管理员权限,否则会报错:
    Denied
    执行成功后,显示‘Service successfully installed.’
    install
    3.1 如果要想卸载Mysql,需要执行如下命令:
    mysqld --remove mysql
remove
  1. 启动Mysql服务,执行如下命令:
    net start mysql
    start

看到 mysql服务已经启动成功,安装就完成了。

  1. 配置root密码:
    先登录mysql服务器,使用命令:
    mysql -uroot -p
    pic1002185755.png

默认没有密码,直接回车。

切换一下数据库:use mysql;
修改root密码,使用命令:
update user set authentication_string=password('sa') where user='root';

修改密码
  1. 退出MySQL,输入命令:
    \q
    退出

如果还在mysql的命令行中,可以使用这个命令退出,或者exit退出。当然,如果嫌麻烦,可以直接关闭窗口。

  1. 关闭MySQL,输入命令:
    net stop mysql
    stop

PHP整合MySQL数据库

PHP本身是无法处理数据库的,需要通过扩展来实现。

  1. 修改php.ini配置文件
    在php.ini文件中将原来注释掉的如下片段释放(去掉最前面的分号即可):
    extension=mysqli
    添加MySQL
  2. 配置路径
    将extension_dir的值改为绝对路径(因为此时,PHP的配置文件被Apache接管,如果使用默认的ext,会找不到)
    extension_dir = "D:/software/php7.3/ext"
    extension_dir
  3. 测试配置
    在之前的index.php代码中,添加一行phpinfo();,完整代码:
<?php
    echo 'hello world';
    phpinfo();
?>
  1. 重启Apache服务后,访问http://localhost/index.php
    MySQL组件

能看到上面的内容,说明一切顺利。

安装WordPress

在wordpress官网https://wordpress.org/download/下载安装包:

wordpress

下载后得到的是一个压缩包,解压到之前Apache目录下的htdocs目录下,然后删除原来的index.html文件:


解压wordpress

在浏览器上访问http://localhost:80/index.php
页面自动调转到http://localhost/wp-admin/install.php

install
选择对应的语言:
语言选择

在MySQL中新建一个数据库:
create database wordpress DEFAULT CHARSET utf8;

创建数据库

查看一下数据库:
show databases;

数据库

在数据库设置页,填用户名root,密码之前设置的也是root,其他信息默认。

简单填写后台网站信息:


网站信息

安装成功了:


成功 主页

wordpress 配置

  1. 固定链接
    1.1 进入后管页面,设置 -> 固定链接。
    1.2 设置Apache的配置文件,<Directory "${SRVROOT}/htdocs">中的AllowOverride All.
<Directory "${SRVROOT}/htdocs">
    Options Indexes FollowSymLinks
    AllowOverride All
    Require all granted
</Directory>
上一篇下一篇

猜你喜欢

热点阅读