将树莓派变成一个web服务器(2):Nginx+Flask+uWSGI部署全过程

时间:2022-10-29 09:17:15

1)安装Flask,uwsgi,nginx

sudo apt-get update
sudo apt-get install python-flask #Flask
sudo apt-get install uwsgi uwsgi-plugin-python #uWSGI
sudo apt-get install nginx #Nginx

2)创建Flask工程

这里就用最简单的HelloWorld,

创建一个工程文件夹flasksite,新建文件index.py

代码:

from flask import Flask

app = Flask(__name__)

@app.route('/')
def hello():
return 'Hello World' if __name__ == '__main__': app.run()

3)配置uwsgi

uwsgi配置文件各项说明

<uwsgi>
<pythonpath>[上一步新建的工程文件夹,即文件夹flask的路径]</pythonpath>
<module>[上一步新建的python文件,即模块名为index]</module>
<callable>[因为app是启动整个服务的入口,默认就写app]</callable>
<socket>127.0.0.1:8000</socket> #注:设定套接字
<master/>
<processes>4</processes> #注:跑几个线程,这里用4个线程
<memory-report/>
</uwsgi>

在刚才创建的flasksite目录下创建一个uwsgi的xml配置文件flasksite.xml::

<uwsgi>
<pythonpath>/var/www/flasksite</pythonpath>
<module>index</module>
<callable>app</callable>
<socket>127.0.0.1:8000</socket>
<master/>
<processes>4</processes>
<memory-report/>
</uwsgi>

3)配置nginx

在/etc/nginx/sites-available/目录下,创建一个站点文件配置文件site:

server {

  listen 80;
  server_name localhost;   location / {
    root /var/www/flasksite;
    include uwsgi_params;
    uwsgi_pass 127.0.0.1:8000;
    uwsgi_param UWSGI_CHDIR /var/www/flasksite;
    uwsgi_param UWSGI_SCRIPT index;
    uwsgi_read_timeout 1800;
    uwsgi_send_timeout 300;
    proxy_read_timeout 300;
    error_page 404 @proxy;
}
}

然后用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_python -x /var/www/flasksite/flasksite.xml

会打出很多的字,如果没有加载工程成功可以从打出的信息中看出,然后不要关闭该Terminal,

将树莓派变成一个web服务器(2):Nginx+Flask+uWSGI部署全过程

*特别注意,使用的是uwsgi_python命令,不是uwsgi

*除了配置XML文件,还可以用命令行部署,如:

sudo uwsgi_python -s 127.0.0.1: --module index --callable app --process 

2.新打开一个Terminal,在里面启动nginx:

sudo /etc/init.d/nginx start

然后在浏览器里访问localhost,helloworld出来了,Terminal里面出现了一行信息。

将树莓派变成一个web服务器(2):Nginx+Flask+uWSGI部署全过程

如果能看到Hell World,说明我们打通的桥梁变成:客户端(浏览器)——服务器(nginx)——socket——uWSGI——python

最后,参考文章:

1.linux下nginx+python+uwsgi部署总结http://www.vimer.cn?p=2274

2.uwsgi 配合django,web.py,flask等 http://projects.unbit.it/uwsgi/wiki/Example

3uwsgi 启动参数:http://uwsgi-docs.readthedocs.org/en/latest/Options.html

将树莓派变成一个web服务器(2):Nginx+Flask+uWSGI部署全过程的更多相关文章

  1. 树莓派变成一个Web服务器: nginx &plus; php &plus; sqlite

    将树莓派变成一个Web服务器,通过访问网页,就可以控制树莓派,比如:查看摄像头\开灯等等. 一想到Linux Web服务器,我们首先想到的是,Apache + MySql + Php. 树莓派可以安装 ...

  2. 树莓派&lpar;raspberry pi&rpar;学习11&colon; 将树莓派变成一个Web服务器&lpar;转&rpar;

    将树莓派变成一个Web服务器,通过访问网页,就可以控制树莓派,比如:查看摄像头\开灯等等. 一想到Linux Web服务器,我们首先想到的是,Apache + MySql + Php. 树莓派可以安装 ...

  3. 用C写一个web服务器(二) I&sol;O多路复用之epoll

    .container { margin-right: auto; margin-left: auto; padding-left: 15px; padding-right: 15px } .conta ...

  4. 十七、创建一个 WEB 服务器(一)

    1.Node.js 创建的第一个应用 var http=require("http") http.createServer(function (req,res) { res.wri ...

  5. 用java写一个web服务器

    一.超文本传输协议 Web服务器和浏览器通过HTTP协议在Internet上发送和接收消息.HTTP协议是一种请求-应答式的协议——客户端发送一个请求,服务器返回该请求的应答.HTTP协议使用可靠的T ...

  6. 【重点突破】——使用Express创建一个web服务器

    一.引言 在自学node.js的过程中有一个非常重要的框架,那就是Express.它是一个基于NodeJs http模块而编写的高层模块,弥补http模块的繁琐和不方便,能够快速开发http服务器.这 ...

  7. C&plus;&plus;实现一个web服务器&comma; 弱智版服务器

    监听本地的8888端口, 当在浏览器中访问这个地址的时候, 返回一堆HTML数据, 这种方式返回的数据不稳定,不同浏览器解析不同, 因为我们没有定义返回文件类型: #include <stdli ...

  8. 使用node&period;js 文档里的方法写一个web服务器

    刚刚看了node.js文档里的一个小例子,就是用 node.js 写一个web服务器的小例子 上代码 (*^▽^*) //helloworld.js// 使用node.js写一个服务器 const h ...

  9. Tomcat源码分析 (一)----- 手写一个web服务器

    作为后端开发人员,在实际的工作中我们会非常高频地使用到web服务器.而tomcat作为web服务器领域中举足轻重的一个web框架,又是不能不学习和了解的. tomcat其实是一个web框架,那么其内部 ...

随机推荐

  1. PHP页面跳转到另一个页面的方法

    用HTTP头信息重定向到另外一个页面的方法如下: <? if (isset($url)) { Header("HTTP/1.1 303 See Other"); Header ...

  2. Easyui部分组件讲解

    Easyui部分组件讲解 目  录 1.... Accordion(可折叠标签)... 2 1.1          实例... 2 1.2          参数... 3 2.... DateBo ...

  3. hadoop中Combiner使用中需要注意的地方

    今天在写一个MR的时候,用到了combiner.在使用过程中,遇到了一些问题,特此记录一下. Combiner分为两种,一种是可插拔的,一种是不可插拔的. 可插拔的:Combiner和Reduce的处 ...

  4. js动态给table添加行&lpar;tr&rpar;

    html <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN"> <html> &lt ...

  5. 学习笔记——原型模式Prototype

    原型模式,简单说就是具有一个克隆方法,外部可以直接使用此方法得到相应对象的拷贝对象. 比如哆啦A梦的复制镜,一照,就把物品拷贝了一份(虽然是镜子复制是相反的,这里就忽略这个细节了) C++中依靠拷贝构 ...

  6. Vue源码后记-vFor列表渲染(3)

    这一节肯定能完! 经过DOM字符串的AST转化,再通过render变成vnode,最后就剩下patch到页面上了. render函数跑完应该是在这里: function mountComponent( ...

  7. 排查程序死循环,死锁的方法 ——pstack

    pstack命令可显示每个进程的栈跟踪,pstack $pid即可,pstack命令须由$pid进程的属主或者root运行. 这次出现cpu占比100%的情况,但看memory占比,并无异常,怀疑是某 ...

  8. MySQL物理备份 xtrabackup

    MySQL 备份之 xtrabackup | innobackupex Xtrabackup 介绍 Xtrabackup 是一个对 InnoDB 做数据备份的工具,支持在线热备份(备份时不影响数据读写 ...

  9. 开机自动启动WEB服务,共享目录。

    最近工作中,需要共享一个目录,每次重启总要手动执行一下  nohup python -m SimpleHTTPServer 8000这个命令,想着实现让它开机自动启动,就一劳永逸了. 手动步骤如下: ...

  10. Java-左移右移-jdk8

    移位有三种 << 左移,左边补0 >> 右移,正数左边补0,负数补1 >>> 右移, 正数,负数统一左边补0 来看几个奇葩的代码 public static ...