目录
- 目录
- THINK
- DO
- 下载
- 安装 (安装目录:”D:\wnmp”)
- 安装NGINX
- 安装php
- 让nginx识别PHP
- 安装mysql
-
- mysql安装
- mysql设置修改初始密码
-
- 检验
- nginx
- php-cli
- mysql
- 制作自动启动脚本
- TIP
- 1. PHP常用扩展开启
- 2. nginx支持PHPINFO路由模式
-
- THINK
- DO
-
THINK
1)下载php,nginx,mysql文件
2)安装顺序 nginx,php,mysql
3)nginx解压,测试能否正常运行,[再制作自动启动脚本]
4)php解压,测试运行,让nginx能识别到php,加入环境变量,php.ini配置常规配置(eg:开启extension_dir及相关常用扩展)
5)mysql解压,测试运行,加入环境变量,修改(设置)root密码
DO
下载
- 百度云盘下载链接:
https://pan.baidu.com/s/1nzCe0Zhxq14XQllG4beXOw
- 密码:
qubc
安装 (安装目录:”D:\wnmp”)
安装NGINX
- 解压到 D:\wnmp\nginx
- 启动程序:在cmd中,进入
D:\wnmp\nginx
,输入命令start nginx
- 关闭程序:在任务管理器中结束nginx.exe任务
-
测试:启动NGINX,在浏览器中访问http://localhost,出现欢迎界面表示NGINX正常工作
-
[TODO]start.bat程序
安装php
- 解压到 D:\wnmp\php
- 测试:cmd进行到安装目录,输入
php.exe -v
,正常会显示版本信息 - 环境变量:将“D:\wnmp\php”加入环境变量
- 手动启动php-cgi:(进入D:\wnmp\php)
php-cgi.exe -b 127.0.0.1:9000 -c php.ini
- TIP:php有CLI模式(php.exe),CGI模式(php-cgi.exe)等运行方式,与nginx配合使用时需要用CGI模式运行PHP
让nginx识别PHP
- 配置nginx conf(D:\wnmp\nginx\conf\nginx.conf)
location / { root html; index index.html index.htm; } #打开下面几行注释 location ~ \.php$ { root html; fastcgi_pass 127.0.0.1:9000; fastcgi_index index.php; #重要: 把 /scripts 修改成 $document_root #fastcgi_param SCRIPT_FILENAME /scripts$fastcgi_script_name; fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name; include fastcgi_params; }
- 在
D:\wnmp\nginx-1.14.0\html
文件夹下创建phpinfo.php
文件
<?php phpinfo(); ?>
- 手动重启php-cgi.exe,nginx(参考上面)
- 访问
localhost/phpinfo.php
安装mysql
mysql安装
- 解压到
D:\wnmp\mysql
-安装(打开cmd,进入D:\wnmp\mysql)
- 移除mysql(如果之前安装过或安装失败)
mysqld -remove
- 初始化mysql(生成data文件夹)
mysqld --initialize
- 安装mysql(需要在mysql/bin目录下运行,保证net start mysql命令能够启动服务)
mysqld -install
- 移除mysql(如果之前安装过或安装失败)
- 测试:cmd进行到安装(解压)目录,输入
mysql --version
,正常会显示版本信息 - 环境变量:将
D:\wnmp\mysql\bin
加入环境变量 - 在cmd中启停mysql:启动
net start mysql
和 停止net stop mysql
mysql设置修改初始密码
- 免密登陆(以管理员身份打开一个CMD窗口,输入命令,勿关闭)
mysqld --skip-grant-tables
- 强制修改密码,账号是否失效
mysql>update user set authentication_string=password('yourpassword'),password_expired='N' where user='root';
- 正式修改密码(因为:第一次修改的密码处理过期状态)
ERROR 1820 (HY000): You must reset your password using ALTER USER statement before executing this statement.
mysql>set password for root@localhost=password('yourpassword');
检验
nginx
- localhost能访问就证明成功运行
php-cli
- 将localhost访问的主页中加入
<?php phpinfo();>
代码,能显示php信息,就证明成功运行
mysql
- 省略(同上,在主页中加入mysql连接代码,能连接上,就证明成功运行)
制作自动启动脚本
新建一个start.bat(stop.bat,restart.bat)文件,把下面的代码放到里面即可
启动:
:启动脚本 @echo off set php_home=./php_5_6_36_nts_Win32_VC11_x64 set nginx_home=./nginx_1-14_0 REM Windows 下无效 REM set PHP_FCGI_CHILDREN=5 REM 每个进程处理的最大请求数,或设置为 Windows 环境变量 set PHP_FCGI_MAX_REQUESTS=1000 echo Starting PHP FastCGI... RunHiddenConsole %php_home%/php-cgi.exe -b 127.0.0.1:9000 -c %php_home%/php.ini echo FastCGI 启动成功 echo. echo Starting nginx... RunHiddenConsole %nginx_home%/nginx.exe -p %nginx_home% echo nginx 启动成功 echo. :echo 15秒后自动退出 :ping 0.0.0.0 -n 15 > null :请按任意键继续. . . pause
停止:
:停止脚本 @echo off echo Stopping nginx... taskkill /F /IM nginx.exe > nul echo nginx 已停止 :换行 echo. echo Stopping PHP FastCGI... taskkill /F /IM php-cgi.exe > nul echo FastCGI 已停止 :请按任意键继续. . . pause
重启(就是把停止启动合在一起):
:停止脚本 @echo off echo Stopping nginx... taskkill /F /IM nginx.exe > nul echo nginx 已停止 :换行 echo. echo Stopping PHP FastCGI... taskkill /F /IM php-cgi.exe > nul echo FastCGI 已停止 echo. :启动脚本 @echo off set php_home=./php_5_6_36_nts_Win32_VC11_x64 set nginx_home=./nginx_1-14_0 REM Windows 下无效 REM set PHP_FCGI_CHILDREN=5 REM 每个进程处理的最大请求数,或设置为 Windows 环境变量 set PHP_FCGI_MAX_REQUESTS=1000 echo Starting PHP FastCGI... RunHiddenConsole %php_home%/php-cgi.exe -b 127.0.0.1:9000 -c %php_home%/php.ini echo FastCGI 启动成功 echo. echo Starting nginx... RunHiddenConsole %nginx_home%/nginx.exe -p %nginx_home% echo nginx 启动成功 echo. :echo 15秒后自动退出 :ping 0.0.0.0 -n 15 > null :请按任意键继续. . . pause
TIP
1. PHP常用扩展开启
extension_dir = "D:\wnmp\php_5_6_36_nts_Win32_VC11_x64\ext" extension=php_gd2.dll extension=php_mysql.dll extension=php_mysqli.dll extension=php_pdo_mysql.dll extension=php_redis.dll extension=php_mbstring.dl ;自己按需要添加...
2. nginx支持PHPINFO路由模式
THINK
-
原理:
- URL1:http://www.xsphp.com/index.php?s=index/handle/route;(模块:index,控制器:handle,方法:route)
- URL2:http://www.xsphp.com/index/handle/route
- URL2解释路由的方法叫PATHINFO
-
目的:
- 让nginx将URL2转换成URL1
- 让nginx将
/index/handle/route
的值传传递给PHP中的变量$_SERVER['PATH_INFO']
- 完成上面2步,开发环境就能支持PATHINFO路由模式了
DO
## xsphp.com server { listen 80; server_name xsphp.com; root E:/www/xsphp_com/public; location / { autoindex on; if (-f $request_filename){ break; } if (!-e $request_filename){ rewrite ^(.*)$ /index.php/$1 last; } index index.php index.html; } #location ~ \.php$ {} tip:$符号不能存在,小坑,注意即可。 location ~ \.php { #root E:\www\xsphp_com\public; tip:win下不区别 “\” “/” root E:/www/xsphp_com/public; index index.php; fastcgi_pass 127.0.0.1:9000; ##nginx的0.7.31以上版本 增加 fastcgi_split_path_info指令,将URI匹配成PHP脚本的URI和pathinfo两个变量 ##即$fastcgi_script_name 和$fastcgi_path_info fastcgi_split_path_info ^(.+\.php)(.*)$; ##PHP中要能读取到pathinfo这个变量 ##就要通过fastcgi_param指令将fastcgi_split_path_info指令匹配到的pathinfo部分赋值给PATH_INFO ##这样PHP中$_SERVER['PATH_INFO']才会存在值 fastcgi_param PATH_INFO $fastcgi_path_info; fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name; include fastcgi_params; } }
参考:Nginx支持PHP的PATHINFO模式配置分析 - 晶晶的博客