gpt4 book ai didi

python - flask 中的 pyserial 读取串行端口(可能使用 gevent)

转载 作者:行者123 更新时间:2023-11-28 20:25:46 24 4
gpt4 key购买 nike

我正在构建一个网络服务器,它需要读取(并继续读取)它正在运行的机器的串行端口。
目的是能够读取条形码扫描仪,并使用服务器发送的事件用读取的条形码更新浏览器。

我正在使用 flask 来执行此操作。我浏览了一下,有些实现只需要 flask,有人说我需要一个像 Gevent 这样的异步库,还有一些人甚至说我需要 Gevent 和某种队列,比如 Redis 或 RabbitMQ。

我试图将我的代码基于我在 stackoverflow 上找到的一个非常简单的示例 here .我大部分时间都在使用它,但我遇到了一些问题;

  • 在 Chrome 中存在跨源错误,通过添加Access-Control-Allow-Origin header 我可以让它在 FireFox 中工作,但 Chrome 仍然无法正常工作。是不是只有FF支持SSE跨源?我需要它来支持 CORS,因为浏览器会需要从单独的机器加载条码数据。
  • 在每条消息之后,浏览器会在控制台中显示条形码,但是然后它关闭连接并仅在大约 3 后再次打开它秒。看来这起源于 Flask,它给了我数据然后就停止了。
  • 另外,我想知道它在负载下的表现如何。我的意思是, flask 为文本/事件流 mime 类型保持连接打开。如果多个客户端连接,过一会儿它不会阻塞 flask 吗,因为所有连接都会饱和吗?

我的代码如下(为清楚起见缩短)

服务器端:

from flask import Flask
import flask
import serial

app = Flask(__name__)
app.debug = True

def event_barcode():
ser = serial.Serial()
ser.port = 0
ser.baudrate = 9600
ser.bytesize = 8
ser.parity = serial.PARITY_NONE
ser.stopbits = serial.STOPBITS_ONE
ser.open()
s = ser.read(7)
yield 'data: %s\n\n' % s

@app.route('/barcode')
def barcode():
newresponse = flask.Response(event_barcode(), mimetype="text/event-stream")
newresponse.headers.add('Access-Control-Allow-Origin', '*')
return newresponse

if __name__ == '__main__':
app.run(port=8080, threaded=True)

客户端:

    <!DOCTYPE HTML>
<html>
<head>
<meta http-equiv=Content-Type content="text/html; charset=utf-8">
<title>TEST</title>
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.8.3/jquery.min.js" type="text/javascript" charset="utf-8"></script>
<script>

$(document).ready(function(){
if (!!window.EventSource) {
console.log('SSE supported.');
var source = new EventSource('http://localhost:8080/barcode');

source.addEventListener('message', function(e) {
console.log(e.data);
}, false);

source.addEventListener('open', function(e) {
console.log('Connection was opened.');
}, false);

source.addEventListener('error', function(e) {
if (e.readyState == EventSource.CLOSED) {
console.log('Connection was closed.');
}
}, false);

} else {
console.log('SSE notsupported.');
}
});

</script>
</head>

<body>

</body>
</html>

我在这里查看了更多信息: http://www.socketubs.net/2012/10/28/Websocket_with_flask_and_gevent/ http://sdiehl.github.com/gevent-tutorial/#chat-server

我希望有人能解决我的问题,并可能为我指出一些解决方案,以解决跨源和 3 秒延迟问题。

谢谢。

最佳答案

以下是一些可能有帮助的要点(我一直想发布基于“django-sse”的“flask-sse”之类的东西):

https://gist.github.com/3680055

https://gist.github.com/3687523

也很有用 - https://github.com/jkbr/chat/blob/master/app.py

'RedisSseStream' 类使用 redis 作为后端在线程之间进行通信(尽管 gevent 可以做到这一点?),并“监听”redis 发布事件。

虽然“PeriodicSseStream”不需要 redis,但它无法在 Flask 线程之间进行通信,即使用来自另一个响应的信息;如果没有像 Redis 这样的东西,单独的线程(流和为另一个用户服务的线程)就无法通信。

正如 Janus 所说,生成器只返回一个结果——它必须产生多个结果,在这种情况下,它必须包含在一个循环中,该循环在每次串行轮询后无限产生;您还需要决定什么将限制轮询,是否受时间限制(定期轮询)或其他因素(例如,如果读取串行端口已经需要一段时间)?

我真的不太了解 sse 的性能,或者它的支持程度(以及跨域),但如果你考虑 socket.io , 你也许可以使用 this改进网络套接字 performance?

关于python - flask 中的 pyserial 读取串行端口(可能使用 gevent),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14022933/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com