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