转载来自
http://blackgu.blogbus.com/logs/171363164.html
略作修改
1)安装Flask,uwsgi,nginx
Flask:sudo apt-get install python-flask
uwsgi:sudo apt-get
install
uwsgi uwsgi-plugin-python
nginx:sudo apt-get install nginx
2)创建Flask工程
这里就用最简单的HelloWorld,创建一个工程目录:myapp,里面包含以下文件:
文件名:myapp.py
代码:
from flask import Flask
app = Flask(__name__)
@app.route(‘/‘)
def hello():
return ‘Hello World‘
if __name__ == ‘__main__‘:
app.run()
3)配置uwsgi
在刚才创建的myapp目录下创建一个uwsgi的xml配置文件myapp_config.xml:
<uwsgi>
<pythonpath>[你的工程的根目录]</pythonpath>
<module>[模块名,这里用myapp]</module>
<callable>[因为app是启动整个服务的入口,所以是app]</callable>
<socket>/tmp/uwsgi.sock</socket> #注:这里的sock文件不是某个现成的文件,也不需要事先创建,运行时会自动创建,文件名也是自己定的,路径也是可以自己定的
<master/>
<processes>4</processes> #注:跑几个线程,这里用4个线程
<memory-report/>
</uwsgi>
样例:
<uwsgi>
<pythonpath>/root/workspace_aptana/mytest/src/test/uwsgi</pythonpath>
<module>myapp</module>
<callable>app</callable>
<socket>/tmp/uwsgi.sock</socket>
<master/>
<processes>4</processes>
<memory-report/>
</uwsgi>
3)配置nginx
在/etc/nginx/sites-available/目录下,创建一个站点文件配置文件site:
server {
listen 80;
server_name www.myapp.com;
location / {
include uwsgi_params;
uwsgi_pass unix:/tmp/uwsgi.sock; #注:这里的sock文件和uwsgi的sock文件配的是同一个文件,因为nginx和uwsgi需要通过这个socket进行交互
}
}
或者,干脆直接在defaut.conf里面修改如下内容:
server {
listen 8081;
server_name localhost;
location / {
include uwsgi_params;
uwsgi_pass unix:/tmp/uwsgi.sock;
}
}
然后用ln命令创建一个link到/etc/nginx/sites-enable/里,link的名字也叫site,删除sites-enable目录下的default的link:
sudo ln -s /etc/nginx/sites-available/site /etc/nginx/sites-enabled/ (注意:这个是LN的小写命令)
sudo rm /etc/nginx/sites-enabled/default
4)开始部署
1.启动uwsgi,命令是sudo uwsgi -x myapp_config.xml,会打出很多的字,如果没有加载工程成功可以从打出的信息中看出,然后不要关闭该Terminal,
2.新打开一个Terminal,在里面启动nginx:sudo /etc/init.d/nginx start,然后在浏览器里访问localhost(看配置的nginx里的server监听的端口,如上面的8),
3这时如果出现502页面,可以看下日志,我的日志是在/var/log/nginx/error.log,如果里面显示是sock文件因为权限问题无法访问,那只要利用chmod命令给sock文件赋上权限:chmod 777 /tmp/uwsgi.sock,然后uwsgi和nginx再重启一下,现在访问localhost就可以看到“Hello World!”,OK!