windows2008R2上手动搭建wnmp环境(非一键)

2016-11-09  本文已影响681人  我是你军哥

<blockquote>##首先去官方网站下载官方文件
我这里版本是

php-7.0.12-nts-Win32-VC14-x64
nginx-1.11.5
mysql-5.6.34-winx64
php下载地址:

http://windows.php.net/download#php-7.0
php我这里采用的非线性安全(VC14 x64 Non Thread Safe (2016-Nov-09 04:00:52))

nginx下载 http://nginx.org/en/download.html

(2016-10-11nginx-1.11.5 mainline version has been released.)nginx稳定版

mysql版本官网地址:http://dev.mysql.com/downloads/mysql/5.6.html#downloads

http://dev.mysql.com/downloads/file/?id=465798

台湾源下载地址:http://ftp.ntu.edu.tw/MySQL/Downloads/MySQL-5.6/

mysql这里我们下载社区服务版
下载好了之后
</blockquote>

server {
        listen       80;
        server_name  localhost;

        #charset koi8-r;

        #access_log  logs/host.access.log  main;

        location / {
            root   D:/wnmp/nginx/html/public;                    -----------nginx web地址设置
            index  index.html index.php;                             -----------添加index.php
        }

        #error_page  404              /404.html;

        # redirect server error pages to the static page /50x.html
        #
        error_page   500 502 503 504  /50x.html;
        location = /50x.html {
            root   html;
        }

        # proxy the PHP scripts to Apache listening on 127.0.0.1:80
        #
        #location ~ \.php$ {
        #    proxy_pass   http://127.0.0.1;
        #}

        # pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000
        #
        location ~ \.php$ {  
            root           D:/wnmp/nginx/html/public;
            fastcgi_pass   127.0.0.1:9000;
            fastcgi_index  index.php;
            fastcgi_param  SCRIPT_FILENAME   $document_root$fastcgi_script_name;  
            include        fastcgi_params;  
      }  
        # deny access to .htaccess files, if Apache's document root
        # concurs with nginx's one
        #
        #location ~ /\.ht {
        #    deny  all;
        #}
    }

修改php配置文件

#更改php目录下的php.ini-development,将文件名改为php.ini,进行如下配置搜索“extension_dir”
找到: e;xtension_dir = "ext" 先去前面的分号再改为 extension_dir = "D:\wnmp\php\ext"搜索“date.timezone”,
找到:;date.timezone = 先去前面的分号再改为 date.timezone = Asia/Shanghai搜索“enable_dl”,
找到:enable_dl = Off 改为 enable_dl = On搜索“cgi.force_redirect” ;cgi.force_redirect = 1 先去前面的分号再改为 cgi.force_redirect = 0搜索“fastcgi.impersonate”,
找到: ;fastcgi.impersonate = 1 去掉前面的分号搜索“cgi.rfc2616_headers”,
找到:;cgi.rfc2616_headers = 0 先去前面的分号再改为 cgi.rfc2616_headers = 1搜索“php_mysql”,
找到:”extension=php_mysql.dll和extension=php_mysqli.dll  去掉前面的“;”extension=php_mysql.dll和extension=php_mysqli.dll (支持MYSQL数据库)

然后在cmd命令行执行
D:\wnmp\php\php-cgi.exe -b 127.0.0.1:9000 -c D:\wnmp\php\php.ini
但是这样受限于php-cgi的PHP_FCGI_MAX_REQUESTS环境变量,默认处理500次后自动退出php-cgi.加之一些非正常原因的异常退出,都会导致php-cgi.exe的退出
所以我们创建一个批处理程序
新建phpcgi.vbs文件代码如下

Set objShell = CreateObject("Wscript.Shell") 
objShell.Run("tskill php-cgi"), 0, TRUE 
objShell.Run("D:\wnmp\php\php-cgi.exe -b 127.0.0.1:9000 -c D:\wnmp\php\php.ini"), 0, TRUE

在D:\wnm\nginx\html目录新建一个info.php文件。输入以下测试内容

<?php 
phpinfo();
?>

打开浏览器,输入http://127.0.0.1/info.php测试,看到php经典配置页面,则代表已调通Nginx和PHP的运行关系

打开cmd窗口,

D:
cd D:\wnmp\mysql\bin
mysqld -install

(ps:图书网上找的,我电脑已经安装,提示已经存在)


mysql.jpg

看到上图success,提示安装成功
表示mysql服务已经安装成功。

在D:\wnmpmysql目录下,复制my-default.ini为my.ini,修改my.ini文件,将[mysqld]替换为以下内容


[client]
port=3306

[mysql]
default-character-set=utf8

[mysqld]
port=3306
basedir = D:\wnmp\mysql
datadir = D:\wnmp\mysql\data
character-set-server=utf8
default-storage-engine=INNODB

sql-mode=NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION
max_connections=512

query_cache_size=0
table_cache=256
tmp_table_size=18M

thread_cache_size=8
myisam_max_sort_file_size=64G
myisam_sort_buffer_size=35M
key_buffer_size=25M
read_buffer_size=64K
read_rnd_buffer_size=256K
sort_buffer_size=256K

innodb_additional_mem_pool_size=2M

innodb_flush_log_at_trx_commit=1
innodb_log_buffer_size=1M

innodb_buffer_pool_size=47M
innodb_log_file_size=24M
innodb_thread_concurrency=8

在cmd命令行中输入“D:\wnmp\mysql\bin\mysqld.exe”启动mysql server端服务。 另开一个cmd命令行,输入“mysql -uroot -p”,密码为空,无报错表示启动成功

修改mysql默认空密码
SET PASSWORD FOR 'root'@'localhost' = PASSWORD('新密码');

在html目录下创建sql.php文件测试php连接mysql服务

#因为php7.0默认已经取消了mysql.dll所以我们采用mysqli连接数据库,进行测试
<?php
    $dbc= new mysqli("localhost","root","123456","test");
    if(!$dbc)  {
        echo"数据库链接错误!";
    }else{
        echo"success";
    }
    mysqli_close($dbc);
?>

如果报错,应该就是php的mysql扩展没有加载进来
修改php.ini文件的 extension_dir 的位置
如上wnmp环境已经安装成功

让wnmp环境随windows服务器重启自动启动

<blockquote>首先添加nginx服务为系统服务
搜索一个Windows Service Wrapper的小项目,让我们有了一个办法来恰当地启动和停止 Nginx。
首先从http://repo.jenkins-ci.org/releases/com/sun/winsw/winsw/1.19.1/winsw-1.19.1-bin.exe
将其放在 Nginx 安装目录下,并重命名为 winsw.exe

打开记事本,复制以下内容到里面,另存为:D:\wnmp\nginx\winsw.xml
</blockquote>

注意:<startargument>标签中-p路径后面不要加空格,否则在服务中启动nginx服务启动不了

<service>  
 <id>nginx</id>  
 <name>Nginx</name>  
 <description>Nginx</description>  
 <executable>D:\wnmp\nginx\nginx.exe</executable>  
 <logpath>D:\wnmp\nginx\</logpath>  
 <logmode>roll</logmode>
 <depend></depend>  
 <startargument>-pD:\wnmp\nginx</startargument>  
 <stopargument>-pD:\wnmp\nginx -s stop</stopargument>  
</service>

<blockquote>
运行cmd,输入:D:\wnmp\nginx\winsw.exe install,回车,提示安装服务完成
至此nginx服务添加到其他服务,随系统自动启动
接下来我们把之前的vbs批处理程序添加到启动项中
这里采用最简单的一种方法,单击
开始菜单——>所有程序——>启动
把vbs批处理程序copy过来,重启服务器,就发现wnmp环境随服务器启动自动运行。
转载请注明:出处,thanks!
</blockquote>

补充说明

在windows上php-cgi运行一段时间后,php-cgi会自动关闭,这时候需要开启php-cgi的守护进程

这里推荐使用xxfpm,具体下载地址,自行搜索
在** xxfpm\bin\ **目录下载执行以下cmd命令
xxfpm "D:/xnmp/php/php-cgi.exe -c D:/wnmp/php/php.ini" -n 5 -i 127.0.0.1 -p 9000

上一篇下一篇

猜你喜欢

热点阅读