当执行bokeh回调(缩放)时,必须加载新的500个值。xRangeStart和xRangeEnd从总数组中定义新的所需值。如何存储这个总数组以获得最佳性能。
Redis,直接来自DataBase (MongoDB),不知何故?(后端无状态)
流动:
用户在前端的操作->回调调用-> ajax ->这里我需要得到所描述的新数据->从-> ajax返回-> source.change.emit()获取新数据。
粗体标记的部分存储在REDIS atm (用python编码)中。当一个图表中有多个图形/行时,回调需要几秒钟(对于每个大小为300万值的数组,大约1秒)。有没有办法在总体上提高这个速度。
发布于 2019-03-26 21:30:26
您是说AJAX后端是启用Python的,因此您可以尝试使用Datashader对要返回的数据进行预处理和优化。
另一种选择是在前端将wheel_zoom替换为“缩放滑块”,该滑块以"mouseup“作为callback_policy,这样回调就不会连续启动,而只在鼠标释放时才会启动。另外,有了滑块回调,就可以在Bokeh服务器上执行Python回调,在那里可以存储经过预处理的、经过优化的Redis数据副本。
https://stackoverflow.com/questions/55355433
复制相似问题