win安装nginx php mysql_WIN10下安装 NGINX+PHP+MYSQL(WNMP) 环境

本文详细介绍了如何在Windows 10系统下安装和配置WNMP(Nginx, PHP, MySQL)环境。包括从百度云盘下载所需软件,逐一安装Nginx、PHP和MySQL,配置Nginx以识别PHP,修改MySQL的初始密码,以及创建自动启动脚本。" 122373042,10739092,Java JDBC操作MySQL数据库实战,"['数据库', 'mysql', 'java', 'JDBC', 'Web项目']
摘要由CSDN通过智能技术生成

目录

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-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

测试: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

目的:

让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;

}

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值