说明
本来想用Nginx+uwsgi的方式部署Flask项目,但uwsgi在Windows环境下还需其他依赖,而且要修改部分文件内容,照着Windows 10安装uWSGI:不可行、失败了一顿操作,最终还是失败了!!!于是尝试使用Apache+mod_wsgi。
方案一:Apache+mod_wsgi
安装Apache
下载Apache包
打开压缩包,把Apache24文件夹放到C盘根目录,即Apache的默认路径“C:\Apache24”。另外如果服务器上打开了iis要先关掉,因为iis跟Apache默认的端口都是80端口,端口冲突时会造成Apache服务无法安装或者启动。
然后打开cmd,cd到“C:\Apache24\bin”,运行“httpd –k install”安装Apache服务,然后启动它。(常用命令:运行服务httpd –k start,停止服务 httpd –k stop)
启动后Windows的控制面板>管理工具>服务中可看到Apache2.4服务。
打开浏览器,在地址栏输入“127.0.0.1”或者“localhost”,如果浏览器显示的网页里边出现“It Works!”,就说明Apache服务安装成功。这个时候在你自己的电脑上输入服务器的ip地址也能看到此页面。
安装mod_wsgi
下载mod_wsgi
使用pip install命令安装此whl文件。
安装好之后运行“mod_wsgi-express module-config”,得到三行语句,把这三行语句复制出来,后边配置站点的时候会用到。
开始配置
创建wsgi入口文件
在项目文件夹中新建一个 wsgi.py文件,要注意里边的application一定不能改成别的,因为mod_wsgi解析的时候只认这个东西。最简版本的wsgi.py代码如下所示:
import sys
Sys.path.insert(0, 'D:\path\to\project') #第二个参数为项目路径
from test import app as application # wsgi只认这个application
在Apache中配置站点
配置httpd.conf
打开Apach安装目录c:\Apache24\conf\httpd.conf文件进行Apache配置。找到有很多LoadModule的位置,把之前得到的三行语句复制到里边去,表示使用wsgi来作为Python Web服务网关接口。
这时候保存httpd.conf去重启Apache服务,会发现Apache服务的名字变了。
找到httpd.conf文件中
LoadModule vhost_alias_module modules/mod_vhost_alias.so
、
Include conf/extra/httpd-vhosts.conf
这两行,把前边的“#”号注释符删掉,表示启用虚拟主机并读取httpd- vhost.conf中的虚拟主机配置来配置站点。
配置httpd-vhosts.conf
打开C:\Apache24\conf\extra\httpd-vhosts.conf文件,里边的两个VirtualHost例子可以在每行前边加“#”号注释掉或者直接删掉,在最后加上下面的语句:
<VirtualHost *:80>
ServerAdmin serveradmin@yourserver.com
DocumentRoot D:\path\to\project
ServerName http://dummy-host.example.com
<Directory "D:\path\to\project">
Require all granted
Require host ip
</Directory>
WSGIScriptAlias / E:\path\to\project\wsgi.py
ErrorLog "logs/error.log"
</VirtualHost>
配置虚拟站点,配置相关的端口号,项目目录,wsgi.py的路径等
其中:
VirtualHost表示这是一个虚拟主机的配置,80指的是所用的端口为默认的80端口。可以弄很多不同的 VirtualHost并使用其他端口,但是要记得去防火墙中添加对应的端口的例外,同时在httpd.conf中查找Listen相关配置代码段增加对 应端口的监听。
ServerAdmin是服务器管理员的电子邮箱地址。
ServerName是服务器的IP地址。
Directory是对应的项目文件夹
WSGIScriptAlias需要写出wsgi.py文件的路径。中间那根斜杠表示url为根目录,也就是测试该站点的地址为http://127.0.0.1或者http://localhost。
至此配置完成,保存httpd.conf与httpd-vhosts.conf文件,然后重启Apache服务。每次修改配置文件之后都要重启Apache服务。
测试
打开浏览器进行测试,至此部署成功!
但是!很快有新的问题出现了。请求某些接口时总是不能成功(本地测试可以,部署到服务器上就失败),至今没有找到原因,待以后再探索。于是尝试第二种方案:Nginx+Tornado
方案二:Nginx+Tornado
配置Nginx
下载Nginx包
解压,利用cmd进入目录后输入:
start nginx.exe
即可启动nginx服务器。启动后在浏览器中输入http://localhost会显示nginx的欢迎画面。
如果未显示说明80端口被其它应用占用了。
其他常用的命令有:
nginx.exe -s quit #停止服务
nginx.exe -s stop #停止服务
nginx.exe -s reload #重启服务
将Tornado用作wsgi
使用pip install命令安装Tornado。
在项目文件夹下创建server.py文件并写下如下代码:
from tornado.httpserver import HTTPServer
from tornado.wsgi import WSGIContainer
from app import app
from tornado.ioloop import IOLoop
s = HTTPServer(WSGIContainer(app))
s.listen(9900)
IOLoop.current().start()
Tornado负责监听9900端口。
使用python server.py
将项目运行起来。
修改Nginx配置文件
修改nginx的配置文件nginx.conf(在解压目录下的conf子文件夹下):
server {
listen 80;
server_name localhost;
#charset koi8-r;
#access_log logs/host.access.log main;
location / {
root html;
index index.html index.htm;
proxy_pass http://localhost:9900;
}
....其他配置信息
}
修改location / 块中的内容,添加一行proxy_pass,则将访问localhost:80的请求全部转发到localhost:9900端口,也就是tornado监听的端口。
测试
重启nginx服务器,输入服务器地址进行测试。成功!且运行稳定。
Tips
修改配置文件并重启Nginx后,有时会出现无论如何都指向的是Nginx主页面。其实是我们开启了多个Nginx的进程,所以我们把多余的Nginx进程终止掉。
在nginx.exe的路径下输入命令
taskkill /fi "imagename eq nginx.exe" /f
再重新开启Nginx:start nginx.exe
就可以访问了。