本文介绍了如何在R SHINY中实现清理例程?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
例如,我的闪亮应用程序可能会打开数据库连接
# server.R
db <- dbConnect("SQLite", DB_PATH)
shinyServer(
... # things involving db
)
现在,如何确保闪亮会话结束时连接db
正常关闭(通过dbDisconnect(db)
)?实际上,应该对连接到服务器的每个客户端执行清理,还是只执行一次?
我只是担心,由于有多个用户一直在连接和断开这款闪亮的应用程序,如果不进行适当的清理,他们会留下悬而未决的数据库连接。实际上,客户端只需关闭浏览器即可在没有警告的情况下断开连接。
推荐答案
执行此操作的正确方法是使用session$onSessionEnded
分配执行清理的函数。例如,在服务器中。R:
cancel.onSessionEnded <- session$onSessionEnded(function() {
dbDisconnect(db)
})
然后可以调用cancel.onSessionEnded
撤消分配。
这篇关于如何在R SHINY中实现清理例程?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持!