V2EX 首页   注册   登录
V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
V2EX  ›  Flask

如何在 flask web 服务器上自动运行一个脚本

  •  
  •   mzmxcvbn · 4 天前 · 1010 次点击

    想做一个工业数据监控的 B/S 系统,服务器定时采集底下硬件的数据,用户可以通过浏览器访问服务器看到实时数据。现在 flask 服务器架好了,底下数据采集的 py 脚本也写好了,但我不知道如何能让服务器一启动就一直运行那个定时采集数据的脚本,然后这个采集上来的数据应该怎么传递?

    第 1 条附言  ·  4 天前
    求大神能给一个方向或者思路
    24 回复  |  直到 2017-04-22 01:51:57 +08:00
        1
    ppwangs   4 天前
    我当时也有和你差不多同样的问题,然后用搜索引擎解决了
        2
    zhuf   4 天前
    crontab
        3
    mzmxcvbn   4 天前
    @ppwangs 能给个关键字吗,搜了好久了
        4
    iPhone8   4 天前
    二楼说的很明确了
        5
    mlyy   4 天前 via iPhone
    celery ,注意搜 beat
        6
    mzmxcvbn   4 天前
    @iPhone8 我这个数据获取是按秒来采集的,定时任务不行吧。。。
        7
    HypoChen   4 天前
    celery beat
        8
    mzmxcvbn   4 天前
    关键不是定时,定时在数据采集的脚本用循环就好了。关键是这个脚本要跟着 web 服务一起起来,而且这个拿到的数据怎么传给服务器。
        9
    liprais   4 天前
    @mzmxcvbn 写个 shell 脚本启动服务器的时候一起调起来,数据写数据库或者随便啥 store,前端展示的时候去读
        10
    mzmxcvbn   4 天前
    @mlyy 我想问一下 celery 能让一个 while true 死循环的任务一直运行吗,让后把收到的数据存在一个地方(循环一次更新一次), web 服务器需要的时候再从那里读这个数据
        11
    mzmxcvbn   4 天前
    @HypoChen 我想问一下 celery 能让一个 while true 死循环的任务一直运行吗,让后把收到的数据存在一个地方(循环一次更新一次), web 服务器需要的时候再从那里读这个数据
        12
    HypoChen   4 天前
    @mzmxcvbn celery beat 支持每隔一定时间(精确到秒)便执行一次任务,文档有写。至于数据,直接扔数据库不好么, web server 直接去数据库拿
        13
    wwqgtxx   4 天前 via iPhone
    最简单的还是开个单独的线程 while True 跑,然后把结果丢进数据库或者消息队列
        14
    mzmxcvbn   4 天前
    @wwqgtxx 我一开始也是这么想的,就是不知道这个线程应该在哪里开, flask 有这个启动的监控吗
        15
    mzmxcvbn   4 天前
    @HypoChen 谢谢,我去找找
        16
    wwqgtxx   4 天前 via iPhone
    @mzmxcvbn app.before_first_request
        17
    modm   4 天前 via iPhone
    apscheduler
        18
    rookiebulls   4 天前 via Android
    apscheduler+1
        19
    kingsonl   4 天前
    apscheduler+1
        20
    clino   4 天前 via Android
    jenkins buildbot
        21
    freestyle   4 天前
    Windows 的话写个 bat/vbs 放开始菜单启动文件夹 Linux 的话选择就多了 楼上的都可以 crontab celery apscheduler

    另外实时显示数据用 websocket 优于轮询
        22
    TJT   4 天前
    apscheduler +1 , uwsgi 记得加 enable-threads ,我现在就是这么干的
        23
    mlyy   4 天前
    @mzmxcvbn 按你的意思,我只需要客户端发 request 的时候能 response 那个时刻的真值? app.before_request 。如果采集速度够快这样就行。采集速度慢的话, celery 之类的后台挂个 beat ,一直写到数据库之类的地方,你 request 的时候去数据库拿就行(既然采集有延迟,我的理解数据有一点延迟没关系)
        24
    lalalakakaka   4 天前
    居然做了和楼主同样的事情。
    而且我懒得学新东西,不想引进去一大堆依赖库,搞的在内网机器很难部署
    我的办法是手写了个守护进程( python 程序),用 subprocess 打开所有子进程:收集器、 web 服务、数据库进程、看门狗之类的。
    然后用个 bat 文件( windows )启动这个守护程序。

    至于数据传输是用 redis 做数据中间件,如果业务毕竟简单的话,直接 redis 做数据持久化就行。
    DigitalOcean
    关于   ·   FAQ   ·   API   ·   我们的愿景   ·   广告投放   ·   鸣谢   ·   370 人在线   最高记录 2466   ·  
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.7.5 · 54ms · UTC 20:18 · PVG 04:18 · LAX 13:18 · JFK 16:18
    ♥ Do have faith in what you're doing.
    沪ICP备16043287号-1