本文介绍了如何在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中实现清理例程?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持!

08-30 08:49