R параллельные вычисления и Shiny Server с использованием Dockerfile - PullRequest
1 голос
/ 22 апреля 2019

Мне нужна помощь с использованием параллельных вычислений и пакета future с блестящей внутри контейнера Docker. Когда я вставляю свое приложение в shinyapps.io, оно работает нормально, но если я использую Docker, оно выдает мне следующую ошибку в журнале.

[2019-04-22T19:49:24.320] [INFO] shiny-server - Shiny Server v1.5.7.890 (Node.js v8.10.0) [2019-04-22T19:49:24.325] [INFO] shiny-server - Using config file "/etc/shiny-server/shiny-server.conf" 
[2019-04-22T19:49:24.440] [INFO] shiny-server - Starting listener on 0.0.0.0:80
[2019-04-22T19:49:29.399] [INFO] shiny-server - Created bookmark state directory: /var/lib/shiny-server/bookmarks
[2019-04-22T19:49:29.401] [INFO] shiny-server - Created user bookmark state directory: /var/lib/shiny-server/bookmarks/shiny
[2019-04-22T19:50:30.486] [INFO] shiny-server - Error getting worker: Error: The application took too long to respond.
[2019-04-22T19:50:30.488] [INFO] shiny-server - Error getting worker: Error: The application took too long to respond.
[2019-04-22T19:50:30.489] [INFO] shiny-server - Error getting worker: Error: The application took too long to respond.

Мой Dockerfile использует R, блестящий сервер, соединение с Postgres и sqlite. Если я не использую future, он работает без ошибок.

# Install R version 3.5
FROM r-base:3.5.1

# Install Ubuntu packages
RUN apt-get update && apt-get install -y \
    sudo \
    gdebi-core \
    pandoc \
    pandoc-citeproc \
    libcurl4-gnutls-dev \
    libcairo2-dev/unstable \
    libxt-dev \
    libssl-dev \
    libpq-dev


# Download and install ShinyServer (latest version)
RUN wget --no-verbose https://s3.amazonaws.com/rstudio-shiny-server-os-build/ubuntu-12.04/x86_64/VERSION -O "version.txt" && \
    VERSION=$(cat version.txt)  && \
    wget --no-verbose "https://s3.amazonaws.com/rstudio-shiny-server-os-build/ubuntu-12.04/x86_64/shiny-server-$VERSION-amd64.deb" -O ss-latest.deb && \
    gdebi -n ss-latest.deb && \
    rm -f version.txt ss-latest.deb


# Install SQLite
RUN apt-get update && \
    DEBIAN_FRONTEND=noninteractive apt-get -yq install sqlite3 && \
    rm -rf /var/lib/apt/lists/* /tmp/* /var/tmp/*


# Install R packages that are required
# TODO: add further package if you need!
RUN R -e "install.packages(c('RSQLite', 'RPostgres', 'readxl', 'dplyr', 'lubridate', 'DT', 'billboarder', 'shiny', 'future'), repos='http://cran.rstudio.com/')"


# Copy configuration files into the Docker image
COPY shiny-server.conf  /etc/shiny-server/shiny-server.conf
COPY /app /srv/shiny-server/


# Give permission of READWRITE for the SQLite database
RUN chmod a+rw /srv/shiny-server/db/ /srv/shiny-server/db/*


# Make the ShinyApp available at port 80
EXPOSE 80


# Copy further configuration files into the Docker image
COPY shiny-server.sh /usr/bin/shiny-server.sh


CMD ["/usr/bin/shiny-server.sh"]

В качестве примера приложения я попробовал загрузить файл global.R shiny и future и выполнить что-то вроде

library(shiny)
library(future)

plan(multiprocess) 
future({print(1)})

с минимальным ui.R (например, FluidPage()) и server.R (например, server <- function(input, output) {}). Бьюсь об заклад, я использую среду Windows 7, и это вызывает путаницу в multiprocess, если я могу просто отправить приложение в свой ИТ-отдел прямо сейчас, чтобы они развернули его на сервере Linux, ИЛИ в нем нет linux библиотека или что-то в этом роде, чего я пока не мог найти. Заранее спасибо.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...