您的位置:首页 > 编程语言 > PHP开发

IIS部署PHP项目并与mysql完美结合

2017-08-25 16:30 435 查看
在上一篇文章中,提到iis与apache共用80端口,但是发现很多问题,例如 IIS网站有支付功能,而微信支付是不支持带有端口的网址的,虽然通过apche代理,在外面看来没有端口,可是内部还是避免不了,所以还是要放弃上一篇使 用的方法

网络上也有很多其他的共用80端口的方法,比如 设置 iis的ip地址与apche的IP地址,并进行绑定,可是感觉毕竟不是最终解决的办法,网络搜罗的办法在此也贴出来

方法一:

IIS5,多IP下共存,IIS为192.168.0.1,apache为192.168.0.2

c:\Inetpub\Adminscripts

cscript adsutil.vbs set w3svc/disablesocketpooling true

该命令反馈如下disablesocketpooling : (BOOLEAN) True

重启IIS

Inetpub\AdminScripts>cscript adsutil.vbs set w3svc/disablesocketpooling true

由于 DisableSocketPooling 在 IIS 6.0 元数据库架构 (MBSchema.xml) 中被定义为有效属性,所以,您仍然可以使用 Adsutil.vbs 设置该属性,但这种设置不起作用。IIS 6.0 中的功能是新增的核心级别驱动程序 HTTP.sys 的一部分。要配置 HTTP.sys,您必须使用 Httpcfg.exe

方法二:

IIS6,多IP下共存,IIS为192.168.0.1,apache为192.168.0.2

到2003的CD下的 support/tools/Support.cab。解压出httpcfg.exe文件,COPY到windows/system32/目录下,用法自己看帮助

命令行

绑定到某IP: httpcfg set iplisten -i 192.168.0.1

即命令使用IIS的只监听指定的IP及端口

查看绑定: httpcfg query iplisten

删除绑定: httpcfg delete iplisten -i 192.168.0.1

命令行

net stop Apache2

net stop iisadmin /y

net START Apache2

net START w3svc

保证iis下的ip设置为全局默认,Apache中httpconf设置listen 192.168.0.2:80,就应该可以两个服务同时运行,相互不冲突了。

IIS的访问地址为http://192.168.0.1,Apache访问地址为http://192.168.0.2

提醒:IIS要指定为IP地址192.168.0.1 端口80;Apache 设置listen 192.168.0.2:80。关键是IIS用httpcfg命令绑定后,要重启系统,仅仅重启服务是不行的。

方法三:

将apache设为使用80端口,IIS使用其它端口,比如81,然后将apache作为IIS的代理。

在httpd.conf里面,取消下面四行的注释:

LoadModule proxy_module modules/mod_proxy.so

LoadModule proxy_connect_module modules/mod_proxy_connect.so

LoadModule proxy_http_module modules/mod_proxy_http.so

LoadModule proxy_ftp_module modules/mod_proxy_ftp.so

然后建立一个虚拟主机,将该域名的所有访问转向81端口。

ServerName iloves.vicp.net

ProxyPass / http://localhost:81/
ProxyPassReverse / http://localhost:81/
这样,对外就可以只需要一个端口,即可同时使用apache和IIS的功能了

方法四:

网上常用的单IP共用80端口方法,不过不推荐,只是使用Apache的代理,速度有影响将apache设为使用80端口,IIS使用其它端口,比如81,然后将apache作为IIS的代理。

在httpd.conf里面,取消下面四行的注释:

LoadModule proxy_module modules/mod_proxy.so

LoadModule proxy_connect_module modules/mod_proxy_connect.so

LoadModule proxy_http_module modules/mod_proxy_http.so

LoadModule proxy_ftp_module modules/mod_proxy_ftp.so

然后建立一个虚拟主机,将该域名的所有访问转向81端口。

ServerName iloves.vicp.net

ProxyPass / http://localhost:81/
ProxyPassReverse / http://localhost:81/
这样,对外就可以只需要一个端口,即可同时使用apache和IIS的功能了

类推,使用第二种方法,你可以在IIS上配置PHP4,Apache2中配置PHP5,只需要IIS中安装PHP4,把php.ini复制到\windows目录即可,这个就不用说了吧,Apache2中,只要把PHP5的php.ini放在PHP5安装目录里面就行了

配置Apache以支持PHP5:

LoadModule php5_module “D:/PHPServer/PHP5/php5apache2.dll”

AddType application/x-httpd-php .php

DirectoryIndex index.html index.php

PHPIniDir “D:/PHPServer/PHP5″

其中最重要的一条就是 PHPIniDir,用来指明php.ini文件所在位置,即PHP5的安装目录,注意所有目录的应该改为D:/PHPServer/PHP5这种格式,而非D:\PHPServer\PHP5,IIS的访问地址为http://192.168.0.1,Apache访问地址为http://192.168.0.2

思来想去,还是决定使用IIS部署PHP,这样可以一劳永逸,而且如果以后有其他的语言,比如asp等,也都继续考虑使用IIS发布

一、安装PHP环境
1、打开php官网,下载PHP5.6环境;
2、点击DownLoad,找到5.6或其他版本,点windows download;



3、根据电脑对应系统的版本下载Non Thread Safe(非线性安全),Apach对应下载Thread Safe(线性安全);



下载出来的文件 php-5.6.28-nts-Win32-VC11-x64.zip

注意的是,在选择php版本的时候,注意最好与你原项目的版本一致,否则可能会一直报错,导致不知道什么原因,我就是因为直接选择了最高的php版本,导致程序一直报错,切记

在上面的都设置完成之后,注意要等待一会儿,网站才能正常访问

4、压缩包解压后,找到php.ini-development或php.ini-production文件,选择其中一个复制一份改名为php.ini,用记事本打开,找到 ;extension_dir,,改为 extension_dir = “D:\php\php-5.6.30-nts-Win32-VC11-x64\ext”,找到;extension=php_bz2.dll等以;extension=开头处,去掉对应开头的”;”,这里的”;”相当于c#中的注释,去掉”;”即相当于去掉注释,使对应的项目变为可用;





二、配置IIS6
1、IIS选中部署的网站,双击右侧的处理程序映射,点击右侧操作中的添加模块映射,请求限制中勾选文件或文件夹选择项;







2、下载VC++2012运行库,这步必不可少:
php5.5系列x86地址:http://www.upupw.net/website/n33.html
php5.5系列x64地址:http://www.upupw.net/website/n43.html

vcredist_x64.exe

亲测地址可能要多打开几次才有效,打开后点击“云端下载”;
三、检测效果:
1、在本地打开部署在IIS上的网站;
2、可能会出现这样的问题:未能从程序集“System.ServiceModel, Version=3.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089”中加载类型“;
3、 根据MSDN的解释:如果安装了 .NET Framework 4,随后启用了 .NET Framework 3.5WCF HTTP 激活,则会发生此错误。
4、解决办法:若要解决该问题,请在 Visual Studio 2010 命令提示符下运行下面的命令行:aspnet_regiis.exe -i -enable或在cmd中运行:C:\Windows\Microsoft.NET\Framework\v4.0.30319\aspnet_regiis.exe -i -enable;

注意的是,在选择php版本的时候,注意最好与你原项目的版本一致,否则可能会一直报错,导致不知道什么原因,我就是因为直接选择了最高的php版本,导致程序一直报错,切记

在上面的都设置完成之后,注意要等待一会儿,网站才能正常访问

接下来就是安装mysql了

第一步:下载安装包

下载 地址:http://www.mysql.com/









截止到目前(2016/7/24) ,官网的最新版本是5.7.13,不过自己没有使用该版本,下载的是之前的版本5.6.31。



平台默认为Windows。



mysql-5.6.37-winx64.zip

确认自己的机器字长,点击download即可。

第二步:解压

解压之后可以将该文件夹改名,放到合适的位置。我是将文件夹改名为MySQL Server 5.6,放到D:\Program Files\MySQL路径中。当然你也可以放到自己想放的任意位置。



第三步:配置(不要急着使用,最好先配置)

配置环境变量PATH后,以后打开mysql就可以不用切换目录。原理:简单来说,环境变量里面的PATH,就是cmd系统的查找目录路径。你输入一个指令,系统怎么知道这个指令有没有呢?系统是怎么做的?其实系统是在当前目录和系统环境变量PATH里面的路径里进行查找,以找到的第一个为准,找不到就报错。所以设置PATH之后,可以省去每次用命令切换目录的麻烦。 打个比方:系统就像一辆公交车,按着既定的路线走。环境变量里面的路径就是行驶路线。到了一个站(找到第一个目录)就下车(运行)。

过程:计算机—>系统属性—>高级系统配置—>环境变量



选择PATH,在其后面添加: 你的mysql bin文件夹的路径 (如:我的是:D:\Program Files\MySQL\MySQL Server 5.6\bin ) 修改后的PATH为:

PATH=…….;D:\Program Files\MySQL\MySQL Server 5.6\bin (需注意:1.必须在原有PATH后加英文输入下的分号;2.是追加,不是覆盖。)



第四步:修改配置文件

配置完环境变量之后先不要启动mysql,还需要修改一下配置文件,mysql-5.6.1X默认的配置文件是在D:\Program Files\MySQL\MySQL Server 5.6\my-default.ini,可以自己再建立一个my.ini文件,在其中修改配置:

[mysqld] basedir=C:\Program Files\MySQL\MySQL Server 5.6(mysql所在目录) datadir=C:\Program Files\MySQL\MySQL Server 5.6\data (mysql所在目录\data)

mydefault.ini内容如下:



my.ini内容如下:



第五步:安装mysql

首先,以管理员身份运行cmd(必须以管理员身份运行,否则权限不够,会出错)

接着,进入D:\Program Files\MySQL Server 5.6\bin目录,

然后,执行命令
mysqld –install
,若无错,则会提示安装成功。



注:若之前安装过mysql,但由于某种原因未卸载干净,当再次安装mysql时,会提示此服务已存在。可用sc delete mysql命令,删除之前的版本,再执行mysqld –install命令。



第六步:启动mysql服务器

在cmd中 输入
net start mysql
命令。



第七步:登录mysql

在cmd中,输入
mysql -u root -p
,第一次登录没有密码,直接回车,登陆成功。



退出mysql的命令是exit 。直接关闭cmd窗口是没有退出的,要输入exit才会退出。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: