R Shiny App 在 60 秒内超时,即使在 conf 文件中传递了 app_init_timeout 设置后也是如此

Posted

技术标签:

【中文标题】R Shiny App 在 60 秒内超时,即使在 conf 文件中传递了 app_init_timeout 设置后也是如此【英文标题】:R Shiny App times out in 60 seconds, even after passing an app_init_timeout setting in the conf file 【发布时间】:2021-06-23 01:38:19 【问题描述】:

我尝试将我的 R 闪亮应用程序容器化,该应用程序使用 docker 连接到 sql 服务器映像。如果我将其指向较小的数据集,该应用程序会加载一些初始数据并且工作正常,如果我在初始化步骤中加载大型数据集,该应用程序会开始给我一个超时。而实际的错误信息是

应用程序启动失败。

应用程序在初始化期间退出。

我查看了R Documentation 并发现关于 app_init_timeout 每个应用程序的默认超时时间为 60 秒,可以通过设置此参数来增加,所以我将超时参数设置为 1800 秒但不幸的是它对我的应用没有影响,并且在通常的 60 秒后超时。

我正在尝试将自定义的 server.conf 复制到 etc/shiny-server/shiny-server.conf 我指定增加的 app_init_timeout 如下:

run_as shiny;
# Define a top-level server which will listen on a port
server 
  # Instruct this server to listen on port 3838
  listen 3838;
  
  # Define the location available at the base URL
  location / 
    site_dir /srv/shiny-server;
    log_dir /var/log/shiny-server;
    directory_index on;
    # Increase the timeout of the app
    app_init_timeout 3600;
    app_idle_timeout 3600;
    

我的 docker 文件是

FROM  rocker/shiny-verse

#update all packages
RUN apt-get update

#upgrade
RUN apt-get upgrade -y

#install additional packages
RUN apt install gpg-agent -y unixodbc apt-utils curl

#get msodbcsql17 and install it
 RUN curl https://packages.microsoft.com/keys/microsoft.asc | apt-key add -
 RUN curl https://packages.microsoft.com/config/ubuntu/18.04/prod.list > /etc/apt/sources.list.d/mssql-release.list
 RUN apt-get update -y
 RUN ACCEPT_EULA=Y apt-get install -y msodbcsql17 


RUN apt-get install tcl8.6 tk8.6 -y
#RUN curl -o Rtools.exe https://cran.r-project.org/bin/windows/Rtools/Rtools35.exe
#rename SQL Driver title in odbcinst file
RUN sed -i 's/ODBC Driver 17 for SQL Server/SQL Server/' etc/odbcinst.ini


#install packaes needed for running the app
RUN R -e "install.packages(c('shiny'))"
RUN R -e "install.packages(c('shinydashboard'))"
RUN R -e "install.packages(c('dbplyr'))"
RUN R -e "install.packages(c('odbc'))"
RUN R -e "install.packages(c('sqldf'))"
RUN R -e "install.packages(c('gsubfn'))"
RUN R -e "install.packages(c('proto'))"
RUN R -e "install.packages(c('randomForest'))"
RUN R -e "install.packages(c('plotly'))"
RUN R -e "install.packages(c('DT'))"
RUN R -e "install.packages(c('plyr','dplyr'))"
RUN R -e "install.packages(c('data.table'))"
RUN R -e "install.packages(c('tidyr'))"
RUN R -e "install.packages(c('lubridate'))"
RUN R -e "install.packages(c('shinycssloaders'))"
RUN R -e "install.packages(c('shinyjs'))"
RUN R -e "install.packages(c('stringr'))"
RUN R -e "install.packages(c('stringi'))"
RUN R -e "install.packages(c('shinyFiles'))"
RUN R -e "install.packages(c('DBI'))"
RUN R -e "install.packages(c('readxl'))"
RUN R -e "install.packages(c('installr'))"
RUN R -e "install.packages(c('smbinning'))"

#copy app to image
COPY app/ srv/shiny-server/app

COPY shiny-server.conf/ etc/shiny-server/shiny-server.conf

如果我遗漏了什么,请告知。非常感谢。

【问题讨论】:

【参考方案1】:

我在使用 Docker 在出色的 DigitalOcean 应用程序服务上部署闪亮的应用程序时遇到了类似的问题。我使用的解决方法是强制应用程序每 10 秒在后台执行一次操作。这样做的缺点是它可能永远不会超时......但这应该根据 DO 应用程序是短暂的这一事实进行排序,因此非活动会话应该结束(我认为......)

(我从SO的其他地方借用了这段代码,不记得在哪里)

在server.R的底部...

  #Stop the app timing out
  autoInvalidate <- reactiveTimer(10000)
  observe(
    autoInvalidate()
    cat(".")
  )

【讨论】:

谢谢,但对应用没有影响。

以上是关于R Shiny App 在 60 秒内超时,即使在 conf 文件中传递了 app_init_timeout 设置后也是如此的主要内容,如果未能解决你的问题,请参考以下文章

错误 R10 - Web 进程在启动后 60 秒内未能绑定到 $PORT

错误 R10(启动超时)-> Web 进程未能在启动后 60 秒内绑定到 $PORT - HEROKU ERROR

在 python 上获取“错误 R10(启动超时)-> Web 进程未能在启动后 60 秒内绑定到 $PORT”

Heroku discord bot 托管错误 R10(启动超时)-> Web 进程在启动后 60 秒内无法绑定到 $PORT

Heroku Node.js 错误 R10(启动超时)-> Web 进程在启动后 60 秒内无法绑定到 $PORT

注销时清除超时的问题