flask + nginx + uwsgi + ubuntu18.04部署python restful接口
@
参考链接
如果你从来没有弄过python restful api 请参考以下链接入门。
如何在Ubuntu 18.04上使用uWSGI和Nginx服务Flask应用程序
注意: 以上链接有一些坑,可能会踩到:
- 如何在
.ini文件中指定项目中的wsgi的路径 nginx配置好后无法访问项目,报权限问题或者连接被拒
以上问题我都遇到过,而且也花了很长时间解决。我的教程里会指明如何解决以上问题,在使用的过程中,有任何问题,可以加群:821605718或者加我个人qq:2768861003
效果展示
已一个简单的helloword为例

一、准备工作
- linux 环境: ubuntu18.04
- 准备一个可运行的python restful api
1.1 可运行的python demo:

app.py:
#!/usr/bin/python
# -*- coding: UTF-8 -*-
from flask import Flask
from flask_restful import Resource, Api
app = Flask(__name__)
api = Api(app)
class HelloWorld(Resource):
"""
api: /api/HelloWorld
restful 接口调用测试
"""
def get(self):
print('Hello world of RESTful api!')
return {'hello': 'world'}
api.add_resource(HelloWorld, '/api/HelloWorld')
if __name__ == '__main__':
app.run(host="0.0.0.0", port=5000)
wsgi.py:
#!/usr/bin/python
# -*- coding: UTF-8 -*-
import sys
import os
FATHER_DIRECTORY = os.path.dirname(
os.path.split(os.path.realpath(__file__))[0])
sys.path.append(FATHER_DIRECTORY)
from restfulServer.app import app
if __name__ == '__main__':
app.run()
1.2 更新系统环境
sudo apt update
sudo apt install python3-pip python3-dev build-essential libssl-dev libffi-dev python3-setuptools
二、创建python虚拟环境
我们将建立一个虚拟环境,以将Flask应用程序与系统上的其他Python文件隔离
- 安装
venv模块
安装python3-vene软件包,此时会安装venv模块
sudo apt install python3-venv
- 创建目录:
test,进入test,复制上面可运行的python demo到这里
mkdir ~/test
cd ~/test
cp -r ~/flaskTest ./.
- 创建虚拟环境
python3.6 -m venv testenv
- 激活虚拟环境
source testenv/bin/activate
此时您已处于虚拟环境中, 界面会展示为:
(testenv)user@host:~/test$
注意:: 在激活的虚拟环境里,一律使用:
pip,而不是pip3
三、设置flask应用程序
以下操作都是在虚拟环境中的操作
pip install wheel
pip install uwsgi flask
- 启用防火墙,允许5000端口被访问。
注意: 也要观察linux服务器的安全组允许5000端口可以被访问,才可以通过域名+端口访问。
sudo ufw allow 5000
测试访问:
cd ~/test/flaskTest/restfulServer
python app.py
注意: 如果有没有安装的包,请安装上,安装命令为:
pip install 包名字
执行后会看到以下输出:
Output
* Serving Flask app "test" (lazy loading)
* Environment: production
WARNING: Do not use the development server in a production environment.
Use a production WSGI server instead.
* Debug mode: off
* Running on http://0.0.0.0:5000/ (Press CTRL+C to quit)
访问:
http://your_server_ip:5000
你会看到以下内容

四、配置uWSGI
以上虽然可以运行,但是ctrl + c结束后就没有了,因此我们需要一个程序的入口点:wsgi.py,以便交互
- 测试uwsgi是否可以正常运行:
我们可以通过简单地向其传递入口点的名称来实现。模块的名称(减去.py扩展名)加上应用程序中可调用名称的名称构成。我这里是wsgi:app。
cd ~/test/flaskTest/restfulServer
uwsgi --socket 0.0.0.0:5000 --protocol=http -w wsgi:app
访问:
http://your_server_ip:5000
你会看到以下内容

2. 创建一个uWSGI配置文件
如果你想长期使用的话,请执行以下操作
nano ~/test/test.ini
[uwsgi]
chdir=/home/ubuntu/test
module = flaskTest.restfulServer.wsgi:app
master = true
processes = 5
socket = test.sock
chmod-socket = 664
vacuum = true
die-on-term = true
[uwsgi]: 知道以下配置属于uwsgi
chdir: 定义你的项目目录
module :.就类似linux里的/,我们将指定两件事: 模块本身(通过引用wsgi.py减去扩展名的文件)和文件中的可调用项app
master : 告诉uwsgi以master模式启动
processes :生成5个进程
socket : 生成Unix套接字,放在chdir指定的目录里。这里的socket文件将用于和nginx进行配合访问
chmod-socket: 更改socket文件的权限
vacuum :当进程停止时,使用这个关键字清理socket
die-on-term: 这可以帮助确保init系统和uWSGI对每个过程信号的含义具有相同的假设
五、设置系统启动
创建一个.service以/etc/systemd/system目录结尾的单元文件用来启动:
sudo nano /etc/systemd/system/test.service
[Unit]
Description=uWSGI instance to serve pythonRestfulApiServer
After=network.target
[Service]
User=ubuntu
Group=www-data
WorkingDirectory=/home/ubuntu/test
Environment="PATH=/home/ubuntu/test/testenv/bin"
ExecStart=/home/ubuntu/test/testenv/bin/uwsgi --ini /home/ubuntu/test/test.ini
[Install]
WantedBy=multi-user.target
到这里,我们的systemd服务文件就完成了,接下来启动uWSGI服务
sudo systemctl start test
sudo systemctl enable test
检查状态:
sudo systemctl status test
输出:
Output
● test.service - uWSGI instance to serve test
Loaded: loaded (/etc/systemd/system/test.service; enabled; vendor preset: enabled)
Active: active (running) since Fri 2018-07-13 14:28:39 UTC; 46s ago
Main PID: 30360 (uwsgi)
Tasks: 6 (limit: 1153)
CGroup: /system.slice/myproject.service
├─30360 /home/ubuntu/test/testEnv/bin/uwsgi --ini myproject.ini
├─30378 /home/ubuntu/test/testEnv/bin/uwsgi --ini myproject.ini
├─30379 /home/ubuntu/test/testEnv/bin/uwsgi --ini myproject.ini
├─30380 /home/ubuntu/test/testEnv/bin/uwsgi --ini myproject.ini
├─30381 /home/ubuntu/test/testEnv/bin/uwsgi --ini myproject.ini
└─30382 /home/ubuntu/test/testEnv/bin/uwsgi --ini myproject.ini
六、配置nginx代理
sudo nano /etc/nginx/sites-available/test
server {
listen 80;
server_name 94.191.19.28;
location / {
include uwsgi_params;
uwsgi_pass unix:/home/ubuntu/test/test.sock;
}
}
sudo ln -s /etc/nginx/sites-available/test /etc/nginx/sites-enabled
sudo nginx -t
sudo nginx -s reload
访问:
http://your_domain
如果遇到任何错误请检查:
sudo less /var/log/nginx/error.log:检查Nginx错误日志。
sudo less /var/log/nginx/access.log:检查Nginx访问日志。
sudo journalctl -u nginx:检查Nginx进程日志。
sudo journalctl -u myproject:检查Flask应用的uWSGI日志。
flask + nginx + uwsgi + ubuntu18.04部署python restful接口的更多相关文章
- [阿里云部署] Ubuntu+Flask+Nginx+uWSGI+Mysql搭建阿里云Web服务器
部署地址:123.56.7.181 Ubuntu+Flask+Nginx+uWSGI+Mysql搭建阿里云Web服务器 这个标题就比之前的"ECS服务器配置Web环境的全过程及参考资料&qu ...
- Flask+Nginx+uWSGI在Ubuntu服务器上的配置
Flask+Nginx+uWSGI在Ubuntu服务器上的配置 Step1 安装系统环境 Ubuntu服务器选择是阿里云的ECS服务,ECS提供单独的内存\CPU\带宽\存储规格可以选择,并且提供合适 ...
- 五步教你实现使用Nginx+uWSGI+Django方法部署Django程序
Django的部署可以有很多方式,采用nginx+uwsgi的方式是其中比较常见的一种方式. 在这种方式中,我们的通常做法是,将nginx作为服务器最前端,它将接收WEB的所有请求,统一管理请求.ng ...
- 使用Nginx+uWSGI+Django方法部署Django程序(上)
Django的部署可以有很多方式,采用nginx+uwsgi的方式是其中比较常见的一种方式. 在这种方式中,我们的通常做法是,将nginx作为服务器最前端,它将接收WEB的所有请求,统一管理请求.ng ...
- 使用Nginx+uWSGI+Django方法部署Django程序
第一步先解决uwsgi与django的桥接.解决在没有nginx的情况下,如何使用uwsgi+DJANGO来实现一个简单的WEB服务器. 第二步解决uwsgi与Nginx的桥接.通过nginx与uws ...
- 使用Nginx+uWSGI+Django方法部署Django程序(下)
在上一篇文章<五步教你实现使用Nginx+uWSGI+Django方法部署Django程序(上)>中,阐述了如何只使用uWSGI来部署Django程序. 当然,单单只有uWSGI是不够的, ...
- Ubuntu18.04安装Python虚拟环境
仅为使用Ubuntu18.04的Python开发人员作参考 1.安装Ubuntu18.04虚拟环境 sudo apt install virtualenv sudo apt install virtu ...
- Ubuntu16.04 flask + nginx + uWSGI 部署
前言 又有段时间没写博客了,最近一直在写外包项目,都没啥空余时间.这几天花了不少时间做项目部署,也看了不少教程,这里就记录下整个过程,也方便以后要做类似部署的时候不用再查来查去了. flask + u ...
- nginx+uwsgi+virtualenv+supervisor部署项目
一.导论 WSGI是Web服务器网关接口.它是一个规范,描述了Web服务器如何与Web应用程序通信,以及Web应用程序如何链接在一起以处理一个请求,(接收请求,处理请求,响应请求) 基于wsgi运行的 ...
随机推荐
- map自定义键值类型
map自定义键值类型 改变Map的默认比较方式 https://www.cnblogs.com/zjfdlut/archive/2011/08/12/2135698.html 大家知道,STL中的ma ...
- 文件导出Excel、Word、Pdf
如果要将查询结果导出Excel,只要将页面的Context-Type修改下: header( "Content-Type: application/vnd.ms-excel"> ...
- Android中ListView的使用
1.主要概念 ListView用于将大数据集以列表的形式展示. ListView可以看成一个容器,它有如下继承链: View <- ViewGroup <- AdapterView < ...
- Async await 解析
Async 定义:使异步函数以同步函数的形式书写(Generator函数语法糖) 原理:将Generator函数和自动执行器spawn包装在一个函数里 形式:将Generator函数的*替换成asyn ...
- Visual Studio快捷键使用
1. 注释相关 添加注释:Ctrl + K,C 取消注释:Ctrl + K,U 2. 格式化相关 格式化代码:Ctrl + K,D 3. 智能提示相关 Ctrl + J
- LVS、nginx、Haproxy对比(详细)
目录 代理软件 负载均衡产品介绍 haproxy 本文档参考 http://www.ha97.com/5646.html 代理软件 负载均衡产品介绍 市面上的负载均衡产品主要分为两种:硬件产品和软件产 ...
- python-----多进程笔记
多进程笔记: 在Python中多进程的创建方式对比: 1.在Python中,可以通过os.fork()创建子进程,但是这种方式智能在'linux'和'unix'以及'mac'下面使用,不能跨平台,所以 ...
- gcc生成so文件
准备三个文件test.h, test.c, main.c test.h #include <stdio.h> void say_hello(); test.c #include " ...
- Spark2 jar存档
spark.yarn.archive需要手动将spark应用依赖jar上传到hdfs,该属性可以避免每一次运行spark应用时都重复打zip包上传到hdfs. 官网http://spark.apach ...
- Java abstract类的基本使用 和 [abstract类实现]打印1000以内的所有素数并输出时间
笔记: /** 关键字abstract ,实现抽象类,相当于给出类的大纲,子类只管继承,但抽象类不可被实例化! * 1.抽象方法只保留方法的功能,而具体的执行,交给继承抽象类的子类,由子类重写所有的抽 ...