python - 使用 python 在 Azure Event Hub 中收集 Websocket 流数据

标签 python azure websocket azure-eventhub azure-stream-analytics

我正在尝试将比特币实时流数据收集到 Azure 事件中心。 下面是我们如何在本地计算机上执行的代码。

如何使用此代码来收集 Azure 事件中心中的流。微软提供的所有示例和文档都不清楚。

import logging
import websocket, json

cc = "btcusd"
interval = '1m'
socket = f'wss://stream.binance.com:9443/ws/{cc}t@kline_{interval}'

def on_message(ws, message):
    json_message = json.loads(message)
    candle = json_message['k']
    is_candle_close = candle['x']
    close = candle['c']
    high = candle['h']
    low = candle['l']
    open = candle['o']
    quote = {
        'close': close,
        'high': high,
        'low': low,
        'open': open
    }
    print(f'{cc} {is_candle_close} {quote}')

def on_error(ws, error):
    logging.error(error)

def on_close(ws):
    logging.info("### closed ###")
    
logging.info("Start")
logging.info("Connecting to websocket")
websocket.enableTrace(True)
ws = websocket.WebSocketApp(socket,
                            on_message = on_message,
                            on_error = on_error,
                            on_close = on_close)
ws.run_forever()

最佳答案

您手头有 2 项任务:

  • 将数据流发送到事件中心。我会首先开始,并使用 Event Hub Python SDK在您的本地应用程序中。
  • 在 Azure 中托管您的应用。完成事件中心端的操作后,您可以在 Azure Functions 中部署应用程序。请参阅Python dev guide为此(请注意,您可以在 Windows 上进行本地开发,但需要部署到 Linux 运行时,但这应该不是问题)。请参阅here从头开始。

函数不是唯一的选择,但可能是最简单的。请参阅that list寻找替代方案。

关于python - 使用 python 在 Azure Event Hub 中收集 Websocket 流数据,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/68501089/

相关文章:

Azure AD B2C - 如何实现自定义注册流程?

Azure 数据仓库备份到 SQL 数据库

javascript - 即使设置间隔后 Canvas 也不会更新

python - 如何在 Django 管理中显示 ManyToMany 关系的 raw_id 值?

python - 如何设置 tkinter 窗口的 WM_CLASS 字符串的应用程序名称?

visual-studio - 可以将Service Fabric应用程序从Windows Docker容器内部署到群集吗?

websocket - Spring 4 DispatcherServlet 与 websockets 映射

python - 如何更新列表而不是删除以前的输入

python - 使用 keras 进行情感分析,包括中性推文

javascript - NodeJs 连接到服务器后对请求进行多次回复