【发布时间】:2021-03-20 03:11:33
【问题描述】:
我有一个完全缓存的流线型应用。事实上,我正在使用在本地端口上运行的 3rd 方缓存系统,我可以看到正在使用缓存。
但是,streamlit 在启动时会运行两个不同的实例:
# Windows Subsystem for Linux version 2.0, Running Ubuntu
You can now view your Streamlit app in your browser.
Local URL: http://localhost:8501
Network URL: http://172.21.141.16:8501
从我的打印语句来看,似乎只有本地实例正在访问我托管在本地端口上的缓存。
同时,网络 URL 实例根本不利用本地端口上托管的缓存,并重新计算所有长时间运行的进程,这些进程很高兴在本地缓存自己。
我不会将这个系统暴露在虚拟机之外,所以我不关心安全性。
我的问题相当于:我如何强制或消除 streamlit 的双实例运行时情况,以便所有正在运行的实例(如果必须有两个)都能够访问本地运行的缓存?
不过,与此同时,我需要保留 streamlit 的网络拓扑,因为我只能从 Windows 主机操作系统访问外部 URL (http://172.21.141.16:8501)。
请注意,我使用的是本地运行的缓存,因为我想访问和累积来自多个进程的缓存值——一些在前面,一些在后面。
【问题讨论】:
标签: caching memcached streamlit