@

参考链接

如果你从来没有弄过python restful api 请参考以下链接入门。

如何在Ubuntu 18.04上使用uWSGI和Nginx服务Flask应用程序

注意: 以上链接有一些坑,可能会踩到:

  1. 如何在.ini文件中指定项目中的wsgi的路径
  2. 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文件隔离

  1. 安装venv模块

    安装python3-vene软件包,此时会安装venv模块
sudo apt install python3-venv
  1. 创建目录:test,进入test,复制上面可运行的python demo到这里
mkdir ~/test
cd ~/test
cp -r ~/flaskTest ./.
  1. 创建虚拟环境
python3.6 -m venv testenv
  1. 激活虚拟环境
source testenv/bin/activate

此时您已处于虚拟环境中, 界面会展示为:

(testenv)user@host:~/test$

注意:: 在激活的虚拟环境里,一律使用:pip,而不是pip3

三、设置flask应用程序

以下操作都是在虚拟环境中的操作

pip install wheel
pip install uwsgi flask
  1. 启用防火墙,允许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,以便交互

  1. 测试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接口的更多相关文章

  1. [阿里云部署] Ubuntu+Flask+Nginx+uWSGI+Mysql搭建阿里云Web服务器

    部署地址:123.56.7.181 Ubuntu+Flask+Nginx+uWSGI+Mysql搭建阿里云Web服务器 这个标题就比之前的"ECS服务器配置Web环境的全过程及参考资料&qu ...

  2. Flask+Nginx+uWSGI在Ubuntu服务器上的配置

    Flask+Nginx+uWSGI在Ubuntu服务器上的配置 Step1 安装系统环境 Ubuntu服务器选择是阿里云的ECS服务,ECS提供单独的内存\CPU\带宽\存储规格可以选择,并且提供合适 ...

  3. 五步教你实现使用Nginx+uWSGI+Django方法部署Django程序

    Django的部署可以有很多方式,采用nginx+uwsgi的方式是其中比较常见的一种方式. 在这种方式中,我们的通常做法是,将nginx作为服务器最前端,它将接收WEB的所有请求,统一管理请求.ng ...

  4. 使用Nginx+uWSGI+Django方法部署Django程序(上)

    Django的部署可以有很多方式,采用nginx+uwsgi的方式是其中比较常见的一种方式. 在这种方式中,我们的通常做法是,将nginx作为服务器最前端,它将接收WEB的所有请求,统一管理请求.ng ...

  5. 使用Nginx+uWSGI+Django方法部署Django程序

    第一步先解决uwsgi与django的桥接.解决在没有nginx的情况下,如何使用uwsgi+DJANGO来实现一个简单的WEB服务器. 第二步解决uwsgi与Nginx的桥接.通过nginx与uws ...

  6. 使用Nginx+uWSGI+Django方法部署Django程序(下)

    在上一篇文章<五步教你实现使用Nginx+uWSGI+Django方法部署Django程序(上)>中,阐述了如何只使用uWSGI来部署Django程序. 当然,单单只有uWSGI是不够的, ...

  7. Ubuntu18.04安装Python虚拟环境

    仅为使用Ubuntu18.04的Python开发人员作参考 1.安装Ubuntu18.04虚拟环境 sudo apt install virtualenv sudo apt install virtu ...

  8. Ubuntu16.04 flask + nginx + uWSGI 部署

    前言 又有段时间没写博客了,最近一直在写外包项目,都没啥空余时间.这几天花了不少时间做项目部署,也看了不少教程,这里就记录下整个过程,也方便以后要做类似部署的时候不用再查来查去了. flask + u ...

  9. nginx+uwsgi+virtualenv+supervisor部署项目

    一.导论 WSGI是Web服务器网关接口.它是一个规范,描述了Web服务器如何与Web应用程序通信,以及Web应用程序如何链接在一起以处理一个请求,(接收请求,处理请求,响应请求) 基于wsgi运行的 ...

随机推荐

  1. map自定义键值类型

    map自定义键值类型 改变Map的默认比较方式 https://www.cnblogs.com/zjfdlut/archive/2011/08/12/2135698.html 大家知道,STL中的ma ...

  2. 文件导出Excel、Word、Pdf

    如果要将查询结果导出Excel,只要将页面的Context-Type修改下: header( "Content-Type: application/vnd.ms-excel"> ...

  3. Android中ListView的使用

    1.主要概念 ListView用于将大数据集以列表的形式展示. ListView可以看成一个容器,它有如下继承链: View <- ViewGroup <- AdapterView < ...

  4. Async await 解析

    Async 定义:使异步函数以同步函数的形式书写(Generator函数语法糖) 原理:将Generator函数和自动执行器spawn包装在一个函数里 形式:将Generator函数的*替换成asyn ...

  5. Visual Studio快捷键使用

    1. 注释相关     添加注释:Ctrl + K,C     取消注释:Ctrl + K,U 2. 格式化相关     格式化代码:Ctrl + K,D 3. 智能提示相关     Ctrl + J

  6. LVS、nginx、Haproxy对比(详细)

    目录 代理软件 负载均衡产品介绍 haproxy 本文档参考 http://www.ha97.com/5646.html 代理软件 负载均衡产品介绍 市面上的负载均衡产品主要分为两种:硬件产品和软件产 ...

  7. python-----多进程笔记

    多进程笔记: 在Python中多进程的创建方式对比: 1.在Python中,可以通过os.fork()创建子进程,但是这种方式智能在'linux'和'unix'以及'mac'下面使用,不能跨平台,所以 ...

  8. gcc生成so文件

    准备三个文件test.h, test.c, main.c test.h #include <stdio.h> void say_hello(); test.c #include " ...

  9. Spark2 jar存档

    spark.yarn.archive需要手动将spark应用依赖jar上传到hdfs,该属性可以避免每一次运行spark应用时都重复打zip包上传到hdfs. 官网http://spark.apach ...

  10. Java abstract类的基本使用 和 [abstract类实现]打印1000以内的所有素数并输出时间

    笔记: /** 关键字abstract ,实现抽象类,相当于给出类的大纲,子类只管继承,但抽象类不可被实例化! * 1.抽象方法只保留方法的功能,而具体的执行,交给继承抽象类的子类,由子类重写所有的抽 ...